tx · A4oWSYra7pmsHUmRHQsaMz2rzNceE5pNwDnvqA8uuR1U

3Mx2CdxmLU49Cdp4KfRWxTTW4YaBntJFvEo:  -0.02900000 Waves

2023.05.04 13:14 [2562880] smart account 3Mx2CdxmLU49Cdp4KfRWxTTW4YaBntJFvEo > SELF 0.00000000 Waves

{ "type": 13, "id": "A4oWSYra7pmsHUmRHQsaMz2rzNceE5pNwDnvqA8uuR1U", "fee": 2900000, "feeAssetId": null, "timestamp": 1683195301746, "version": 2, "chainId": 84, "sender": "3Mx2CdxmLU49Cdp4KfRWxTTW4YaBntJFvEo", "senderPublicKey": "8ADc4gyHar89vZD2Z5UCJpkDhV4ogKsaYAJQqHRjd9uS", "proofs": [ "4GW9Rd9Ch7yWoPZPbGYYvZfb3qQzjbMgDUVqVxE7o2E5QuEzyBKiUPFZEBDs7HKhy1chowx6EHwFWzSEn5S5YWQ5" ], "script": "base64:BgJVCAISBAoCCAESBwoFCAgICAESBAoCCAgSBQoDCAgBEgQKAggIEgMKAQESAwoBARIECgIICBIECgIIBBIAEgMKAQESABIECgIICBIECgIICBIECgIICDgACXNlcGFyYXRvcgICX18ADnBvb2xXZWlnaHRNdWx0AIDC1y8AD21heERlcHRoRGVmYXVsdAAKABZmaW5hbGl6YXRpb25TdGFnZVRvdGFsAAAAF2ZpbmFsaXphdGlvblN0YWdlU2hhcmVzAAEADmtleUVwb2NoTGVuZ3RoCQC5CQIJAMwIAgICJXMJAMwIAgILZXBvY2hMZW5ndGgFA25pbAUJc2VwYXJhdG9yABFrZXlFcG9jaExlbmd0aE5ldwkAuQkCCQDMCAICBCVzJXMJAMwIAgIQZXBvY2hMZW5ndGhfX25ldwUDbmlsBQlzZXBhcmF0b3IBFWtleUVwb2NoTGVuZ3RoQnlFcG9jaAEFZXBvY2gJALkJAgkAzAgCAgQlcyVkCQDMCAICC2Vwb2NoTGVuZ3RoCQDMCAIJAKQDAQUFZXBvY2gFA25pbAUJc2VwYXJhdG9yAA9rZXlDdXJyZW50RXBvY2gJALkJAgkAzAgCAgIlcwkAzAgCAgxjdXJyZW50RXBvY2gFA25pbAUJc2VwYXJhdG9yAAtrZXlNYXhEZXB0aAkAuQkCCQDMCAICAiVzCQDMCAICCG1heERlcHRoBQNuaWwFCXNlcGFyYXRvcgAia2V5Vm90aW5nRW1pc3Npb25DYW5kaWRhdGVDb250cmFjdAkAuQkCCQDMCAICAiVzCQDMCAICH3ZvdGluZ0VtaXNzaW9uQ2FuZGlkYXRlQ29udHJhY3QFA25pbAUJc2VwYXJhdG9yABJrZXlGYWN0b3J5Q29udHJhY3QJALkJAgkAzAgCAgIlcwkAzAgCAg9mYWN0b3J5Q29udHJhY3QFA25pbAUJc2VwYXJhdG9yABNrZXlCb29zdGluZ0NvbnRyYWN0CQC5CQIJAMwIAgICJXMJAMwIAgIQYm9vc3RpbmdDb250cmFjdAUDbmlsBQlzZXBhcmF0b3IAEmtleVN0YWtpbmdDb250cmFjdAkAuQkCCQDMCAICAiVzCQDMCAICD3N0YWtpbmdDb250cmFjdAUDbmlsBQlzZXBhcmF0b3IAFGtleUZpbmFsaXphdGlvblN0YWdlCQC5CQIJAMwIAgICJXMJAMwIAgIRZmluYWxpemF0aW9uU3RhZ2UFA25pbAUJc2VwYXJhdG9yAAtrZXlOZXh0UG9vbAkAuQkCCQDMCAICAiVzCQDMCAICCG5leHRQb29sBQNuaWwFCXNlcGFyYXRvcgALa2V5TmV4dFVzZXIJALkJAgkAzAgCAgIlcwkAzAgCAghuZXh0VXNlcgUDbmlsBQlzZXBhcmF0b3IADmtleVN0YXJ0SGVpZ2h0CQC5CQIJAMwIAgICJXMJAMwIAgILc3RhcnRIZWlnaHQFA25pbAUJc2VwYXJhdG9yABFrZXlDdXJyZW50RXBvY2hVaQkAuQkCCQDMCAICAiVzCQDMCAICDmN1cnJlbnRFcG9jaFVpBQNuaWwFCXNlcGFyYXRvcgAQa2V5U3RhcnRIZWlnaHRVaQkAuQkCCQDMCAICAiVzCQDMCAICDXN0YXJ0SGVpZ2h0VWkFA25pbAUJc2VwYXJhdG9yAB1rZXlGaW5hbGl6YXRpb25TaG91bGRCZUZvcmNlZAkAuQkCCQDMCAICAiVzCQDMCAICBWZvcmNlBQNuaWwFCXNlcGFyYXRvcgEVa2V5U3RhcnRIZWlnaHRCeUVwb2NoAQVlcG9jaAkAuQkCCQDMCAICBCVzJWQJAMwIAgILc3RhcnRIZWlnaHQJAMwIAgkApAMBBQVlcG9jaAUDbmlsBQlzZXBhcmF0b3IBDGtleUZpbmFsaXplZAEFZXBvY2gJALkJAgkAzAgCAgQlcyVkCQDMCAICCWZpbmFsaXplZAkAzAgCCQCkAwEFBWVwb2NoBQNuaWwFCXNlcGFyYXRvcgEJa2V5SW5MaXN0AQRwb29sBAskdDAxNjkzMTczMwUEcG9vbAQNYW1vdW50QXNzZXRJZAgFCyR0MDE2OTMxNzMzAl8xBAxwcmljZUFzc2V0SWQIBQskdDAxNjkzMTczMwJfMgkAuQkCCQDMCAICBiVzJXMlcwkAzAgCAgZpbkxpc3QJAMwIAgUNYW1vdW50QXNzZXRJZAkAzAgCBQxwcmljZUFzc2V0SWQFA25pbAUJc2VwYXJhdG9yAQdrZXlVc2VkAgdhZGRyZXNzBWVwb2NoCQC5CQIJAMwIAgIGJXMlcyVkCQDMCAICBHVzZWQJAMwIAgkApQgBBQdhZGRyZXNzCQDMCAIJAKQDAQUFZXBvY2gFA25pbAUJc2VwYXJhdG9yAQdrZXlWb3RlAwRwb29sB2FkZHJlc3MFZXBvY2gECyR0MDIwMDcyMDQ3BQRwb29sBA1hbW91bnRBc3NldElkCAULJHQwMjAwNzIwNDcCXzEEDHByaWNlQXNzZXRJZAgFCyR0MDIwMDcyMDQ3Al8yCQC5CQIJAMwIAgIKJXMlcyVzJXMlZAkAzAgCAgR2b3RlCQDMCAIFDWFtb3VudEFzc2V0SWQJAMwIAgUMcHJpY2VBc3NldElkCQDMCAIJAKUIAQUHYWRkcmVzcwkAzAgCCQCkAwEFBWVwb2NoBQNuaWwFCXNlcGFyYXRvcgEPa2V5Vm90aW5nUmVzdWx0AgRwb29sBWVwb2NoBAskdDAyMjI5MjI2OQUEcG9vbAQNYW1vdW50QXNzZXRJZAgFCyR0MDIyMjkyMjY5Al8xBAxwcmljZUFzc2V0SWQIBQskdDAyMjI5MjI2OQJfMgkAuQkCCQDMCAICCCVzJXMlcyVkCQDMCAICDHZvdGluZ1Jlc3VsdAkAzAgCBQ1hbW91bnRBc3NldElkCQDMCAIFDHByaWNlQXNzZXRJZAkAzAgCCQCkAwEFBWVwb2NoBQNuaWwFCXNlcGFyYXRvcgEVa2V5Vm90aW5nUmVzdWx0U3Rha2VkAgxscEFzc2V0SWRTdHIFZXBvY2gJALkJAgkAzAgCAgYlcyVzJWQJAMwIAgISdm90aW5nUmVzdWx0U3Rha2VkCQDMCAIFDGxwQXNzZXRJZFN0cgkAzAgCCQCkAwEFBWVwb2NoBQNuaWwFCXNlcGFyYXRvcgEMa2V5UG9vbFNoYXJlAgRwb29sBWVwb2NoBAskdDAyNTkwMjYzMAUEcG9vbAQNYW1vdW50QXNzZXRJZAgFCyR0MDI1OTAyNjMwAl8xBAxwcmljZUFzc2V0SWQIBQskdDAyNTkwMjYzMAJfMgkAuQkCCQDMCAICCCVzJXMlcyVkCQDMCAICCXBvb2xTaGFyZQkAzAgCBQ1hbW91bnRBc3NldElkCQDMCAIFDHByaWNlQXNzZXRJZAkAzAgCCQCkAwEFBWVwb2NoBQNuaWwFCXNlcGFyYXRvcgENa2V5VG90YWxWb3RlcwEFZXBvY2gJALkJAgkAzAgCAgQlcyVkCQDMCAICCnRvdGFsVm90ZXMJAMwIAgkApAMBBQVlcG9jaAUDbmlsBQlzZXBhcmF0b3IBD2tleVN0YWtlZEJ5VXNlcgIMbHBBc3NldElkU3RyDnVzZXJBZGRyZXNzU3RyCQC5CQIJAMwIAgIGJXMlcyVzCQDMCAICBnN0YWtlZAkAzAgCBQ51c2VyQWRkcmVzc1N0cgkAzAgCBQxscEFzc2V0SWRTdHIFA25pbAUJc2VwYXJhdG9yAQd3cmFwRXJyAQNtc2cJALkJAgkAzAgCAhV2b3RpbmdfZW1pc3Npb24ucmlkZToJAMwIAgUDbXNnBQNuaWwCASABCHRocm93RXJyAQNtc2cJAAIBCQEHd3JhcEVycgEFA21zZwEOZ2V0VmFsdWVPckZhaWwDB2FkZHJlc3MDa2V5BHR5cGUEBWVycm9yCQEHd3JhcEVycgEJALkJAgkAzAgCAgptYW5kYXRvcnkgCQDMCAIJAKUIAQUHYWRkcmVzcwkAzAgCAgEuCQDMCAIFA2tleQkAzAgCAg8gaXMgbm90IGRlZmluZWQFA25pbAIACQETdmFsdWVPckVycm9yTWVzc2FnZQIEByRtYXRjaDAFBHR5cGUDCQABAgUHJG1hdGNoMAIGU3RyaW5nBANzdHIFByRtYXRjaDAJAJ0IAgUHYWRkcmVzcwUDa2V5AwkAAQIFByRtYXRjaDACA0ludAQDaW50BQckbWF0Y2gwCQCaCAIFB2FkZHJlc3MFA2tleQkBCHRocm93RXJyAQISaW52YWxpZCBlbnRyeSB0eXBlBQVlcnJvcgEMZ2V0U3RyT3JGYWlsAgdhZGRyZXNzA2tleQoAAUAJAQ5nZXRWYWx1ZU9yRmFpbAMFB2FkZHJlc3MFA2tleQIAAwkAAQIFAUACBlN0cmluZwUBQAkAAgEJAKwCAgkAAwEFAUACGyBjb3VsZG4ndCBiZSBjYXN0IHRvIFN0cmluZwEMZ2V0SW50T3JGYWlsAgdhZGRyZXNzA2tleQoAAUAJAQ5nZXRWYWx1ZU9yRmFpbAMFB2FkZHJlc3MFA2tleQAAAwkAAQIFAUACA0ludAUBQAkAAgEJAKwCAgkAAwEFAUACGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAEMcG9vbFRvU3RyaW5nAQRwb29sCQCsAgIJAKwCAggFBHBvb2wCXzEFCXNlcGFyYXRvcggFBHBvb2wCXzIBDHN0cmluZ1RvUG9vbAEDc3RyBAVwYXJ0cwkAtQkCBQNzdHIFCXNlcGFyYXRvcgMJAAACCQCQAwEFBXBhcnRzAAIJAJQKAgkAkQMCBQVwYXJ0cwAACQCRAwIFBXBhcnRzAAEJAQh0aHJvd0VycgECE2ludmFsaWQgcG9vbCBzdHJpbmcBFmdldExwQXNzZXRCeVBvb2xBc3NldHMCDWFtb3VudEFzc2V0SWQMcHJpY2VBc3NldElkCgEfa2V5TWFwcGluZ3NCYXNlQXNzZXQyaW50ZXJuYWxJZAEMYmFzZUFzc2V0U3RyCQCsAgICKCVzJXMlc19fbWFwcGluZ3NfX2Jhc2VBc3NldDJpbnRlcm5hbElkX18FDGJhc2VBc3NldFN0cgoBKWtleU1hcHBpbmdQb29sQXNzZXRzVG9Qb29sQ29udHJhY3RBZGRyZXNzAhhpbnRlcm5hbEFtb3VudEFzc2V0SWRTdHIXaW50ZXJuYWxQcmljZUFzc2V0SWRTdHIJAKwCAgkArAICCQCsAgIJAKwCAgIKJWQlZCVzJXNfXwkApAMBBRhpbnRlcm5hbEFtb3VudEFzc2V0SWRTdHICAl9fCQCkAwEFF2ludGVybmFsUHJpY2VBc3NldElkU3RyAiNfX21hcHBpbmdzX19wb29sQXNzZXRzMlBvb2xDb250cmFjdAoBH2tleU1hcHBpbmdQb29sQ29udHJhY3RUb0xQQXNzZXQBE3Bvb2xDb250cmFjdEFkZHJlc3MJAKwCAgkArAICAgglcyVzJXNfXwUTcG9vbENvbnRyYWN0QWRkcmVzcwIgX19tYXBwaW5nc19fcG9vbENvbnRyYWN0MkxwQXNzZXQED2ZhY3RvcnlDb250cmFjdAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBDGdldFN0ck9yRmFpbAIFBHRoaXMFEmtleUZhY3RvcnlDb250cmFjdAQVYW1vdW50QXNzZXRJbnRlcm5hbElkCQEMZ2V0SW50T3JGYWlsAgUPZmFjdG9yeUNvbnRyYWN0CQEfa2V5TWFwcGluZ3NCYXNlQXNzZXQyaW50ZXJuYWxJZAEFDWFtb3VudEFzc2V0SWQEFHByaWNlQXNzZXRJbnRlcm5hbElkCQEMZ2V0SW50T3JGYWlsAgUPZmFjdG9yeUNvbnRyYWN0CQEfa2V5TWFwcGluZ3NCYXNlQXNzZXQyaW50ZXJuYWxJZAEFDHByaWNlQXNzZXRJZAQTcG9vbENvbnRyYWN0QWRkcmVzcwkBDGdldFN0ck9yRmFpbAIFD2ZhY3RvcnlDb250cmFjdAkBKWtleU1hcHBpbmdQb29sQXNzZXRzVG9Qb29sQ29udHJhY3RBZGRyZXNzAgUVYW1vdW50QXNzZXRJbnRlcm5hbElkBRRwcmljZUFzc2V0SW50ZXJuYWxJZAQJbHBBc3NldElkCQEMZ2V0U3RyT3JGYWlsAgUPZmFjdG9yeUNvbnRyYWN0CQEfa2V5TWFwcGluZ1Bvb2xDb250cmFjdFRvTFBBc3NldAEFE3Bvb2xDb250cmFjdEFkZHJlc3MFCWxwQXNzZXRJZAEYY2hlY2tXeEVtaXNzaW9uUG9vbExhYmVsAQRwb29sBAskdDA1MTY4NTIwOAUEcG9vbAQNYW1vdW50QXNzZXRJZAgFCyR0MDUxNjg1MjA4Al8xBAxwcmljZUFzc2V0SWQIBQskdDA1MTY4NTIwOAJfMgQPZmFjdG9yeUNvbnRyYWN0CQERQGV4dHJOYXRpdmUoMTA2MikBCQEMZ2V0U3RyT3JGYWlsAgUEdGhpcwUSa2V5RmFjdG9yeUNvbnRyYWN0CgABQAkA/AcEBQ9mYWN0b3J5Q29udHJhY3QCGGNoZWNrV3hFbWlzc2lvblBvb2xMYWJlbAkAzAgCBQ1hbW91bnRBc3NldElkCQDMCAIFDHByaWNlQXNzZXRJZAUDbmlsBQNuaWwDCQABAgUBQAIHQm9vbGVhbgUBQAkAAgEJAKwCAgkAAwEFAUACHCBjb3VsZG4ndCBiZSBjYXN0IHRvIEJvb2xlYW4ADXBvb2xzTGlzdE5hbWUCBXBvb2xzARBnZXRWb3Rlc0xpc3ROYW1lAQRwb29sBAskdDA1NTA5NTU0OQUEcG9vbAQNYW1vdW50QXNzZXRJZAgFCyR0MDU1MDk1NTQ5Al8xBAxwcmljZUFzc2V0SWQIBQskdDA1NTA5NTU0OQJfMgkAuQkCCQDMCAICBXZvdGVzCQDMCAIFDWFtb3VudEFzc2V0SWQJAMwIAgUMcHJpY2VBc3NldElkBQNuaWwFCXNlcGFyYXRvcgELa2V5TGlzdEhlYWQBCGxpc3ROYW1lBARtZXRhAwkAAAIFCGxpc3ROYW1lBQ1wb29sc0xpc3ROYW1lAgQlcyVzAgglcyVzJXMlcwkAuQkCCQDMCAIFBG1ldGEJAMwIAgUIbGlzdE5hbWUJAMwIAgIEaGVhZAUDbmlsBQlzZXBhcmF0b3IBC2tleUxpc3RTaXplAQhsaXN0TmFtZQQEbWV0YQMJAAACBQhsaXN0TmFtZQUNcG9vbHNMaXN0TmFtZQIEJXMlcwIIJXMlcyVzJXMJALkJAgkAzAgCBQRtZXRhCQDMCAIFCGxpc3ROYW1lCQDMCAICBHNpemUFA25pbAUJc2VwYXJhdG9yAQtrZXlMaXN0UHJldgIIbGlzdE5hbWUCaWQEBG1ldGEDCQAAAgUIbGlzdE5hbWUFDXBvb2xzTGlzdE5hbWUCCCVzJXMlcyVzAgolcyVzJXMlcyVzCQC5CQIJAMwIAgUEbWV0YQkAzAgCBQhsaXN0TmFtZQkAzAgCBQJpZAkAzAgCAgRwcmV2BQNuaWwFCXNlcGFyYXRvcgELa2V5TGlzdE5leHQCCGxpc3ROYW1lAmlkBARtZXRhAwkAAAIFCGxpc3ROYW1lBQ1wb29sc0xpc3ROYW1lAgglcyVzJXMlcwIKJXMlcyVzJXMlcwkAuQkCCQDMCAIFBG1ldGEJAMwIAgUIbGlzdE5hbWUJAMwIAgUCaWQJAMwIAgIEbmV4dAUDbmlsBQlzZXBhcmF0b3IBDGNvbnRhaW5zTm9kZQIIbGlzdE5hbWUCaWQECmhlYWRPclVuaXQJAJ0IAgUEdGhpcwkBC2tleUxpc3RIZWFkAQUIbGlzdE5hbWUECnByZXZPclVuaXQJAJ0IAgUEdGhpcwkBC2tleUxpc3RQcmV2AgUIbGlzdE5hbWUFAmlkBApuZXh0T3JVbml0CQCdCAIFBHRoaXMJAQtrZXlMaXN0TmV4dAIFCGxpc3ROYW1lBQJpZAMDCQAAAgUCaWQJAQt2YWx1ZU9yRWxzZQIFCmhlYWRPclVuaXQCAAYJAQIhPQIFCnByZXZPclVuaXQFBHVuaXQGCQECIT0CBQpuZXh0T3JVbml0BQR1bml0ARFpbnNlcnROb2RlQWN0aW9ucwIIbGlzdE5hbWUCaWQECmhlYWRPclVuaXQJAJ0IAgUEdGhpcwkBC2tleUxpc3RIZWFkAQUIbGlzdE5hbWUECGxpc3RTaXplCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQtrZXlMaXN0U2l6ZQEFCGxpc3ROYW1lAAAECWNoZWNrTm9kZQMJAQEhAQkBDGNvbnRhaW5zTm9kZQIFCGxpc3ROYW1lBQJpZAYJAQh0aHJvd0VycgECC05vZGUgZXhpc3RzAwkAAAIFCWNoZWNrTm9kZQUJY2hlY2tOb2RlCQDOCAIJAM4IAgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBC2tleUxpc3RTaXplAQUIbGlzdE5hbWUJAGQCBQhsaXN0U2l6ZQABBQNuaWwDCQECIT0CBQpoZWFkT3JVbml0BQR1bml0CQDMCAIJAQtTdHJpbmdFbnRyeQIJAQtrZXlMaXN0TmV4dAIFCGxpc3ROYW1lBQJpZAkBBXZhbHVlAQUKaGVhZE9yVW5pdAkAzAgCCQELU3RyaW5nRW50cnkCCQELa2V5TGlzdFByZXYCBQhsaXN0TmFtZQkBBXZhbHVlAQUKaGVhZE9yVW5pdAUCaWQFA25pbAUDbmlsCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQtrZXlMaXN0SGVhZAEFCGxpc3ROYW1lBQJpZAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuARFkZWxldGVOb2RlQWN0aW9ucwIIbGlzdE5hbWUCaWQECmhlYWRPclVuaXQJAJ0IAgUEdGhpcwkBC2tleUxpc3RIZWFkAQUIbGlzdE5hbWUECGxpc3RTaXplCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQtrZXlMaXN0U2l6ZQEFCGxpc3ROYW1lAAAECnByZXZPclVuaXQJAJ0IAgUEdGhpcwkBC2tleUxpc3RQcmV2AgUIbGlzdE5hbWUFAmlkBApuZXh0T3JVbml0CQCdCAIFBHRoaXMJAQtrZXlMaXN0TmV4dAIFCGxpc3ROYW1lBQJpZAkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQELa2V5TGlzdFNpemUBBQhsaXN0TmFtZQkAZQIFCGxpc3RTaXplAAEFA25pbAMDCQECIT0CBQpwcmV2T3JVbml0BQR1bml0CQECIT0CBQpuZXh0T3JVbml0BQR1bml0BwkAzAgCCQELU3RyaW5nRW50cnkCCQELa2V5TGlzdE5leHQCBQhsaXN0TmFtZQkBBXZhbHVlAQUKcHJldk9yVW5pdAkBBXZhbHVlAQUKbmV4dE9yVW5pdAkAzAgCCQELU3RyaW5nRW50cnkCCQELa2V5TGlzdFByZXYCBQhsaXN0TmFtZQkBBXZhbHVlAQUKbmV4dE9yVW5pdAkBBXZhbHVlAQUKcHJldk9yVW5pdAkAzAgCCQELRGVsZXRlRW50cnkBCQELa2V5TGlzdFByZXYCBQhsaXN0TmFtZQUCaWQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBC2tleUxpc3ROZXh0AgUIbGlzdE5hbWUFAmlkBQNuaWwDCQECIT0CBQpuZXh0T3JVbml0BQR1bml0CQDMCAIJAQtTdHJpbmdFbnRyeQIJAQtrZXlMaXN0SGVhZAEFCGxpc3ROYW1lCQEFdmFsdWUBBQpuZXh0T3JVbml0CQDMCAIJAQtEZWxldGVFbnRyeQEJAQtrZXlMaXN0TmV4dAIFCGxpc3ROYW1lBQJpZAkAzAgCCQELRGVsZXRlRW50cnkBCQELa2V5TGlzdFByZXYCBQhsaXN0TmFtZQkBBXZhbHVlAQUKbmV4dE9yVW5pdAUDbmlsAwkBAiE9AgUKcHJldk9yVW5pdAUEdW5pdAkAzAgCCQELRGVsZXRlRW50cnkBCQELa2V5TGlzdFByZXYCBQhsaXN0TmFtZQUCaWQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBC2tleUxpc3ROZXh0AgUIbGlzdE5hbWUJAQV2YWx1ZQEFCnByZXZPclVuaXQFA25pbAMJAAACBQJpZAkBC3ZhbHVlT3JFbHNlAgUKaGVhZE9yVW5pdAIACQDMCAIJAQtEZWxldGVFbnRyeQEJAQtrZXlMaXN0SGVhZAEFCGxpc3ROYW1lBQNuaWwJAQh0aHJvd0VycgEJAKwCAgkArAICCQCsAgICDmludmFsaWQgbm9kZTogBQhsaXN0TmFtZQIBLgUCaWQBFmtleU1hbmFnZXJWYXVsdEFkZHJlc3MAAhclc19fbWFuYWdlclZhdWx0QWRkcmVzcwETa2V5TWFuYWdlclB1YmxpY0tleQACFCVzX19tYW5hZ2VyUHVibGljS2V5ARdnZXRNYW5hZ2VyQWRkcmVzc09yRmFpbAAJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARFAZXh0ck5hdGl2ZSgxMDU4KQEJARZrZXlNYW5hZ2VyVmF1bHRBZGRyZXNzAAEWbWFuYWdlclB1YmxpY0tleU9yVW5pdAAEE21hbmFnZXJWYXVsdEFkZHJlc3MJARdnZXRNYW5hZ2VyQWRkcmVzc09yRmFpbAAEByRtYXRjaDAJAJ0IAgUTbWFuYWdlclZhdWx0QWRkcmVzcwkBE2tleU1hbmFnZXJQdWJsaWNLZXkAAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAkA2QQBBQFzAwkAAQIFByRtYXRjaDACBFVuaXQFBHVuaXQJAAIBAgtNYXRjaCBlcnJvcgEJaXNNYW5hZ2VyAQFpBAckbWF0Y2gwCQEWbWFuYWdlclB1YmxpY0tleU9yVW5pdAADCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQCcGsFByRtYXRjaDAJAAACCAUBaQ9jYWxsZXJQdWJsaWNLZXkFAnBrAwkAAQIFByRtYXRjaDACBFVuaXQJAAACCAUBaQZjYWxsZXIFBHRoaXMJAAIBAgtNYXRjaCBlcnJvcgELbXVzdE1hbmFnZXIBAWkDCQEJaXNNYW5hZ2VyAQUBaQYJAAIBAhFwZXJtaXNzaW9uIGRlbmllZAEIbXVzdFRoaXMBAWkDCQAAAggFAWkGY2FsbGVyBQR0aGlzBgkAAgECEXBlcm1pc3Npb24gZGVuaWVkDwFpARhnZXRVc2VyR3d4QW1vdW50QXRIZWlnaHQCC3VzZXJBZGRyZXNzDHRhcmdldEhlaWdodAQXYm9vc3RpbmdDb250cmFjdEFkZHJlc3MJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQEMZ2V0U3RyT3JGYWlsAgUEdGhpcwUTa2V5Qm9vc3RpbmdDb250cmFjdAkBB3dyYXBFcnIBAiFpbnZhbGlkIGJvb3N0aW5nIGNvbnRyYWN0IGFkZHJlc3MJAJQKAgUDbmlsCgABQAkA/AcEBRdib29zdGluZ0NvbnRyYWN0QWRkcmVzcwIgZ2V0VXNlckd3eEFtb3VudEF0SGVpZ2h0UkVBRE9OTFkJAMwIAgULdXNlckFkZHJlc3MJAMwIAgUMdGFyZ2V0SGVpZ2h0BQNuaWwFA25pbAMJAAECBQFAAgNJbnQFAUAJAAIBCQCsAgIJAAMBBQFAAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQBaQELY29uc3RydWN0b3IFD2ZhY3RvcnlDb250cmFjdB92b3RpbmdFbWlzc2lvbkNhbmRpZGF0ZUNvbnRyYWN0EGJvb3N0aW5nQ29udHJhY3QPc3Rha2luZ0NvbnRyYWN0C2Vwb2NoTGVuZ3RoBAZjaGVja3MJAMwIAgkBC211c3RNYW5hZ2VyAQUBaQkAzAgCAwkBAiE9AgkApggBBQ9mYWN0b3J5Q29udHJhY3QFBHVuaXQGAiBpbnZhbGlkIGZhY3RvcnkgY29udHJhY3QgYWRkcmVzcwkAzAgCAwkBAiE9AgkApggBBR92b3RpbmdFbWlzc2lvbkNhbmRpZGF0ZUNvbnRyYWN0BQR1bml0BgIyaW52YWxpZCB2b3RpbmcgZW1pc3Npb24gY2FuZGlkYXRlIGNvbnRyYWN0IGFkZHJlc3MJAMwIAgMJAQIhPQIJAKYIAQUQYm9vc3RpbmdDb250cmFjdAUEdW5pdAYCIWludmFsaWQgYm9vc3RpbmcgY29udHJhY3QgYWRkcmVzcwkAzAgCAwkBAiE9AgkApggBBQ9zdGFraW5nQ29udHJhY3QFBHVuaXQGAiBpbnZhbGlkIHN0YWtpbmcgY29udHJhY3QgYWRkcmVzcwkAzAgCAwkAZgIFC2Vwb2NoTGVuZ3RoAAAGCQEIdGhyb3dFcnIBAhRpbnZhbGlkIGVwb2NoIGxlbmd0aAUDbmlsAwkAAAIFBmNoZWNrcwUGY2hlY2tzCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgUSa2V5RmFjdG9yeUNvbnRyYWN0BQ9mYWN0b3J5Q29udHJhY3QJAMwIAgkBC1N0cmluZ0VudHJ5AgUia2V5Vm90aW5nRW1pc3Npb25DYW5kaWRhdGVDb250cmFjdAUfdm90aW5nRW1pc3Npb25DYW5kaWRhdGVDb250cmFjdAkAzAgCCQELU3RyaW5nRW50cnkCBRNrZXlCb29zdGluZ0NvbnRyYWN0BRBib29zdGluZ0NvbnRyYWN0CQDMCAIJAQtTdHJpbmdFbnRyeQIFEmtleVN0YWtpbmdDb250cmFjdAUPc3Rha2luZ0NvbnRyYWN0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ5rZXlFcG9jaExlbmd0aAULZXBvY2hMZW5ndGgFA25pbAUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQZjcmVhdGUCDWFtb3VudEFzc2V0SWQMcHJpY2VBc3NldElkBAZjaGVja3MJAMwIAgMJAAACCQDYBAEICAUBaQZjYWxsZXIFYnl0ZXMJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwUia2V5Vm90aW5nRW1pc3Npb25DYW5kaWRhdGVDb250cmFjdAIABgkBC211c3RNYW5hZ2VyAQUBaQUDbmlsAwkAAAIFBmNoZWNrcwUGY2hlY2tzBARwb29sCQCUCgIFDWFtb3VudEFzc2V0SWQFDHByaWNlQXNzZXRJZAQNaW5MaXN0QWN0aW9ucwkAzggCCQDMCAIJAQxCb29sZWFuRW50cnkCCQEJa2V5SW5MaXN0AQUEcG9vbAYFA25pbAkBEWluc2VydE5vZGVBY3Rpb25zAgUNcG9vbHNMaXN0TmFtZQkBDHBvb2xUb1N0cmluZwEFBHBvb2wEGGN1cnJlbnRFcG9jaElzTm90RGVmaW5lZAkAAAIJAJoIAgUEdGhpcwUPa2V5Q3VycmVudEVwb2NoBQR1bml0BBJzdGFydEhlaWdodEFjdGlvbnMDBRhjdXJyZW50RXBvY2hJc05vdERlZmluZWQEBWVwb2NoAAAJAMwIAgkBDEludGVnZXJFbnRyeQIFD2tleUN1cnJlbnRFcG9jaAUFZXBvY2gJAMwIAgkBDEludGVnZXJFbnRyeQIJARVrZXlTdGFydEhlaWdodEJ5RXBvY2gBBQVlcG9jaAUGaGVpZ2h0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ5rZXlTdGFydEhlaWdodAUGaGVpZ2h0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBRFrZXlDdXJyZW50RXBvY2hVaQUFZXBvY2gJAMwIAgkBDEludGVnZXJFbnRyeQIFEGtleVN0YXJ0SGVpZ2h0VWkFBmhlaWdodAUDbmlsBQNuaWwJAJQKAgkAzggCBQ1pbkxpc3RBY3Rpb25zBRJzdGFydEhlaWdodEFjdGlvbnMFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEEdm90ZQMNYW1vdW50QXNzZXRJZAxwcmljZUFzc2V0SWQGYW1vdW50BARwb29sCQCUCgIFDWFtb3VudEFzc2V0SWQFDHByaWNlQXNzZXRJZAQFZXBvY2gJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUPa2V5Q3VycmVudEVwb2NoAAAEC3N0YXJ0SGVpZ2h0CQEMZ2V0SW50T3JGYWlsAgUEdGhpcwkBFWtleVN0YXJ0SGVpZ2h0QnlFcG9jaAEFBWVwb2NoBAtlcG9jaExlbmd0aAkBDGdldEludE9yRmFpbAIFBHRoaXMFDmtleUVwb2NoTGVuZ3RoBAllbmRIZWlnaHQJAGQCBQtzdGFydEhlaWdodAULZXBvY2hMZW5ndGgEF2ZpbmFsaXphdGlvblN0YWdlT3JVbml0CQCaCAIFBHRoaXMFFGtleUZpbmFsaXphdGlvblN0YWdlBAR1c2VkCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQdrZXlVc2VkAggFAWkGY2FsbGVyBQVlcG9jaAAABAR2b3RlCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQdrZXlWb3RlAwUEcG9vbAgFAWkGY2FsbGVyBQVlcG9jaAAABApwb29sUmVzdWx0CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQ9rZXlWb3RpbmdSZXN1bHQCBQRwb29sBQVlcG9jaAAABAp0b3RhbFZvdGVzCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQ1rZXlUb3RhbFZvdGVzAQUFZXBvY2gAAAQTZ3d4QW1vdW50QXRFbmRUb3RhbAoAAUAJAPwHBAUEdGhpcwIYZ2V0VXNlckd3eEFtb3VudEF0SGVpZ2h0CQDMCAIJANgEAQgIBQFpBmNhbGxlcgVieXRlcwkAzAgCBQllbmRIZWlnaHQFA25pbAUDbmlsAwkAAQIFAUACA0ludAUBQAkAAgEJAKwCAgkAAwEFAUACGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAQJYXZhaWxhYmxlCQBlAgUTZ3d4QW1vdW50QXRFbmRUb3RhbAUEdXNlZAQHbmV3Vm90ZQkAZAIFBHZvdGUFBmFtb3VudAQKd3hFbWlzc2lvbgkBGGNoZWNrV3hFbWlzc2lvblBvb2xMYWJlbAEFBHBvb2wEBmNoZWNrcwkAzAgCAwkBAiE9AgkAoAgBCQEJa2V5SW5MaXN0AQUEcG9vbAUEdW5pdAYJAQh0aHJvd0VycgECDmludmFsaWQgYXNzZXRzCQDMCAIDCQBmAgUJZW5kSGVpZ2h0BQZoZWlnaHQGCQEIdGhyb3dFcnIBAg5pbnZhbGlkIGhlaWdodAkAzAgCAwkAAAIFF2ZpbmFsaXphdGlvblN0YWdlT3JVbml0BQR1bml0BgkBCHRocm93RXJyAQIYZmluYWxpemF0aW9uIGluIHByb2dyZXNzCQDMCAIDCQBmAgUTZ3d4QW1vdW50QXRFbmRUb3RhbAAABgkBCHRocm93RXJyAQITeW91IGRvIG5vdCBoYXZlIGdXWAkAzAgCAwMJAGYCBQZhbW91bnQAAAkAZwIFCWF2YWlsYWJsZQUGYW1vdW50BwYJAQh0aHJvd0VycgECDmludmFsaWQgYW1vdW50CQDMCAIDBQp3eEVtaXNzaW9uBgkBCHRocm93RXJyAQIdcG9vbCBoYXNuJ3QgV1hfRU1JU1NJT04gbGFiZWwFA25pbAMJAAACBQZjaGVja3MFBmNoZWNrcwQNdm90ZXNMaXN0TmFtZQkBEGdldFZvdGVzTGlzdE5hbWUBBQRwb29sBA51c2VyQWRkcmVzc1N0cgkApQgBCAUBaQZjYWxsZXIEEHZvdGVzTGlzdEFjdGlvbnMDCQEMY29udGFpbnNOb2RlAgUNdm90ZXNMaXN0TmFtZQUOdXNlckFkZHJlc3NTdHIFA25pbAkBEWluc2VydE5vZGVBY3Rpb25zAgUNdm90ZXNMaXN0TmFtZQUOdXNlckFkZHJlc3NTdHIJAJQKAgkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEHa2V5VXNlZAIIBQFpBmNhbGxlcgUFZXBvY2gJAGQCBQR1c2VkBQZhbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIJAQdrZXlWb3RlAwUEcG9vbAgFAWkGY2FsbGVyBQVlcG9jaAUHbmV3Vm90ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBD2tleVZvdGluZ1Jlc3VsdAIFBHBvb2wFBWVwb2NoCQBkAgUKcG9vbFJlc3VsdAUGYW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQENa2V5VG90YWxWb3RlcwEFBWVwb2NoCQBkAgUKdG90YWxWb3RlcwUGYW1vdW50BQNuaWwFEHZvdGVzTGlzdEFjdGlvbnMFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEKY2FuY2VsVm90ZQINYW1vdW50QXNzZXRJZAxwcmljZUFzc2V0SWQEBHBvb2wJAJQKAgUNYW1vdW50QXNzZXRJZAUMcHJpY2VBc3NldElkBAVlcG9jaAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQ9rZXlDdXJyZW50RXBvY2gAAAQLc3RhcnRIZWlnaHQJAQxnZXRJbnRPckZhaWwCBQR0aGlzCQEVa2V5U3RhcnRIZWlnaHRCeUVwb2NoAQUFZXBvY2gEC2Vwb2NoTGVuZ3RoCQEMZ2V0SW50T3JGYWlsAgUEdGhpcwUOa2V5RXBvY2hMZW5ndGgECWVuZEhlaWdodAkAZAIFC3N0YXJ0SGVpZ2h0BQtlcG9jaExlbmd0aAQXZmluYWxpemF0aW9uU3RhZ2VPclVuaXQJAJoIAgUEdGhpcwUUa2V5RmluYWxpemF0aW9uU3RhZ2UEBHVzZWQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBB2tleVVzZWQCCAUBaQZjYWxsZXIFBWVwb2NoAAAEBHZvdGUJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBB2tleVZvdGUDBQRwb29sCAUBaQZjYWxsZXIFBWVwb2NoAAAECnBvb2xSZXN1bHQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBD2tleVZvdGluZ1Jlc3VsdAIFBHBvb2wFBWVwb2NoAAAECnRvdGFsVm90ZXMJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBDWtleVRvdGFsVm90ZXMBBQVlcG9jaAAABAZjaGVja3MJAMwIAgMJAQIhPQIJAKAIAQkBCWtleUluTGlzdAEFBHBvb2wFBHVuaXQGCQEIdGhyb3dFcnIBAg5pbnZhbGlkIGFzc2V0cwkAzAgCAwkAZgIFCWVuZEhlaWdodAUGaGVpZ2h0BgkBCHRocm93RXJyAQIOaW52YWxpZCBoZWlnaHQJAMwIAgMJAAACBRdmaW5hbGl6YXRpb25TdGFnZU9yVW5pdAUEdW5pdAYJAQh0aHJvd0VycgECGGZpbmFsaXphdGlvbiBpbiBwcm9ncmVzcwkAzAgCAwkAZgIFBHZvdGUAAAYJAQh0aHJvd0VycgECB25vIHZvdGUFA25pbAMJAAACBQZjaGVja3MFBmNoZWNrcwQNdm90ZXNMaXN0TmFtZQkBEGdldFZvdGVzTGlzdE5hbWUBBQRwb29sBA51c2VyQWRkcmVzc1N0cgkApQgBCAUBaQZjYWxsZXIJAJQKAgkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEHa2V5VXNlZAIIBQFpBmNhbGxlcgUFZXBvY2gJAJYDAQkAzAgCCQBlAgUEdXNlZAUEdm90ZQkAzAgCAAAFA25pbAkAzAgCCQELRGVsZXRlRW50cnkBCQEHa2V5Vm90ZQMFBHBvb2wIBQFpBmNhbGxlcgUFZXBvY2gJAMwIAgkBDEludGVnZXJFbnRyeQIJAQ9rZXlWb3RpbmdSZXN1bHQCBQRwb29sBQVlcG9jaAkAZQIFCnBvb2xSZXN1bHQFBHZvdGUJAMwIAgkBDEludGVnZXJFbnRyeQIJAQ1rZXlUb3RhbFZvdGVzAQUFZXBvY2gJAGUCBQp0b3RhbFZvdGVzBQR2b3RlBQNuaWwJARFkZWxldGVOb2RlQWN0aW9ucwIFDXZvdGVzTGlzdE5hbWUFDnVzZXJBZGRyZXNzU3RyBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBDnNldEVwb2NoTGVuZ3RoAQ5uZXdFcG9jaExlbmd0aAQGY2hlY2tzCQDMCAIJAQttdXN0TWFuYWdlcgEFAWkJAMwIAgMJAGYCBQ5uZXdFcG9jaExlbmd0aAAABgkBCHRocm93RXJyAQIUaW52YWxpZCBlcG9jaCBsZW5ndGgFA25pbAMJAAACBQZjaGVja3MFBmNoZWNrcwkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRFrZXlFcG9jaExlbmd0aE5ldwUObmV3RXBvY2hMZW5ndGgFA25pbAUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQtzZXRNYXhEZXB0aAELbmV3TWF4RGVwdGgEBmNoZWNrcwkAzAgCCQELbXVzdE1hbmFnZXIBBQFpCQDMCAIDCQBmAgULbmV3TWF4RGVwdGgAAAYJAQh0aHJvd0VycgECEWludmFsaWQgbWF4IGRlcHRoBQNuaWwDCQAAAgUGY2hlY2tzBQZjaGVja3MJAJQKAgkAzAgCCQEMSW50ZWdlckVudHJ5AgULa2V5TWF4RGVwdGgFC25ld01heERlcHRoBQNuaWwFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQETcHJvY2Vzc1ZvdGVJTlRFUk5BTAIHcG9vbFN0cg51c2VyQWRkcmVzc1N0cgQLY2hlY2tDYWxsZXIJAQhtdXN0VGhpcwEFAWkDCQAAAgULY2hlY2tDYWxsZXIFC2NoZWNrQ2FsbGVyBAt1c2VyQWRkcmVzcwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEFDnVzZXJBZGRyZXNzU3RyCQEHd3JhcEVycgEJAKwCAgIqcHJvY2Vzc1ZvdGVJTlRFUk5BTDogaW52YWxpZCB1c2VyIGFkZHJlc3MgBQ51c2VyQWRkcmVzc1N0cgQFZXBvY2gJAQxnZXRJbnRPckZhaWwCBQR0aGlzBQ9rZXlDdXJyZW50RXBvY2gEDWVwb2NoUHJldmlvdXMJAGUCBQVlcG9jaAABBAtlcG9jaExlbmd0aAkBDGdldEludE9yRmFpbAIFBHRoaXMFDmtleUVwb2NoTGVuZ3RoBAtzdGFydEhlaWdodAkBDGdldEludE9yRmFpbAIFBHRoaXMJARVrZXlTdGFydEhlaWdodEJ5RXBvY2gBBQVlcG9jaAQJZW5kSGVpZ2h0CQBkAgULc3RhcnRIZWlnaHQFC2Vwb2NoTGVuZ3RoBBNzdGFydEhlaWdodFByZXZpb3VzCQEMZ2V0SW50T3JGYWlsAgUEdGhpcwkBFWtleVN0YXJ0SGVpZ2h0QnlFcG9jaAEFDWVwb2NoUHJldmlvdXMEE2Vwb2NoTGVuZ3RoUHJldmlvdXMJAQxnZXRJbnRPckZhaWwCBQR0aGlzCQEVa2V5RXBvY2hMZW5ndGhCeUVwb2NoAQUNZXBvY2hQcmV2aW91cwQRZW5kSGVpZ2h0UHJldmlvdXMJAGQCBRNzdGFydEhlaWdodFByZXZpb3VzBRNlcG9jaExlbmd0aFByZXZpb3VzBBBjaGVja1RhcmdldEVwb2NoAwkAZwIFDWVwb2NoUHJldmlvdXMAAAYJAQh0aHJvd0VycgECK3Byb2Nlc3NWb3RlSU5URVJOQUw6IGludmFsaWQgcHJldmlvdXMgZXBvY2gDCQAAAgUQY2hlY2tUYXJnZXRFcG9jaAUQY2hlY2tUYXJnZXRFcG9jaAQEcG9vbAkBDHN0cmluZ1RvUG9vbAEFB3Bvb2xTdHIEDSR0MDE3NDg4MTc1MjgFBHBvb2wEDWFtb3VudEFzc2V0SWQIBQ0kdDAxNzQ4ODE3NTI4Al8xBAxwcmljZUFzc2V0SWQIBQ0kdDAxNzQ4ODE3NTI4Al8yBAp3eEVtaXNzaW9uCQEYY2hlY2tXeEVtaXNzaW9uUG9vbExhYmVsAQUEcG9vbAQTZ3d4QW1vdW50QXRFbmRUb3RhbAoAAUAJAPwHBAUEdGhpcwIYZ2V0VXNlckd3eEFtb3VudEF0SGVpZ2h0CQDMCAIFDnVzZXJBZGRyZXNzU3RyCQDMCAIFCWVuZEhlaWdodAUDbmlsBQNuaWwDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50BBtnd3hBbW91bnRBdEVuZFRvdGFsUHJldmlvdXMKAAFACQD8BwQFBHRoaXMCGGdldFVzZXJHd3hBbW91bnRBdEhlaWdodAkAzAgCBQ51c2VyQWRkcmVzc1N0cgkAzAgCBRFlbmRIZWlnaHRQcmV2aW91cwUDbmlsBQNuaWwDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50BAp0b3RhbFZvdGVzCQELdmFsdWVPckVsc2UCCQCfCAEJAQ1rZXlUb3RhbFZvdGVzAQUFZXBvY2gAAAQMdm90aW5nUmVzdWx0CQELdmFsdWVPckVsc2UCCQCfCAEJAQ9rZXlWb3RpbmdSZXN1bHQCBQRwb29sBQVlcG9jaAAABAx2b3RlUHJldmlvdXMJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnwgBCQEHa2V5Vm90ZQMFBHBvb2wFC3VzZXJBZGRyZXNzBQ1lcG9jaFByZXZpb3VzCQEHd3JhcEVycgEJAKwCAgkArAICCQCsAgIJAKwCAgIUcHJvY2Vzc1ZvdGVJTlRFUk5BTCAFB3Bvb2xTdHICASAFDnVzZXJBZGRyZXNzU3RyAhI6IG5vIHByZXZpb3VzIHZvdGUEBHVzZWQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBB2tleVVzZWQCBQt1c2VyQWRkcmVzcwUFZXBvY2gAAAQMbHBBc3NldElkU3RyCQEWZ2V0THBBc3NldEJ5UG9vbEFzc2V0cwIFDWFtb3VudEFzc2V0SWQFDHByaWNlQXNzZXRJZAQadm90aW5nUmVzdWx0U3Rha2VkUHJldmlvdXMJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBFWtleVZvdGluZ1Jlc3VsdFN0YWtlZAIFDGxwQXNzZXRJZFN0cgUNZXBvY2hQcmV2aW91cwAABA9zdGFraW5nQ29udHJhY3QJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQxnZXRTdHJPckZhaWwCBQR0aGlzBRJrZXlTdGFraW5nQ29udHJhY3QEDHN0YWtlZEJ5VXNlcgkBC3ZhbHVlT3JFbHNlAgkAmggCBQ9zdGFraW5nQ29udHJhY3QJAQ9rZXlTdGFrZWRCeVVzZXICBQxscEFzc2V0SWRTdHIFDnVzZXJBZGRyZXNzU3RyAAAEGXZvdGluZ1Jlc3VsdFN0YWtlZEFjdGlvbnMDCQAAAgUMc3Rha2VkQnlVc2VyAAAFA25pbAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBFWtleVZvdGluZ1Jlc3VsdFN0YWtlZAIFDGxwQXNzZXRJZFN0cgUNZXBvY2hQcmV2aW91cwkAZAIFGnZvdGluZ1Jlc3VsdFN0YWtlZFByZXZpb3VzBQx2b3RlUHJldmlvdXMFA25pbAQHbmV3Vm90ZQMJAGYCBRtnd3hBbW91bnRBdEVuZFRvdGFsUHJldmlvdXMAAAkAawMFDHZvdGVQcmV2aW91cwUTZ3d4QW1vdW50QXRFbmRUb3RhbAUbZ3d4QW1vdW50QXRFbmRUb3RhbFByZXZpb3VzAAAEB2FjdGlvbnMDAwkAZgIFB25ld1ZvdGUAAAUKd3hFbWlzc2lvbgcJAMwIAgkBDEludGVnZXJFbnRyeQIJAQdrZXlWb3RlAwUEcG9vbAULdXNlckFkZHJlc3MFBWVwb2NoBQduZXdWb3RlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQENa2V5VG90YWxWb3RlcwEFBWVwb2NoCQBkAgUKdG90YWxWb3RlcwUHbmV3Vm90ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBD2tleVZvdGluZ1Jlc3VsdAIFBHBvb2wFBWVwb2NoCQBkAgUMdm90aW5nUmVzdWx0BQduZXdWb3RlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEHa2V5VXNlZAIFC3VzZXJBZGRyZXNzBQVlcG9jaAkAZAIFBHVzZWQFB25ld1ZvdGUFA25pbAkBEWRlbGV0ZU5vZGVBY3Rpb25zAgkBEGdldFZvdGVzTGlzdE5hbWUBBQRwb29sBQ51c2VyQWRkcmVzc1N0cgkAlAoCCQDOCAIFB2FjdGlvbnMFGXZvdGluZ1Jlc3VsdFN0YWtlZEFjdGlvbnMFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQETcHJvY2Vzc1Bvb2xJTlRFUk5BTAIHcG9vbFN0cgVmb3JjZQQLY2hlY2tDYWxsZXIJAQhtdXN0VGhpcwEFAWkDCQAAAgULY2hlY2tDYWxsZXIFC2NoZWNrQ2FsbGVyBAt0YXJnZXRFcG9jaAQMY3VycmVudEVwb2NoCQEMZ2V0SW50T3JGYWlsAgUEdGhpcwUPa2V5Q3VycmVudEVwb2NoAwUFZm9yY2UFDGN1cnJlbnRFcG9jaAkAZQIFDGN1cnJlbnRFcG9jaAABBBBjaGVja1RhcmdldEVwb2NoAwkAZwIFC3RhcmdldEVwb2NoAAAGCQEIdGhyb3dFcnIBAilwcm9jZXNzUG9vbElOVEVSTkFMOiBpbnZhbGlkIHRhcmdldCBlcG9jaAMJAAACBRBjaGVja1RhcmdldEVwb2NoBRBjaGVja1RhcmdldEVwb2NoBARwb29sCQEMc3RyaW5nVG9Qb29sAQUHcG9vbFN0cgQNJHQwMTk4ODUxOTkyNQUEcG9vbAQNYW1vdW50QXNzZXRJZAgFDSR0MDE5ODg1MTk5MjUCXzEEDHByaWNlQXNzZXRJZAgFDSR0MDE5ODg1MTk5MjUCXzIED3N0YWtpbmdDb250cmFjdAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBDGdldFN0ck9yRmFpbAIFBHRoaXMFEmtleVN0YWtpbmdDb250cmFjdAQPZmFjdG9yeUNvbnRyYWN0CQERQGV4dHJOYXRpdmUoMTA2MikBCQEMZ2V0U3RyT3JGYWlsAgUEdGhpcwUSa2V5RmFjdG9yeUNvbnRyYWN0BAlscEFzc2V0SWQJARZnZXRMcEFzc2V0QnlQb29sQXNzZXRzAgUNYW1vdW50QXNzZXRJZAUMcHJpY2VBc3NldElkBAFyCgABQAkA/AcEBQ9zdGFraW5nQ29udHJhY3QCEnVzZXJzTGlzdFRyYXZlcnNhbAkAzAgCBQlscEFzc2V0SWQFA25pbAUDbmlsAwkAAQIFAUACB0Jvb2xlYW4FAUAJAAIBCQCsAgIJAAMBBQFAAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuAwkAAAIFAXIFAXIDBQFyCQCUCgIFA25pbAYECnd4RW1pc3Npb24JARhjaGVja1d4RW1pc3Npb25Qb29sTGFiZWwBBQRwb29sBAp0b3RhbFZvdGVzCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQ1rZXlUb3RhbFZvdGVzAQULdGFyZ2V0RXBvY2gAAAQMdm90aW5nUmVzdWx0CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQ9rZXlWb3RpbmdSZXN1bHQCBQRwb29sBQt0YXJnZXRFcG9jaAAABAVzaGFyZQMDCQAAAgUKdG90YWxWb3RlcwAABgkBASEBBQp3eEVtaXNzaW9uAAAJAGsDBQx2b3RpbmdSZXN1bHQFDnBvb2xXZWlnaHRNdWx0BQp0b3RhbFZvdGVzBA9tb2RpZnlXZWlnaHRJbnYJAPwHBAUPZmFjdG9yeUNvbnRyYWN0Agxtb2RpZnlXZWlnaHQJAMwIAgUJbHBBc3NldElkCQDMCAIFBXNoYXJlBQNuaWwFA25pbAMJAAACBQ9tb2RpZnlXZWlnaHRJbnYFD21vZGlmeVdlaWdodEludgQQcG9vbHNMaXN0QWN0aW9ucwMDBQp3eEVtaXNzaW9uBgUFZm9yY2UFA25pbAkAzggCCQDMCAIJAQtEZWxldGVFbnRyeQEJAQlrZXlJbkxpc3QBBQRwb29sBQNuaWwJARFkZWxldGVOb2RlQWN0aW9ucwIFDXBvb2xzTGlzdE5hbWUFB3Bvb2xTdHIJAJQKAgkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEMa2V5UG9vbFNoYXJlAgUEcG9vbAULdGFyZ2V0RXBvY2gFBXNoYXJlBQNuaWwFEHBvb2xzTGlzdEFjdGlvbnMHCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBDmZpbmFsaXplSGVscGVyAAQFZm9yY2UJAQt2YWx1ZU9yRWxzZQIJAKAIAQUda2V5RmluYWxpemF0aW9uU2hvdWxkQmVGb3JjZWQHBAVlcG9jaAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQ9rZXlDdXJyZW50RXBvY2gAAAQNcHJldmlvdXNFcG9jaAkAZQIFBWVwb2NoAAEEC3N0YXJ0SGVpZ2h0CQEMZ2V0SW50T3JGYWlsAgUEdGhpcwkBFWtleVN0YXJ0SGVpZ2h0QnlFcG9jaAEFBWVwb2NoBAtlcG9jaExlbmd0aAkBDGdldEludE9yRmFpbAIFBHRoaXMFDmtleUVwb2NoTGVuZ3RoBAllbmRIZWlnaHQJAGQCBQtzdGFydEhlaWdodAULZXBvY2hMZW5ndGgEF2ZpbmFsaXphdGlvblN0YWdlT3JVbml0CQCaCAIFBHRoaXMFFGtleUZpbmFsaXphdGlvblN0YWdlAwMDCQBnAgUGaGVpZ2h0BQllbmRIZWlnaHQJAAACBRdmaW5hbGl6YXRpb25TdGFnZU9yVW5pdAUEdW5pdAcJAQEhAQUFZm9yY2UHBAhuZXdFcG9jaAkAZAIFBWVwb2NoAAEEFG5ld0Vwb2NoTGVuZ3RoT3B0aW9uCQCaCAIFBHRoaXMFEWtleUVwb2NoTGVuZ3RoTmV3BBVuZXdFcG9jaExlbmd0aEFjdGlvbnMEByRtYXRjaDAFFG5ld0Vwb2NoTGVuZ3RoT3B0aW9uAwkAAQIFByRtYXRjaDACA0ludAQObmV3RXBvY2hMZW5ndGgFByRtYXRjaDAJAMwIAgkBDEludGVnZXJFbnRyeQIFDmtleUVwb2NoTGVuZ3RoBQ5uZXdFcG9jaExlbmd0aAkAzAgCCQELRGVsZXRlRW50cnkBBRFrZXlFcG9jaExlbmd0aE5ldwUDbmlsAwkAAQIFByRtYXRjaDACBFVuaXQFA25pbAkAAgECC01hdGNoIGVycm9yCQCUCgIJAM4IAgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBFWtleVN0YXJ0SGVpZ2h0QnlFcG9jaAEFCG5ld0Vwb2NoBQZoZWlnaHQJAMwIAgkBDEludGVnZXJFbnRyeQIFDmtleVN0YXJ0SGVpZ2h0BQZoZWlnaHQJAMwIAgkBDEludGVnZXJFbnRyeQIFD2tleUN1cnJlbnRFcG9jaAUIbmV3RXBvY2gJAMwIAgkBDEludGVnZXJFbnRyeQIFFGtleUZpbmFsaXphdGlvblN0YWdlBRZmaW5hbGl6YXRpb25TdGFnZVRvdGFsCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEVa2V5RXBvY2hMZW5ndGhCeUVwb2NoAQUFZXBvY2gFC2Vwb2NoTGVuZ3RoBQNuaWwFFW5ld0Vwb2NoTGVuZ3RoQWN0aW9ucwYDAwUFZm9yY2UJAAACBRdmaW5hbGl6YXRpb25TdGFnZU9yVW5pdAUEdW5pdAcJAJQKAgkAzAgCCQEMSW50ZWdlckVudHJ5AgUUa2V5RmluYWxpemF0aW9uU3RhZ2UFF2ZpbmFsaXphdGlvblN0YWdlU2hhcmVzBQNuaWwGAwkAAAIFF2ZpbmFsaXphdGlvblN0YWdlT3JVbml0BQR1bml0CQCUCgIFA25pbAcDCQAAAgUXZmluYWxpemF0aW9uU3RhZ2VPclVuaXQFFmZpbmFsaXphdGlvblN0YWdlVG90YWwECnBvb2xPclVuaXQJAKIIAQULa2V5TmV4dFBvb2wECnVzZXJPclVuaXQJAKIIAQULa2V5TmV4dFVzZXIEByRtYXRjaDAFCnBvb2xPclVuaXQDCQABAgUHJG1hdGNoMAIEVW5pdAQHJG1hdGNoMQkAoggBCQELa2V5TGlzdEhlYWQBBQ1wb29sc0xpc3ROYW1lAwkAAQIFByRtYXRjaDECBFVuaXQJAJQKAgkAzAgCCQEMSW50ZWdlckVudHJ5AgUUa2V5RmluYWxpemF0aW9uU3RhZ2UFF2ZpbmFsaXphdGlvblN0YWdlU2hhcmVzCQDMCAIJAQtEZWxldGVFbnRyeQEFC2tleU5leHRQb29sCQDMCAIJAQtEZWxldGVFbnRyeQEFC2tleU5leHRVc2VyBQNuaWwGAwkAAQIFByRtYXRjaDECBlN0cmluZwQMcG9vbHNIZWFkU3RyBQckbWF0Y2gxCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgULa2V5TmV4dFBvb2wFDHBvb2xzSGVhZFN0cgUDbmlsBgkAAgECC01hdGNoIGVycm9yAwkAAQIFByRtYXRjaDACBlN0cmluZwQHcG9vbFN0cgUHJG1hdGNoMAQEcG9vbAkBDHN0cmluZ1RvUG9vbAEFB3Bvb2xTdHIEDm5leHRVc2VyT3JVbml0BAckbWF0Y2gxBQp1c2VyT3JVbml0AwkAAQIFByRtYXRjaDECBFVuaXQJAKIIAQkBC2tleUxpc3RIZWFkAQkBEGdldFZvdGVzTGlzdE5hbWUBBQRwb29sAwkAAQIFByRtYXRjaDECBlN0cmluZwQEdXNlcgUHJG1hdGNoMQQEbmV4dAkAoggBCQELa2V5TGlzdE5leHQCCQEQZ2V0Vm90ZXNMaXN0TmFtZQEFBHBvb2wFBHVzZXIDCQAAAgUEbmV4dAUEbmV4dAQOcHJvY2Vzc1ZvdGVJbnYJAPwHBAUEdGhpcwITcHJvY2Vzc1ZvdGVJTlRFUk5BTAkAzAgCBQdwb29sU3RyCQDMCAIFBHVzZXIFA25pbAUDbmlsAwkAAAIFDnByb2Nlc3NWb3RlSW52BQ5wcm9jZXNzVm90ZUludgUEbmV4dAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECC01hdGNoIGVycm9yBAckbWF0Y2gxBQ5uZXh0VXNlck9yVW5pdAMJAAECBQckbWF0Y2gxAgRVbml0BA5uZXh0UG9vbE9yVW5pdAkAoggBCQELa2V5TGlzdE5leHQCBQ1wb29sc0xpc3ROYW1lBQdwb29sU3RyBAckbWF0Y2gyBQ5uZXh0UG9vbE9yVW5pdAMJAAECBQckbWF0Y2gyAgRVbml0CQCUCgIJAMwIAgkBDEludGVnZXJFbnRyeQIFFGtleUZpbmFsaXphdGlvblN0YWdlBRdmaW5hbGl6YXRpb25TdGFnZVNoYXJlcwkAzAgCCQELRGVsZXRlRW50cnkBBQtrZXlOZXh0UG9vbAkAzAgCCQELRGVsZXRlRW50cnkBBQtrZXlOZXh0VXNlcgUDbmlsBgMJAAECBQckbWF0Y2gyAgZTdHJpbmcEAXMFByRtYXRjaDIJAJQKAgkAzAgCCQELU3RyaW5nRW50cnkCBQtrZXlOZXh0UG9vbAUBcwkAzAgCCQELRGVsZXRlRW50cnkBBQtrZXlOZXh0VXNlcgUDbmlsBgkAAgECC01hdGNoIGVycm9yAwkAAQIFByRtYXRjaDECBlN0cmluZwQIbmV4dFVzZXIFByRtYXRjaDEJAJQKAgkAzAgCCQELU3RyaW5nRW50cnkCBQtrZXlOZXh0VXNlcgUIbmV4dFVzZXIFA25pbAYJAAIBAgtNYXRjaCBlcnJvcgkAAgECC01hdGNoIGVycm9yAwkAAAIFF2ZpbmFsaXphdGlvblN0YWdlT3JVbml0BRdmaW5hbGl6YXRpb25TdGFnZVNoYXJlcwQKcG9vbE9yVW5pdAkAoggBBQtrZXlOZXh0UG9vbAQHJG1hdGNoMAUKcG9vbE9yVW5pdAMJAAECBQckbWF0Y2gwAgRVbml0BAckbWF0Y2gxCQCiCAEJAQtrZXlMaXN0SGVhZAEFDXBvb2xzTGlzdE5hbWUDCQABAgUHJG1hdGNoMQIEVW5pdAQHYWN0aW9ucwMFBWZvcmNlCQDMCAIJAQtEZWxldGVFbnRyeQEFFGtleUZpbmFsaXphdGlvblN0YWdlCQDMCAIJAQtEZWxldGVFbnRyeQEFHWtleUZpbmFsaXphdGlvblNob3VsZEJlRm9yY2VkBQNuaWwJAMwIAgkBC0RlbGV0ZUVudHJ5AQUUa2V5RmluYWxpemF0aW9uU3RhZ2UJAMwIAgkBDEJvb2xlYW5FbnRyeQIJAQxrZXlGaW5hbGl6ZWQBBQ1wcmV2aW91c0Vwb2NoBgkAzAgCCQEMSW50ZWdlckVudHJ5AgURa2V5Q3VycmVudEVwb2NoVWkFBWVwb2NoCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRBrZXlTdGFydEhlaWdodFVpBQtzdGFydEhlaWdodAUDbmlsCQCUCgIFB2FjdGlvbnMGAwkAAQIFByRtYXRjaDECBlN0cmluZwQLbmV4dFBvb2xTdHIFByRtYXRjaDEJAJQKAgkAzAgCCQELU3RyaW5nRW50cnkCBQtrZXlOZXh0UG9vbAULbmV4dFBvb2xTdHIFA25pbAYJAAIBAgtNYXRjaCBlcnJvcgMJAAECBQckbWF0Y2gwAgZTdHJpbmcEB3Bvb2xTdHIFByRtYXRjaDAEDm5leHRQb29sT3JVbml0CQCiCAEJAQtrZXlMaXN0TmV4dAIFDXBvb2xzTGlzdE5hbWUFB3Bvb2xTdHIDCQAAAgUObmV4dFBvb2xPclVuaXQFDm5leHRQb29sT3JVbml0BAFyCgABQAkA/AcEBQR0aGlzAhNwcm9jZXNzUG9vbElOVEVSTkFMCQDMCAIFB3Bvb2xTdHIJAMwIAgUFZm9yY2UFA25pbAUDbmlsAwkAAQIFAUACB0Jvb2xlYW4FAUAJAAIBCQCsAgIJAAMBBQFAAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuAwkAAAIFAXIFAXIDBQFyCQCUCgIFA25pbAYEByRtYXRjaDEFDm5leHRQb29sT3JVbml0AwkAAQIFByRtYXRjaDECBFVuaXQEB2FjdGlvbnMDBQVmb3JjZQkAzAgCCQELRGVsZXRlRW50cnkBBRRrZXlGaW5hbGl6YXRpb25TdGFnZQkAzAgCCQELRGVsZXRlRW50cnkBBR1rZXlGaW5hbGl6YXRpb25TaG91bGRCZUZvcmNlZAkAzAgCCQELRGVsZXRlRW50cnkBBQtrZXlOZXh0UG9vbAUDbmlsCQDMCAIJAQtEZWxldGVFbnRyeQEFFGtleUZpbmFsaXphdGlvblN0YWdlCQDMCAIJAQxCb29sZWFuRW50cnkCCQEMa2V5RmluYWxpemVkAQUNcHJldmlvdXNFcG9jaAYJAMwIAgkBDEludGVnZXJFbnRyeQIFEWtleUN1cnJlbnRFcG9jaFVpBQVlcG9jaAkAzAgCCQEMSW50ZWdlckVudHJ5AgUQa2V5U3RhcnRIZWlnaHRVaQULc3RhcnRIZWlnaHQJAMwIAgkBC0RlbGV0ZUVudHJ5AQULa2V5TmV4dFBvb2wFA25pbAkAlAoCBQdhY3Rpb25zBgMJAAECBQckbWF0Y2gxAgZTdHJpbmcEC25leHRQb29sU3RyBQckbWF0Y2gxCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgULa2V5TmV4dFBvb2wFC25leHRQb29sU3RyBQNuaWwGCQACAQILTWF0Y2ggZXJyb3IJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAgtNYXRjaCBlcnJvcgkBCHRocm93RXJyAQIWZmluYWxpemF0aW9uIGlzIGJyb2tlbgFpAQ9maW5hbGl6ZVdyYXBwZXIBB2NvdW50ZXIEBnJlc3VsdAoAAUAJAPwHBAUEdGhpcwIOZmluYWxpemVIZWxwZXIFA25pbAUDbmlsAwkAAQIFAUACB0Jvb2xlYW4FAUAJAAIBCQCsAgIJAAMBBQFAAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuAwkAAAIFBnJlc3VsdAUGcmVzdWx0AwkBASEBBQZyZXN1bHQDCQAAAgUHY291bnRlcgAACQEIdGhyb3dFcnIBAh5DdXJyZW50IHZvdGluZyBpcyBub3Qgb3ZlciB5ZXQJAJQKAgUDbmlsBQR1bml0BAhtYXhEZXB0aAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQtrZXlNYXhEZXB0aAUPbWF4RGVwdGhEZWZhdWx0AwkAZgIFCG1heERlcHRoBQdjb3VudGVyBANpbnYJAPwHBAUEdGhpcwIPZmluYWxpemVXcmFwcGVyCQDMCAIJAGQCBQdjb3VudGVyAAEFA25pbAUDbmlsAwkAAAIFA2ludgUDaW52CQCUCgIFA25pbAUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAlAoCBQNuaWwFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEIZmluYWxpemUABANpbnYJAPwHBAUEdGhpcwIPZmluYWxpemVXcmFwcGVyCQDMCAIAAAUDbmlsBQNuaWwDCQAAAgUDaW52BQNpbnYJAJQKAgUDbmlsBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBFGNvbnRhaW5zTm9kZVJFQURPTkxZAghsaXN0TmFtZQJpZAkAlAoCBQNuaWwJAQxjb250YWluc05vZGUCBQhsaXN0TmFtZQUCaWQBaQEKaW5zZXJ0Tm9kZQIIbGlzdE5hbWUCaWQEC2NoZWNrQ2FsbGVyCQELbXVzdE1hbmFnZXIBBQFpAwkAAAIFC2NoZWNrQ2FsbGVyBQtjaGVja0NhbGxlcgkAlAoCCQERaW5zZXJ0Tm9kZUFjdGlvbnMCBQhsaXN0TmFtZQUCaWQFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEKZGVsZXRlTm9kZQIIbGlzdE5hbWUCaWQEC2NoZWNrQ2FsbGVyCQELbXVzdE1hbmFnZXIBBQFpAwkAAAIFC2NoZWNrQ2FsbGVyBQtjaGVja0NhbGxlcgkAlAoCCQERZGVsZXRlTm9kZUFjdGlvbnMCBQhsaXN0TmFtZQUCaWQFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAnR4AQZ2ZXJpZnkABA90YXJnZXRQdWJsaWNLZXkEByRtYXRjaDAJARZtYW5hZ2VyUHVibGljS2V5T3JVbml0AAMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAJwawUHJG1hdGNoMAUCcGsDCQABAgUHJG1hdGNoMAIEVW5pdAgFAnR4D3NlbmRlclB1YmxpY0tleQkAAgECC01hdGNoIGVycm9yCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQ90YXJnZXRQdWJsaWNLZXm+9BVq", "height": 2562880, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 5jbiB9LFD9vaEFt11mTxivySUdKkVmw4ifG7Tu62tmQf Next: none Diff:
OldNewDifferences
101101
102102
103103 func getValueOrFail (address,key,type) = {
104- let error = makeString(["mandatory ", toString(address), ".", key, " is not defined"], "")
104+ let error = wrapErr(makeString(["mandatory ", toString(address), ".", key, " is not defined"], ""))
105105 valueOrErrorMessage( match type {
106106 case str: String =>
107107 getString(address, key)
108108 case int: Int =>
109109 getInteger(address, key)
110110 case _ =>
111- throw("invalid entry type")
111+ throwErr("invalid entry type")
112112 }, error)
113113 }
114114
136136 let parts = split(str, separator)
137137 if ((size(parts) == 2))
138138 then $Tuple2(parts[0], parts[1])
139- else throw("invalid pool string")
139+ else throwErr("invalid pool string")
140140 }
141141
142142
157157
158158
159159 func checkWxEmissionPoolLabel (pool) = {
160- let $t051525192 = pool
161- let amountAssetId = $t051525192._1
162- let priceAssetId = $t051525192._2
160+ let $t051685208 = pool
161+ let amountAssetId = $t051685208._1
162+ let priceAssetId = $t051685208._2
163163 let factoryContract = addressFromStringValue(getStrOrFail(this, keyFactoryContract))
164164 let @ = invoke(factoryContract, "checkWxEmissionPoolLabel", [amountAssetId, priceAssetId], nil)
165165 if ($isInstanceOf(@, "Boolean"))
171171 let poolsListName = "pools"
172172
173173 func getVotesListName (pool) = {
174- let $t054935533 = pool
175- let amountAssetId = $t054935533._1
176- let priceAssetId = $t054935533._2
174+ let $t055095549 = pool
175+ let amountAssetId = $t055095549._1
176+ let priceAssetId = $t055095549._2
177177 makeString(["votes", amountAssetId, priceAssetId], separator)
178178 }
179179
227227 let listSize = valueOrElse(getInteger(this, keyListSize(listName)), 0)
228228 let checkNode = if (!(containsNode(listName, id)))
229229 then true
230- else throw("Node exists")
230+ else throwErr("Node exists")
231231 if ((checkNode == checkNode))
232232 then (([IntegerEntry(keyListSize(listName), (listSize + 1))] ++ (if ((headOrUnit != unit))
233233 then [StringEntry(keyListNext(listName, id), value(headOrUnit)), StringEntry(keyListPrev(listName, value(headOrUnit)), id)]
251251 then [DeleteEntry(keyListPrev(listName, id)), DeleteEntry(keyListNext(listName, value(prevOrUnit)))]
252252 else if ((id == valueOrElse(headOrUnit, "")))
253253 then [DeleteEntry(keyListHead(listName))]
254- else throw(((("invalid node: " + listName) + ".") + id))))
254+ else throwErr(((("invalid node: " + listName) + ".") + id))))
255255 }
256+
257+
258+func keyManagerVaultAddress () = "%s__managerVaultAddress"
256259
257260
258261 func keyManagerPublicKey () = "%s__managerPublicKey"
259262
260263
261-func keyPendingManagerPublicKey () = "%s__pendingManagerPublicKey"
264+func getManagerAddressOrFail () = addressFromStringValue(getStringValue(keyManagerVaultAddress()))
262265
263266
264-func managerPublicKeyOrUnit () = match getString(keyManagerPublicKey()) {
265- case s: String =>
266- fromBase58String(s)
267+func managerPublicKeyOrUnit () = {
268+ let managerVaultAddress = getManagerAddressOrFail()
269+ match getString(managerVaultAddress, keyManagerPublicKey()) {
270+ case s: String =>
271+ fromBase58String(s)
272+ case _: Unit =>
273+ unit
274+ case _ =>
275+ throw("Match error")
276+ }
277+ }
278+
279+
280+func isManager (i) = match managerPublicKeyOrUnit() {
281+ case pk: ByteVector =>
282+ (i.callerPublicKey == pk)
267283 case _: Unit =>
268- unit
284+ (i.caller == this)
269285 case _ =>
270286 throw("Match error")
271287 }
272288
273289
274-func pendingManagerPublicKeyOrUnit () = match getString(keyPendingManagerPublicKey()) {
275- case s: String =>
276- fromBase58String(s)
277- case _: Unit =>
278- unit
279- case _ =>
280- throw("Match error")
281-}
290+func mustManager (i) = if (isManager(i))
291+ then true
292+ else throw("permission denied")
282293
283-
284-let permissionDeniedError = throw("Permission denied")
285294
286295 func mustThis (i) = if ((i.caller == this))
287296 then true
288- else permissionDeniedError
289-
290-
291-func mustManager (i) = match managerPublicKeyOrUnit() {
292- case pk: ByteVector =>
293- if ((i.callerPublicKey == pk))
294- then true
295- else permissionDeniedError
296- case _: Unit =>
297- mustThis(i)
298- case _ =>
299- throw("Match error")
300-}
301-
302-
303-@Callable(i)
304-func setManager (pendingManagerPublicKey) = {
305- let checkCaller = mustManager(i)
306- if ((checkCaller == checkCaller))
307- then {
308- let checkManagerPublicKey = fromBase58String(pendingManagerPublicKey)
309- if ((checkManagerPublicKey == checkManagerPublicKey))
310- then [StringEntry(keyPendingManagerPublicKey(), pendingManagerPublicKey)]
311- else throw("Strict value is not equal to itself.")
312- }
313- else throw("Strict value is not equal to itself.")
314- }
315-
316-
317-
318-@Callable(i)
319-func confirmManager () = {
320- let pm = pendingManagerPublicKeyOrUnit()
321- let hasPM = if (isDefined(pm))
322- then true
323- else throw("No pending manager")
324- if ((hasPM == hasPM))
325- then {
326- let checkPM = if ((i.callerPublicKey == value(pm)))
327- then true
328- else throw("You are not pending manager")
329- if ((checkPM == checkPM))
330- then [StringEntry(keyManagerPublicKey(), toBase58String(value(pm))), DeleteEntry(keyPendingManagerPublicKey())]
331- else throw("Strict value is not equal to itself.")
332- }
333- else throw("Strict value is not equal to itself.")
334- }
335-
297+ else throw("permission denied")
336298
337299
338300 @Callable(i)
339301 func getUserGwxAmountAtHeight (userAddress,targetHeight) = {
340- let boostingContractAddress = valueOrErrorMessage(addressFromString(getStrOrFail(this, keyBoostingContract)), "invalid boosting contract address")
302+ let boostingContractAddress = valueOrErrorMessage(addressFromString(getStrOrFail(this, keyBoostingContract)), wrapErr("invalid boosting contract address"))
341303 $Tuple2(nil, {
342304 let @ = invoke(boostingContractAddress, "getUserGwxAmountAtHeightREADONLY", [userAddress, targetHeight], nil)
343305 if ($isInstanceOf(@, "Int"))
360322 then true
361323 else "invalid staking contract address", if ((epochLength > 0))
362324 then true
363- else throw("invalid epoch length")]
325+ else throwErr("invalid epoch length")]
364326 if ((checks == checks))
365327 then $Tuple2([StringEntry(keyFactoryContract, factoryContract), StringEntry(keyVotingEmissionCandidateContract, votingEmissionCandidateContract), StringEntry(keyBoostingContract, boostingContract), StringEntry(keyStakingContract, stakingContract), IntegerEntry(keyEpochLength, epochLength)], unit)
366328 else throw("Strict value is not equal to itself.")
414376 let wxEmission = checkWxEmissionPoolLabel(pool)
415377 let checks = [if ((getBoolean(keyInList(pool)) != unit))
416378 then true
417- else throw("invalid assets"), if ((endHeight > height))
379+ else throwErr("invalid assets"), if ((endHeight > height))
418380 then true
419- else throw("invalid height"), if ((finalizationStageOrUnit == unit))
381+ else throwErr("invalid height"), if ((finalizationStageOrUnit == unit))
420382 then true
421- else throw("finalization in progress"), if ((gwxAmountAtEndTotal > 0))
383+ else throwErr("finalization in progress"), if ((gwxAmountAtEndTotal > 0))
422384 then true
423- else throw("you do not have gWX"), if (if ((amount > 0))
385+ else throwErr("you do not have gWX"), if (if ((amount > 0))
424386 then (available >= amount)
425387 else false)
426388 then true
427- else throw("invalid amount"), if (wxEmission)
389+ else throwErr("invalid amount"), if (wxEmission)
428390 then true
429- else throw("pool hasn't WX_EMISSION label")]
391+ else throwErr("pool hasn't WX_EMISSION label")]
430392 if ((checks == checks))
431393 then {
432394 let votesListName = getVotesListName(pool)
455417 let totalVotes = valueOrElse(getInteger(this, keyTotalVotes(epoch)), 0)
456418 let checks = [if ((getBoolean(keyInList(pool)) != unit))
457419 then true
458- else throw("invalid assets"), if ((endHeight > height))
420+ else throwErr("invalid assets"), if ((endHeight > height))
459421 then true
460- else throw("invalid height"), if ((finalizationStageOrUnit == unit))
422+ else throwErr("invalid height"), if ((finalizationStageOrUnit == unit))
461423 then true
462- else throw("finalization in progress"), if ((vote > 0))
424+ else throwErr("finalization in progress"), if ((vote > 0))
463425 then true
464- else throw("no vote")]
426+ else throwErr("no vote")]
465427 if ((checks == checks))
466428 then {
467429 let votesListName = getVotesListName(pool)
477439 func setEpochLength (newEpochLength) = {
478440 let checks = [mustManager(i), if ((newEpochLength > 0))
479441 then true
480- else throw("invalid epoch length")]
442+ else throwErr("invalid epoch length")]
481443 if ((checks == checks))
482444 then $Tuple2([IntegerEntry(keyEpochLengthNew, newEpochLength)], unit)
483445 else throw("Strict value is not equal to itself.")
489451 func setMaxDepth (newMaxDepth) = {
490452 let checks = [mustManager(i), if ((newMaxDepth > 0))
491453 then true
492- else throw("invalid max depth")]
454+ else throwErr("invalid max depth")]
493455 if ((checks == checks))
494456 then $Tuple2([IntegerEntry(keyMaxDepth, newMaxDepth)], unit)
495457 else throw("Strict value is not equal to itself.")
502464 let checkCaller = mustThis(i)
503465 if ((checkCaller == checkCaller))
504466 then {
505- let userAddress = valueOrErrorMessage(addressFromString(userAddressStr), ("processVoteINTERNAL: invalid user address " + userAddressStr))
467+ let userAddress = valueOrErrorMessage(addressFromString(userAddressStr), wrapErr(("processVoteINTERNAL: invalid user address " + userAddressStr)))
506468 let epoch = getIntOrFail(this, keyCurrentEpoch)
507469 let epochPrevious = (epoch - 1)
508470 let epochLength = getIntOrFail(this, keyEpochLength)
513475 let endHeightPrevious = (startHeightPrevious + epochLengthPrevious)
514476 let checkTargetEpoch = if ((epochPrevious >= 0))
515477 then true
516- else throw("processVoteINTERNAL: invalid previous epoch")
478+ else throwErr("processVoteINTERNAL: invalid previous epoch")
517479 if ((checkTargetEpoch == checkTargetEpoch))
518480 then {
519481 let pool = stringToPool(poolStr)
520- let $t01798418024 = pool
521- let amountAssetId = $t01798418024._1
522- let priceAssetId = $t01798418024._2
482+ let $t01748817528 = pool
483+ let amountAssetId = $t01748817528._1
484+ let priceAssetId = $t01748817528._2
523485 let wxEmission = checkWxEmissionPoolLabel(pool)
524486 let gwxAmountAtEndTotal = {
525487 let @ = invoke(this, "getUserGwxAmountAtHeight", [userAddressStr, endHeight], nil)
535497 }
536498 let totalVotes = valueOrElse(getInteger(keyTotalVotes(epoch)), 0)
537499 let votingResult = valueOrElse(getInteger(keyVotingResult(pool, epoch)), 0)
538- let votePrevious = valueOrErrorMessage(getInteger(keyVote(pool, userAddress, epochPrevious)), (((("processVoteINTERNAL " + poolStr) + " ") + userAddressStr) + ": no previous vote"))
500+ let votePrevious = valueOrErrorMessage(getInteger(keyVote(pool, userAddress, epochPrevious)), wrapErr((((("processVoteINTERNAL " + poolStr) + " ") + userAddressStr) + ": no previous vote")))
539501 let used = valueOrElse(getInteger(this, keyUsed(userAddress, epoch)), 0)
540502 let lpAssetIdStr = getLpAssetByPoolAssets(amountAssetId, priceAssetId)
541503 let votingResultStakedPrevious = valueOrElse(getInteger(keyVotingResultStaked(lpAssetIdStr, epochPrevious)), 0)
574536 }
575537 let checkTargetEpoch = if ((targetEpoch >= 0))
576538 then true
577- else throw("processPoolINTERNAL: invalid target epoch")
539+ else throwErr("processPoolINTERNAL: invalid target epoch")
578540 if ((checkTargetEpoch == checkTargetEpoch))
579541 then {
580542 let pool = stringToPool(poolStr)
581- let $t02036620406 = pool
582- let amountAssetId = $t02036620406._1
583- let priceAssetId = $t02036620406._2
543+ let $t01988519925 = pool
544+ let amountAssetId = $t01988519925._1
545+ let priceAssetId = $t01988519925._2
584546 let stakingContract = addressFromStringValue(getStrOrFail(this, keyStakingContract))
585547 let factoryContract = addressFromStringValue(getStrOrFail(this, keyFactoryContract))
586548 let lpAssetId = getLpAssetByPoolAssets(amountAssetId, priceAssetId)
755717 throw("Match error")
756718 }
757719 }
758- else throw("finalization is broken")
720+ else throwErr("finalization is broken")
759721 }
760722
761723
771733 if ((result == result))
772734 then if (!(result))
773735 then if ((counter == 0))
774- then throw("Current voting is not over yet")
736+ then throwErr("Current voting is not over yet")
775737 else $Tuple2(nil, unit)
776738 else {
777739 let maxDepth = valueOrElse(getInteger(this, keyMaxDepth), maxDepthDefault)
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let separator = "__"
55
66 let poolWeightMult = 100000000
77
88 let maxDepthDefault = 10
99
1010 let finalizationStageTotal = 0
1111
1212 let finalizationStageShares = 1
1313
1414 let keyEpochLength = makeString(["%s", "epochLength"], separator)
1515
1616 let keyEpochLengthNew = makeString(["%s%s", "epochLength__new"], separator)
1717
1818 func keyEpochLengthByEpoch (epoch) = makeString(["%s%d", "epochLength", toString(epoch)], separator)
1919
2020
2121 let keyCurrentEpoch = makeString(["%s", "currentEpoch"], separator)
2222
2323 let keyMaxDepth = makeString(["%s", "maxDepth"], separator)
2424
2525 let keyVotingEmissionCandidateContract = makeString(["%s", "votingEmissionCandidateContract"], separator)
2626
2727 let keyFactoryContract = makeString(["%s", "factoryContract"], separator)
2828
2929 let keyBoostingContract = makeString(["%s", "boostingContract"], separator)
3030
3131 let keyStakingContract = makeString(["%s", "stakingContract"], separator)
3232
3333 let keyFinalizationStage = makeString(["%s", "finalizationStage"], separator)
3434
3535 let keyNextPool = makeString(["%s", "nextPool"], separator)
3636
3737 let keyNextUser = makeString(["%s", "nextUser"], separator)
3838
3939 let keyStartHeight = makeString(["%s", "startHeight"], separator)
4040
4141 let keyCurrentEpochUi = makeString(["%s", "currentEpochUi"], separator)
4242
4343 let keyStartHeightUi = makeString(["%s", "startHeightUi"], separator)
4444
4545 let keyFinalizationShouldBeForced = makeString(["%s", "force"], separator)
4646
4747 func keyStartHeightByEpoch (epoch) = makeString(["%s%d", "startHeight", toString(epoch)], separator)
4848
4949
5050 func keyFinalized (epoch) = makeString(["%s%d", "finalized", toString(epoch)], separator)
5151
5252
5353 func keyInList (pool) = {
5454 let $t016931733 = pool
5555 let amountAssetId = $t016931733._1
5656 let priceAssetId = $t016931733._2
5757 makeString(["%s%s%s", "inList", amountAssetId, priceAssetId], separator)
5858 }
5959
6060
6161 func keyUsed (address,epoch) = makeString(["%s%s%d", "used", toString(address), toString(epoch)], separator)
6262
6363
6464 func keyVote (pool,address,epoch) = {
6565 let $t020072047 = pool
6666 let amountAssetId = $t020072047._1
6767 let priceAssetId = $t020072047._2
6868 makeString(["%s%s%s%s%d", "vote", amountAssetId, priceAssetId, toString(address), toString(epoch)], separator)
6969 }
7070
7171
7272 func keyVotingResult (pool,epoch) = {
7373 let $t022292269 = pool
7474 let amountAssetId = $t022292269._1
7575 let priceAssetId = $t022292269._2
7676 makeString(["%s%s%s%d", "votingResult", amountAssetId, priceAssetId, toString(epoch)], separator)
7777 }
7878
7979
8080 func keyVotingResultStaked (lpAssetIdStr,epoch) = makeString(["%s%s%d", "votingResultStaked", lpAssetIdStr, toString(epoch)], separator)
8181
8282
8383 func keyPoolShare (pool,epoch) = {
8484 let $t025902630 = pool
8585 let amountAssetId = $t025902630._1
8686 let priceAssetId = $t025902630._2
8787 makeString(["%s%s%s%d", "poolShare", amountAssetId, priceAssetId, toString(epoch)], separator)
8888 }
8989
9090
9191 func keyTotalVotes (epoch) = makeString(["%s%d", "totalVotes", toString(epoch)], separator)
9292
9393
9494 func keyStakedByUser (lpAssetIdStr,userAddressStr) = makeString(["%s%s%s", "staked", userAddressStr, lpAssetIdStr], separator)
9595
9696
9797 func wrapErr (msg) = makeString(["voting_emission.ride:", msg], " ")
9898
9999
100100 func throwErr (msg) = throw(wrapErr(msg))
101101
102102
103103 func getValueOrFail (address,key,type) = {
104- let error = makeString(["mandatory ", toString(address), ".", key, " is not defined"], "")
104+ let error = wrapErr(makeString(["mandatory ", toString(address), ".", key, " is not defined"], ""))
105105 valueOrErrorMessage( match type {
106106 case str: String =>
107107 getString(address, key)
108108 case int: Int =>
109109 getInteger(address, key)
110110 case _ =>
111- throw("invalid entry type")
111+ throwErr("invalid entry type")
112112 }, error)
113113 }
114114
115115
116116 func getStrOrFail (address,key) = {
117117 let @ = getValueOrFail(address, key, "")
118118 if ($isInstanceOf(@, "String"))
119119 then @
120120 else throw(($getType(@) + " couldn't be cast to String"))
121121 }
122122
123123
124124 func getIntOrFail (address,key) = {
125125 let @ = getValueOrFail(address, key, 0)
126126 if ($isInstanceOf(@, "Int"))
127127 then @
128128 else throw(($getType(@) + " couldn't be cast to Int"))
129129 }
130130
131131
132132 func poolToString (pool) = ((pool._1 + separator) + pool._2)
133133
134134
135135 func stringToPool (str) = {
136136 let parts = split(str, separator)
137137 if ((size(parts) == 2))
138138 then $Tuple2(parts[0], parts[1])
139- else throw("invalid pool string")
139+ else throwErr("invalid pool string")
140140 }
141141
142142
143143 func getLpAssetByPoolAssets (amountAssetId,priceAssetId) = {
144144 func keyMappingsBaseAsset2internalId (baseAssetStr) = ("%s%s%s__mappings__baseAsset2internalId__" + baseAssetStr)
145145
146146 func keyMappingPoolAssetsToPoolContractAddress (internalAmountAssetIdStr,internalPriceAssetIdStr) = (((("%d%d%s%s__" + toString(internalAmountAssetIdStr)) + "__") + toString(internalPriceAssetIdStr)) + "__mappings__poolAssets2PoolContract")
147147
148148 func keyMappingPoolContractToLPAsset (poolContractAddress) = (("%s%s%s__" + poolContractAddress) + "__mappings__poolContract2LpAsset")
149149
150150 let factoryContract = addressFromStringValue(getStrOrFail(this, keyFactoryContract))
151151 let amountAssetInternalId = getIntOrFail(factoryContract, keyMappingsBaseAsset2internalId(amountAssetId))
152152 let priceAssetInternalId = getIntOrFail(factoryContract, keyMappingsBaseAsset2internalId(priceAssetId))
153153 let poolContractAddress = getStrOrFail(factoryContract, keyMappingPoolAssetsToPoolContractAddress(amountAssetInternalId, priceAssetInternalId))
154154 let lpAssetId = getStrOrFail(factoryContract, keyMappingPoolContractToLPAsset(poolContractAddress))
155155 lpAssetId
156156 }
157157
158158
159159 func checkWxEmissionPoolLabel (pool) = {
160- let $t051525192 = pool
161- let amountAssetId = $t051525192._1
162- let priceAssetId = $t051525192._2
160+ let $t051685208 = pool
161+ let amountAssetId = $t051685208._1
162+ let priceAssetId = $t051685208._2
163163 let factoryContract = addressFromStringValue(getStrOrFail(this, keyFactoryContract))
164164 let @ = invoke(factoryContract, "checkWxEmissionPoolLabel", [amountAssetId, priceAssetId], nil)
165165 if ($isInstanceOf(@, "Boolean"))
166166 then @
167167 else throw(($getType(@) + " couldn't be cast to Boolean"))
168168 }
169169
170170
171171 let poolsListName = "pools"
172172
173173 func getVotesListName (pool) = {
174- let $t054935533 = pool
175- let amountAssetId = $t054935533._1
176- let priceAssetId = $t054935533._2
174+ let $t055095549 = pool
175+ let amountAssetId = $t055095549._1
176+ let priceAssetId = $t055095549._2
177177 makeString(["votes", amountAssetId, priceAssetId], separator)
178178 }
179179
180180
181181 func keyListHead (listName) = {
182182 let meta = if ((listName == poolsListName))
183183 then "%s%s"
184184 else "%s%s%s%s"
185185 makeString([meta, listName, "head"], separator)
186186 }
187187
188188
189189 func keyListSize (listName) = {
190190 let meta = if ((listName == poolsListName))
191191 then "%s%s"
192192 else "%s%s%s%s"
193193 makeString([meta, listName, "size"], separator)
194194 }
195195
196196
197197 func keyListPrev (listName,id) = {
198198 let meta = if ((listName == poolsListName))
199199 then "%s%s%s%s"
200200 else "%s%s%s%s%s"
201201 makeString([meta, listName, id, "prev"], separator)
202202 }
203203
204204
205205 func keyListNext (listName,id) = {
206206 let meta = if ((listName == poolsListName))
207207 then "%s%s%s%s"
208208 else "%s%s%s%s%s"
209209 makeString([meta, listName, id, "next"], separator)
210210 }
211211
212212
213213 func containsNode (listName,id) = {
214214 let headOrUnit = getString(this, keyListHead(listName))
215215 let prevOrUnit = getString(this, keyListPrev(listName, id))
216216 let nextOrUnit = getString(this, keyListNext(listName, id))
217217 if (if ((id == valueOrElse(headOrUnit, "")))
218218 then true
219219 else (prevOrUnit != unit))
220220 then true
221221 else (nextOrUnit != unit)
222222 }
223223
224224
225225 func insertNodeActions (listName,id) = {
226226 let headOrUnit = getString(this, keyListHead(listName))
227227 let listSize = valueOrElse(getInteger(this, keyListSize(listName)), 0)
228228 let checkNode = if (!(containsNode(listName, id)))
229229 then true
230- else throw("Node exists")
230+ else throwErr("Node exists")
231231 if ((checkNode == checkNode))
232232 then (([IntegerEntry(keyListSize(listName), (listSize + 1))] ++ (if ((headOrUnit != unit))
233233 then [StringEntry(keyListNext(listName, id), value(headOrUnit)), StringEntry(keyListPrev(listName, value(headOrUnit)), id)]
234234 else nil)) ++ [StringEntry(keyListHead(listName), id)])
235235 else throw("Strict value is not equal to itself.")
236236 }
237237
238238
239239 func deleteNodeActions (listName,id) = {
240240 let headOrUnit = getString(this, keyListHead(listName))
241241 let listSize = valueOrElse(getInteger(this, keyListSize(listName)), 0)
242242 let prevOrUnit = getString(this, keyListPrev(listName, id))
243243 let nextOrUnit = getString(this, keyListNext(listName, id))
244244 ([IntegerEntry(keyListSize(listName), (listSize - 1))] ++ (if (if ((prevOrUnit != unit))
245245 then (nextOrUnit != unit)
246246 else false)
247247 then [StringEntry(keyListNext(listName, value(prevOrUnit)), value(nextOrUnit)), StringEntry(keyListPrev(listName, value(nextOrUnit)), value(prevOrUnit)), DeleteEntry(keyListPrev(listName, id)), DeleteEntry(keyListNext(listName, id))]
248248 else if ((nextOrUnit != unit))
249249 then [StringEntry(keyListHead(listName), value(nextOrUnit)), DeleteEntry(keyListNext(listName, id)), DeleteEntry(keyListPrev(listName, value(nextOrUnit)))]
250250 else if ((prevOrUnit != unit))
251251 then [DeleteEntry(keyListPrev(listName, id)), DeleteEntry(keyListNext(listName, value(prevOrUnit)))]
252252 else if ((id == valueOrElse(headOrUnit, "")))
253253 then [DeleteEntry(keyListHead(listName))]
254- else throw(((("invalid node: " + listName) + ".") + id))))
254+ else throwErr(((("invalid node: " + listName) + ".") + id))))
255255 }
256+
257+
258+func keyManagerVaultAddress () = "%s__managerVaultAddress"
256259
257260
258261 func keyManagerPublicKey () = "%s__managerPublicKey"
259262
260263
261-func keyPendingManagerPublicKey () = "%s__pendingManagerPublicKey"
264+func getManagerAddressOrFail () = addressFromStringValue(getStringValue(keyManagerVaultAddress()))
262265
263266
264-func managerPublicKeyOrUnit () = match getString(keyManagerPublicKey()) {
265- case s: String =>
266- fromBase58String(s)
267+func managerPublicKeyOrUnit () = {
268+ let managerVaultAddress = getManagerAddressOrFail()
269+ match getString(managerVaultAddress, keyManagerPublicKey()) {
270+ case s: String =>
271+ fromBase58String(s)
272+ case _: Unit =>
273+ unit
274+ case _ =>
275+ throw("Match error")
276+ }
277+ }
278+
279+
280+func isManager (i) = match managerPublicKeyOrUnit() {
281+ case pk: ByteVector =>
282+ (i.callerPublicKey == pk)
267283 case _: Unit =>
268- unit
284+ (i.caller == this)
269285 case _ =>
270286 throw("Match error")
271287 }
272288
273289
274-func pendingManagerPublicKeyOrUnit () = match getString(keyPendingManagerPublicKey()) {
275- case s: String =>
276- fromBase58String(s)
277- case _: Unit =>
278- unit
279- case _ =>
280- throw("Match error")
281-}
290+func mustManager (i) = if (isManager(i))
291+ then true
292+ else throw("permission denied")
282293
283-
284-let permissionDeniedError = throw("Permission denied")
285294
286295 func mustThis (i) = if ((i.caller == this))
287296 then true
288- else permissionDeniedError
289-
290-
291-func mustManager (i) = match managerPublicKeyOrUnit() {
292- case pk: ByteVector =>
293- if ((i.callerPublicKey == pk))
294- then true
295- else permissionDeniedError
296- case _: Unit =>
297- mustThis(i)
298- case _ =>
299- throw("Match error")
300-}
301-
302-
303-@Callable(i)
304-func setManager (pendingManagerPublicKey) = {
305- let checkCaller = mustManager(i)
306- if ((checkCaller == checkCaller))
307- then {
308- let checkManagerPublicKey = fromBase58String(pendingManagerPublicKey)
309- if ((checkManagerPublicKey == checkManagerPublicKey))
310- then [StringEntry(keyPendingManagerPublicKey(), pendingManagerPublicKey)]
311- else throw("Strict value is not equal to itself.")
312- }
313- else throw("Strict value is not equal to itself.")
314- }
315-
316-
317-
318-@Callable(i)
319-func confirmManager () = {
320- let pm = pendingManagerPublicKeyOrUnit()
321- let hasPM = if (isDefined(pm))
322- then true
323- else throw("No pending manager")
324- if ((hasPM == hasPM))
325- then {
326- let checkPM = if ((i.callerPublicKey == value(pm)))
327- then true
328- else throw("You are not pending manager")
329- if ((checkPM == checkPM))
330- then [StringEntry(keyManagerPublicKey(), toBase58String(value(pm))), DeleteEntry(keyPendingManagerPublicKey())]
331- else throw("Strict value is not equal to itself.")
332- }
333- else throw("Strict value is not equal to itself.")
334- }
335-
297+ else throw("permission denied")
336298
337299
338300 @Callable(i)
339301 func getUserGwxAmountAtHeight (userAddress,targetHeight) = {
340- let boostingContractAddress = valueOrErrorMessage(addressFromString(getStrOrFail(this, keyBoostingContract)), "invalid boosting contract address")
302+ let boostingContractAddress = valueOrErrorMessage(addressFromString(getStrOrFail(this, keyBoostingContract)), wrapErr("invalid boosting contract address"))
341303 $Tuple2(nil, {
342304 let @ = invoke(boostingContractAddress, "getUserGwxAmountAtHeightREADONLY", [userAddress, targetHeight], nil)
343305 if ($isInstanceOf(@, "Int"))
344306 then @
345307 else throw(($getType(@) + " couldn't be cast to Int"))
346308 })
347309 }
348310
349311
350312
351313 @Callable(i)
352314 func constructor (factoryContract,votingEmissionCandidateContract,boostingContract,stakingContract,epochLength) = {
353315 let checks = [mustManager(i), if ((addressFromString(factoryContract) != unit))
354316 then true
355317 else "invalid factory contract address", if ((addressFromString(votingEmissionCandidateContract) != unit))
356318 then true
357319 else "invalid voting emission candidate contract address", if ((addressFromString(boostingContract) != unit))
358320 then true
359321 else "invalid boosting contract address", if ((addressFromString(stakingContract) != unit))
360322 then true
361323 else "invalid staking contract address", if ((epochLength > 0))
362324 then true
363- else throw("invalid epoch length")]
325+ else throwErr("invalid epoch length")]
364326 if ((checks == checks))
365327 then $Tuple2([StringEntry(keyFactoryContract, factoryContract), StringEntry(keyVotingEmissionCandidateContract, votingEmissionCandidateContract), StringEntry(keyBoostingContract, boostingContract), StringEntry(keyStakingContract, stakingContract), IntegerEntry(keyEpochLength, epochLength)], unit)
366328 else throw("Strict value is not equal to itself.")
367329 }
368330
369331
370332
371333 @Callable(i)
372334 func create (amountAssetId,priceAssetId) = {
373335 let checks = [if ((toBase58String(i.caller.bytes) == valueOrElse(getString(this, keyVotingEmissionCandidateContract), "")))
374336 then true
375337 else mustManager(i)]
376338 if ((checks == checks))
377339 then {
378340 let pool = $Tuple2(amountAssetId, priceAssetId)
379341 let inListActions = ([BooleanEntry(keyInList(pool), true)] ++ insertNodeActions(poolsListName, poolToString(pool)))
380342 let currentEpochIsNotDefined = (getInteger(this, keyCurrentEpoch) == unit)
381343 let startHeightActions = if (currentEpochIsNotDefined)
382344 then {
383345 let epoch = 0
384346 [IntegerEntry(keyCurrentEpoch, epoch), IntegerEntry(keyStartHeightByEpoch(epoch), height), IntegerEntry(keyStartHeight, height), IntegerEntry(keyCurrentEpochUi, epoch), IntegerEntry(keyStartHeightUi, height)]
385347 }
386348 else nil
387349 $Tuple2((inListActions ++ startHeightActions), unit)
388350 }
389351 else throw("Strict value is not equal to itself.")
390352 }
391353
392354
393355
394356 @Callable(i)
395357 func vote (amountAssetId,priceAssetId,amount) = {
396358 let pool = $Tuple2(amountAssetId, priceAssetId)
397359 let epoch = valueOrElse(getInteger(this, keyCurrentEpoch), 0)
398360 let startHeight = getIntOrFail(this, keyStartHeightByEpoch(epoch))
399361 let epochLength = getIntOrFail(this, keyEpochLength)
400362 let endHeight = (startHeight + epochLength)
401363 let finalizationStageOrUnit = getInteger(this, keyFinalizationStage)
402364 let used = valueOrElse(getInteger(this, keyUsed(i.caller, epoch)), 0)
403365 let vote = valueOrElse(getInteger(this, keyVote(pool, i.caller, epoch)), 0)
404366 let poolResult = valueOrElse(getInteger(this, keyVotingResult(pool, epoch)), 0)
405367 let totalVotes = valueOrElse(getInteger(this, keyTotalVotes(epoch)), 0)
406368 let gwxAmountAtEndTotal = {
407369 let @ = invoke(this, "getUserGwxAmountAtHeight", [toBase58String(i.caller.bytes), endHeight], nil)
408370 if ($isInstanceOf(@, "Int"))
409371 then @
410372 else throw(($getType(@) + " couldn't be cast to Int"))
411373 }
412374 let available = (gwxAmountAtEndTotal - used)
413375 let newVote = (vote + amount)
414376 let wxEmission = checkWxEmissionPoolLabel(pool)
415377 let checks = [if ((getBoolean(keyInList(pool)) != unit))
416378 then true
417- else throw("invalid assets"), if ((endHeight > height))
379+ else throwErr("invalid assets"), if ((endHeight > height))
418380 then true
419- else throw("invalid height"), if ((finalizationStageOrUnit == unit))
381+ else throwErr("invalid height"), if ((finalizationStageOrUnit == unit))
420382 then true
421- else throw("finalization in progress"), if ((gwxAmountAtEndTotal > 0))
383+ else throwErr("finalization in progress"), if ((gwxAmountAtEndTotal > 0))
422384 then true
423- else throw("you do not have gWX"), if (if ((amount > 0))
385+ else throwErr("you do not have gWX"), if (if ((amount > 0))
424386 then (available >= amount)
425387 else false)
426388 then true
427- else throw("invalid amount"), if (wxEmission)
389+ else throwErr("invalid amount"), if (wxEmission)
428390 then true
429- else throw("pool hasn't WX_EMISSION label")]
391+ else throwErr("pool hasn't WX_EMISSION label")]
430392 if ((checks == checks))
431393 then {
432394 let votesListName = getVotesListName(pool)
433395 let userAddressStr = toString(i.caller)
434396 let votesListActions = if (containsNode(votesListName, userAddressStr))
435397 then nil
436398 else insertNodeActions(votesListName, userAddressStr)
437399 $Tuple2(([IntegerEntry(keyUsed(i.caller, epoch), (used + amount)), IntegerEntry(keyVote(pool, i.caller, epoch), newVote), IntegerEntry(keyVotingResult(pool, epoch), (poolResult + amount)), IntegerEntry(keyTotalVotes(epoch), (totalVotes + amount))] ++ votesListActions), unit)
438400 }
439401 else throw("Strict value is not equal to itself.")
440402 }
441403
442404
443405
444406 @Callable(i)
445407 func cancelVote (amountAssetId,priceAssetId) = {
446408 let pool = $Tuple2(amountAssetId, priceAssetId)
447409 let epoch = valueOrElse(getInteger(this, keyCurrentEpoch), 0)
448410 let startHeight = getIntOrFail(this, keyStartHeightByEpoch(epoch))
449411 let epochLength = getIntOrFail(this, keyEpochLength)
450412 let endHeight = (startHeight + epochLength)
451413 let finalizationStageOrUnit = getInteger(this, keyFinalizationStage)
452414 let used = valueOrElse(getInteger(this, keyUsed(i.caller, epoch)), 0)
453415 let vote = valueOrElse(getInteger(this, keyVote(pool, i.caller, epoch)), 0)
454416 let poolResult = valueOrElse(getInteger(this, keyVotingResult(pool, epoch)), 0)
455417 let totalVotes = valueOrElse(getInteger(this, keyTotalVotes(epoch)), 0)
456418 let checks = [if ((getBoolean(keyInList(pool)) != unit))
457419 then true
458- else throw("invalid assets"), if ((endHeight > height))
420+ else throwErr("invalid assets"), if ((endHeight > height))
459421 then true
460- else throw("invalid height"), if ((finalizationStageOrUnit == unit))
422+ else throwErr("invalid height"), if ((finalizationStageOrUnit == unit))
461423 then true
462- else throw("finalization in progress"), if ((vote > 0))
424+ else throwErr("finalization in progress"), if ((vote > 0))
463425 then true
464- else throw("no vote")]
426+ else throwErr("no vote")]
465427 if ((checks == checks))
466428 then {
467429 let votesListName = getVotesListName(pool)
468430 let userAddressStr = toString(i.caller)
469431 $Tuple2(([IntegerEntry(keyUsed(i.caller, epoch), max([(used - vote), 0])), DeleteEntry(keyVote(pool, i.caller, epoch)), IntegerEntry(keyVotingResult(pool, epoch), (poolResult - vote)), IntegerEntry(keyTotalVotes(epoch), (totalVotes - vote))] ++ deleteNodeActions(votesListName, userAddressStr)), unit)
470432 }
471433 else throw("Strict value is not equal to itself.")
472434 }
473435
474436
475437
476438 @Callable(i)
477439 func setEpochLength (newEpochLength) = {
478440 let checks = [mustManager(i), if ((newEpochLength > 0))
479441 then true
480- else throw("invalid epoch length")]
442+ else throwErr("invalid epoch length")]
481443 if ((checks == checks))
482444 then $Tuple2([IntegerEntry(keyEpochLengthNew, newEpochLength)], unit)
483445 else throw("Strict value is not equal to itself.")
484446 }
485447
486448
487449
488450 @Callable(i)
489451 func setMaxDepth (newMaxDepth) = {
490452 let checks = [mustManager(i), if ((newMaxDepth > 0))
491453 then true
492- else throw("invalid max depth")]
454+ else throwErr("invalid max depth")]
493455 if ((checks == checks))
494456 then $Tuple2([IntegerEntry(keyMaxDepth, newMaxDepth)], unit)
495457 else throw("Strict value is not equal to itself.")
496458 }
497459
498460
499461
500462 @Callable(i)
501463 func processVoteINTERNAL (poolStr,userAddressStr) = {
502464 let checkCaller = mustThis(i)
503465 if ((checkCaller == checkCaller))
504466 then {
505- let userAddress = valueOrErrorMessage(addressFromString(userAddressStr), ("processVoteINTERNAL: invalid user address " + userAddressStr))
467+ let userAddress = valueOrErrorMessage(addressFromString(userAddressStr), wrapErr(("processVoteINTERNAL: invalid user address " + userAddressStr)))
506468 let epoch = getIntOrFail(this, keyCurrentEpoch)
507469 let epochPrevious = (epoch - 1)
508470 let epochLength = getIntOrFail(this, keyEpochLength)
509471 let startHeight = getIntOrFail(this, keyStartHeightByEpoch(epoch))
510472 let endHeight = (startHeight + epochLength)
511473 let startHeightPrevious = getIntOrFail(this, keyStartHeightByEpoch(epochPrevious))
512474 let epochLengthPrevious = getIntOrFail(this, keyEpochLengthByEpoch(epochPrevious))
513475 let endHeightPrevious = (startHeightPrevious + epochLengthPrevious)
514476 let checkTargetEpoch = if ((epochPrevious >= 0))
515477 then true
516- else throw("processVoteINTERNAL: invalid previous epoch")
478+ else throwErr("processVoteINTERNAL: invalid previous epoch")
517479 if ((checkTargetEpoch == checkTargetEpoch))
518480 then {
519481 let pool = stringToPool(poolStr)
520- let $t01798418024 = pool
521- let amountAssetId = $t01798418024._1
522- let priceAssetId = $t01798418024._2
482+ let $t01748817528 = pool
483+ let amountAssetId = $t01748817528._1
484+ let priceAssetId = $t01748817528._2
523485 let wxEmission = checkWxEmissionPoolLabel(pool)
524486 let gwxAmountAtEndTotal = {
525487 let @ = invoke(this, "getUserGwxAmountAtHeight", [userAddressStr, endHeight], nil)
526488 if ($isInstanceOf(@, "Int"))
527489 then @
528490 else throw(($getType(@) + " couldn't be cast to Int"))
529491 }
530492 let gwxAmountAtEndTotalPrevious = {
531493 let @ = invoke(this, "getUserGwxAmountAtHeight", [userAddressStr, endHeightPrevious], nil)
532494 if ($isInstanceOf(@, "Int"))
533495 then @
534496 else throw(($getType(@) + " couldn't be cast to Int"))
535497 }
536498 let totalVotes = valueOrElse(getInteger(keyTotalVotes(epoch)), 0)
537499 let votingResult = valueOrElse(getInteger(keyVotingResult(pool, epoch)), 0)
538- let votePrevious = valueOrErrorMessage(getInteger(keyVote(pool, userAddress, epochPrevious)), (((("processVoteINTERNAL " + poolStr) + " ") + userAddressStr) + ": no previous vote"))
500+ let votePrevious = valueOrErrorMessage(getInteger(keyVote(pool, userAddress, epochPrevious)), wrapErr((((("processVoteINTERNAL " + poolStr) + " ") + userAddressStr) + ": no previous vote")))
539501 let used = valueOrElse(getInteger(this, keyUsed(userAddress, epoch)), 0)
540502 let lpAssetIdStr = getLpAssetByPoolAssets(amountAssetId, priceAssetId)
541503 let votingResultStakedPrevious = valueOrElse(getInteger(keyVotingResultStaked(lpAssetIdStr, epochPrevious)), 0)
542504 let stakingContract = addressFromStringValue(getStrOrFail(this, keyStakingContract))
543505 let stakedByUser = valueOrElse(getInteger(stakingContract, keyStakedByUser(lpAssetIdStr, userAddressStr)), 0)
544506 let votingResultStakedActions = if ((stakedByUser == 0))
545507 then nil
546508 else [IntegerEntry(keyVotingResultStaked(lpAssetIdStr, epochPrevious), (votingResultStakedPrevious + votePrevious))]
547509 let newVote = if ((gwxAmountAtEndTotalPrevious > 0))
548510 then fraction(votePrevious, gwxAmountAtEndTotal, gwxAmountAtEndTotalPrevious)
549511 else 0
550512 let actions = if (if ((newVote > 0))
551513 then wxEmission
552514 else false)
553515 then [IntegerEntry(keyVote(pool, userAddress, epoch), newVote), IntegerEntry(keyTotalVotes(epoch), (totalVotes + newVote)), IntegerEntry(keyVotingResult(pool, epoch), (votingResult + newVote)), IntegerEntry(keyUsed(userAddress, epoch), (used + newVote))]
554516 else deleteNodeActions(getVotesListName(pool), userAddressStr)
555517 $Tuple2((actions ++ votingResultStakedActions), unit)
556518 }
557519 else throw("Strict value is not equal to itself.")
558520 }
559521 else throw("Strict value is not equal to itself.")
560522 }
561523
562524
563525
564526 @Callable(i)
565527 func processPoolINTERNAL (poolStr,force) = {
566528 let checkCaller = mustThis(i)
567529 if ((checkCaller == checkCaller))
568530 then {
569531 let targetEpoch = {
570532 let currentEpoch = getIntOrFail(this, keyCurrentEpoch)
571533 if (force)
572534 then currentEpoch
573535 else (currentEpoch - 1)
574536 }
575537 let checkTargetEpoch = if ((targetEpoch >= 0))
576538 then true
577- else throw("processPoolINTERNAL: invalid target epoch")
539+ else throwErr("processPoolINTERNAL: invalid target epoch")
578540 if ((checkTargetEpoch == checkTargetEpoch))
579541 then {
580542 let pool = stringToPool(poolStr)
581- let $t02036620406 = pool
582- let amountAssetId = $t02036620406._1
583- let priceAssetId = $t02036620406._2
543+ let $t01988519925 = pool
544+ let amountAssetId = $t01988519925._1
545+ let priceAssetId = $t01988519925._2
584546 let stakingContract = addressFromStringValue(getStrOrFail(this, keyStakingContract))
585547 let factoryContract = addressFromStringValue(getStrOrFail(this, keyFactoryContract))
586548 let lpAssetId = getLpAssetByPoolAssets(amountAssetId, priceAssetId)
587549 let r = {
588550 let @ = invoke(stakingContract, "usersListTraversal", [lpAssetId], nil)
589551 if ($isInstanceOf(@, "Boolean"))
590552 then @
591553 else throw(($getType(@) + " couldn't be cast to Boolean"))
592554 }
593555 if ((r == r))
594556 then if (r)
595557 then $Tuple2(nil, true)
596558 else {
597559 let wxEmission = checkWxEmissionPoolLabel(pool)
598560 let totalVotes = valueOrElse(getInteger(this, keyTotalVotes(targetEpoch)), 0)
599561 let votingResult = valueOrElse(getInteger(this, keyVotingResult(pool, targetEpoch)), 0)
600562 let share = if (if ((totalVotes == 0))
601563 then true
602564 else !(wxEmission))
603565 then 0
604566 else fraction(votingResult, poolWeightMult, totalVotes)
605567 let modifyWeightInv = invoke(factoryContract, "modifyWeight", [lpAssetId, share], nil)
606568 if ((modifyWeightInv == modifyWeightInv))
607569 then {
608570 let poolsListActions = if (if (wxEmission)
609571 then true
610572 else force)
611573 then nil
612574 else ([DeleteEntry(keyInList(pool))] ++ deleteNodeActions(poolsListName, poolStr))
613575 $Tuple2(([IntegerEntry(keyPoolShare(pool, targetEpoch), share)] ++ poolsListActions), false)
614576 }
615577 else throw("Strict value is not equal to itself.")
616578 }
617579 else throw("Strict value is not equal to itself.")
618580 }
619581 else throw("Strict value is not equal to itself.")
620582 }
621583 else throw("Strict value is not equal to itself.")
622584 }
623585
624586
625587
626588 @Callable(i)
627589 func finalizeHelper () = {
628590 let force = valueOrElse(getBoolean(keyFinalizationShouldBeForced), false)
629591 let epoch = valueOrElse(getInteger(this, keyCurrentEpoch), 0)
630592 let previousEpoch = (epoch - 1)
631593 let startHeight = getIntOrFail(this, keyStartHeightByEpoch(epoch))
632594 let epochLength = getIntOrFail(this, keyEpochLength)
633595 let endHeight = (startHeight + epochLength)
634596 let finalizationStageOrUnit = getInteger(this, keyFinalizationStage)
635597 if (if (if ((height >= endHeight))
636598 then (finalizationStageOrUnit == unit)
637599 else false)
638600 then !(force)
639601 else false)
640602 then {
641603 let newEpoch = (epoch + 1)
642604 let newEpochLengthOption = getInteger(this, keyEpochLengthNew)
643605 let newEpochLengthActions = match newEpochLengthOption {
644606 case newEpochLength: Int =>
645607 [IntegerEntry(keyEpochLength, newEpochLength), DeleteEntry(keyEpochLengthNew)]
646608 case _: Unit =>
647609 nil
648610 case _ =>
649611 throw("Match error")
650612 }
651613 $Tuple2(([IntegerEntry(keyStartHeightByEpoch(newEpoch), height), IntegerEntry(keyStartHeight, height), IntegerEntry(keyCurrentEpoch, newEpoch), IntegerEntry(keyFinalizationStage, finalizationStageTotal), IntegerEntry(keyEpochLengthByEpoch(epoch), epochLength)] ++ newEpochLengthActions), true)
652614 }
653615 else if (if (force)
654616 then (finalizationStageOrUnit == unit)
655617 else false)
656618 then $Tuple2([IntegerEntry(keyFinalizationStage, finalizationStageShares)], true)
657619 else if ((finalizationStageOrUnit == unit))
658620 then $Tuple2(nil, false)
659621 else if ((finalizationStageOrUnit == finalizationStageTotal))
660622 then {
661623 let poolOrUnit = getString(keyNextPool)
662624 let userOrUnit = getString(keyNextUser)
663625 match poolOrUnit {
664626 case _: Unit =>
665627 match getString(keyListHead(poolsListName)) {
666628 case _: Unit =>
667629 $Tuple2([IntegerEntry(keyFinalizationStage, finalizationStageShares), DeleteEntry(keyNextPool), DeleteEntry(keyNextUser)], true)
668630 case poolsHeadStr: String =>
669631 $Tuple2([StringEntry(keyNextPool, poolsHeadStr)], true)
670632 case _ =>
671633 throw("Match error")
672634 }
673635 case poolStr: String =>
674636 let pool = stringToPool(poolStr)
675637 let nextUserOrUnit = match userOrUnit {
676638 case _: Unit =>
677639 getString(keyListHead(getVotesListName(pool)))
678640 case user: String =>
679641 let next = getString(keyListNext(getVotesListName(pool), user))
680642 if ((next == next))
681643 then {
682644 let processVoteInv = invoke(this, "processVoteINTERNAL", [poolStr, user], nil)
683645 if ((processVoteInv == processVoteInv))
684646 then next
685647 else throw("Strict value is not equal to itself.")
686648 }
687649 else throw("Strict value is not equal to itself.")
688650 case _ =>
689651 throw("Match error")
690652 }
691653 match nextUserOrUnit {
692654 case _: Unit =>
693655 let nextPoolOrUnit = getString(keyListNext(poolsListName, poolStr))
694656 match nextPoolOrUnit {
695657 case _: Unit =>
696658 $Tuple2([IntegerEntry(keyFinalizationStage, finalizationStageShares), DeleteEntry(keyNextPool), DeleteEntry(keyNextUser)], true)
697659 case s: String =>
698660 $Tuple2([StringEntry(keyNextPool, s), DeleteEntry(keyNextUser)], true)
699661 case _ =>
700662 throw("Match error")
701663 }
702664 case nextUser: String =>
703665 $Tuple2([StringEntry(keyNextUser, nextUser)], true)
704666 case _ =>
705667 throw("Match error")
706668 }
707669 case _ =>
708670 throw("Match error")
709671 }
710672 }
711673 else if ((finalizationStageOrUnit == finalizationStageShares))
712674 then {
713675 let poolOrUnit = getString(keyNextPool)
714676 match poolOrUnit {
715677 case _: Unit =>
716678 match getString(keyListHead(poolsListName)) {
717679 case _: Unit =>
718680 let actions = if (force)
719681 then [DeleteEntry(keyFinalizationStage), DeleteEntry(keyFinalizationShouldBeForced)]
720682 else [DeleteEntry(keyFinalizationStage), BooleanEntry(keyFinalized(previousEpoch), true), IntegerEntry(keyCurrentEpochUi, epoch), IntegerEntry(keyStartHeightUi, startHeight)]
721683 $Tuple2(actions, true)
722684 case nextPoolStr: String =>
723685 $Tuple2([StringEntry(keyNextPool, nextPoolStr)], true)
724686 case _ =>
725687 throw("Match error")
726688 }
727689 case poolStr: String =>
728690 let nextPoolOrUnit = getString(keyListNext(poolsListName, poolStr))
729691 if ((nextPoolOrUnit == nextPoolOrUnit))
730692 then {
731693 let r = {
732694 let @ = invoke(this, "processPoolINTERNAL", [poolStr, force], nil)
733695 if ($isInstanceOf(@, "Boolean"))
734696 then @
735697 else throw(($getType(@) + " couldn't be cast to Boolean"))
736698 }
737699 if ((r == r))
738700 then if (r)
739701 then $Tuple2(nil, true)
740702 else match nextPoolOrUnit {
741703 case _: Unit =>
742704 let actions = if (force)
743705 then [DeleteEntry(keyFinalizationStage), DeleteEntry(keyFinalizationShouldBeForced), DeleteEntry(keyNextPool)]
744706 else [DeleteEntry(keyFinalizationStage), BooleanEntry(keyFinalized(previousEpoch), true), IntegerEntry(keyCurrentEpochUi, epoch), IntegerEntry(keyStartHeightUi, startHeight), DeleteEntry(keyNextPool)]
745707 $Tuple2(actions, true)
746708 case nextPoolStr: String =>
747709 $Tuple2([StringEntry(keyNextPool, nextPoolStr)], true)
748710 case _ =>
749711 throw("Match error")
750712 }
751713 else throw("Strict value is not equal to itself.")
752714 }
753715 else throw("Strict value is not equal to itself.")
754716 case _ =>
755717 throw("Match error")
756718 }
757719 }
758- else throw("finalization is broken")
720+ else throwErr("finalization is broken")
759721 }
760722
761723
762724
763725 @Callable(i)
764726 func finalizeWrapper (counter) = {
765727 let result = {
766728 let @ = invoke(this, "finalizeHelper", nil, nil)
767729 if ($isInstanceOf(@, "Boolean"))
768730 then @
769731 else throw(($getType(@) + " couldn't be cast to Boolean"))
770732 }
771733 if ((result == result))
772734 then if (!(result))
773735 then if ((counter == 0))
774- then throw("Current voting is not over yet")
736+ then throwErr("Current voting is not over yet")
775737 else $Tuple2(nil, unit)
776738 else {
777739 let maxDepth = valueOrElse(getInteger(this, keyMaxDepth), maxDepthDefault)
778740 if ((maxDepth > counter))
779741 then {
780742 let inv = invoke(this, "finalizeWrapper", [(counter + 1)], nil)
781743 if ((inv == inv))
782744 then $Tuple2(nil, unit)
783745 else throw("Strict value is not equal to itself.")
784746 }
785747 else $Tuple2(nil, unit)
786748 }
787749 else throw("Strict value is not equal to itself.")
788750 }
789751
790752
791753
792754 @Callable(i)
793755 func finalize () = {
794756 let inv = invoke(this, "finalizeWrapper", [0], nil)
795757 if ((inv == inv))
796758 then $Tuple2(nil, unit)
797759 else throw("Strict value is not equal to itself.")
798760 }
799761
800762
801763
802764 @Callable(i)
803765 func containsNodeREADONLY (listName,id) = $Tuple2(nil, containsNode(listName, id))
804766
805767
806768
807769 @Callable(i)
808770 func insertNode (listName,id) = {
809771 let checkCaller = mustManager(i)
810772 if ((checkCaller == checkCaller))
811773 then $Tuple2(insertNodeActions(listName, id), unit)
812774 else throw("Strict value is not equal to itself.")
813775 }
814776
815777
816778
817779 @Callable(i)
818780 func deleteNode (listName,id) = {
819781 let checkCaller = mustManager(i)
820782 if ((checkCaller == checkCaller))
821783 then $Tuple2(deleteNodeActions(listName, id), unit)
822784 else throw("Strict value is not equal to itself.")
823785 }
824786
825787
826788 @Verifier(tx)
827789 func verify () = {
828790 let targetPublicKey = match managerPublicKeyOrUnit() {
829791 case pk: ByteVector =>
830792 pk
831793 case _: Unit =>
832794 tx.senderPublicKey
833795 case _ =>
834796 throw("Match error")
835797 }
836798 sigVerify(tx.bodyBytes, tx.proofs[0], targetPublicKey)
837799 }
838800

github/deemru/w8io/873ac7e 
143.16 ms