tx · 5mdwckWoBuwHGxXrUXHeYhvZFyg7PfnXgoE6CtGxbTWw

3N9Zi6AcWcGbM23jQJ4fnzFsoHoTsxYDznr:  -0.02200000 Waves

2023.05.19 16:10 [2584885] smart account 3N9Zi6AcWcGbM23jQJ4fnzFsoHoTsxYDznr > SELF 0.00000000 Waves

{ "type": 13, "id": "5mdwckWoBuwHGxXrUXHeYhvZFyg7PfnXgoE6CtGxbTWw", "fee": 2200000, "feeAssetId": null, "timestamp": 1684501847824, "version": 2, "chainId": 84, "sender": "3N9Zi6AcWcGbM23jQJ4fnzFsoHoTsxYDznr", "senderPublicKey": "GFbasS3jufhZkK4xR7tdTjjnP8K33KvJFEDHRtxXDkaJ", "proofs": [ "3ErUDiN96oPY7ao637JbCah7DQaUhBH2LohjzsAcdpB2ScSyvjZq6Y6oDxJC5sQ5cDnUdg2b5q3Kr5CuCtws9toB" ], "script": "base64:BgKpFggCEgQKAggBEgcKBQgICAgBEgQKAggIEgUKAwgIARIECgIICBIDCgEBEgMKAQESBAoCCAgSBAoCCAQSABIDCgEBEgASBAoCCAgSBAoCCAgSBAoCCAgiCXNlcGFyYXRvciIOcG9vbFdlaWdodE11bHQiD21heERlcHRoRGVmYXVsdCIWZmluYWxpemF0aW9uU3RhZ2VUb3RhbCIXZmluYWxpemF0aW9uU3RhZ2VTaGFyZXMiDmtleUVwb2NoTGVuZ3RoIhFrZXlFcG9jaExlbmd0aE5ldyIVa2V5RXBvY2hMZW5ndGhCeUVwb2NoIgVlcG9jaCIPa2V5Q3VycmVudEVwb2NoIgtrZXlNYXhEZXB0aCIia2V5Vm90aW5nRW1pc3Npb25DYW5kaWRhdGVDb250cmFjdCISa2V5RmFjdG9yeUNvbnRyYWN0IhNrZXlCb29zdGluZ0NvbnRyYWN0IhJrZXlTdGFraW5nQ29udHJhY3QiFGtleUZpbmFsaXphdGlvblN0YWdlIgtrZXlOZXh0UG9vbCILa2V5TmV4dFVzZXIiDmtleVN0YXJ0SGVpZ2h0IhFrZXlDdXJyZW50RXBvY2hVaSIQa2V5U3RhcnRIZWlnaHRVaSIda2V5RmluYWxpemF0aW9uU2hvdWxkQmVGb3JjZWQiFWtleVN0YXJ0SGVpZ2h0QnlFcG9jaCIMa2V5RmluYWxpemVkIglrZXlJbkxpc3QiBHBvb2wiCyR0MDE2OTMxNzMzIg1hbW91bnRBc3NldElkIgxwcmljZUFzc2V0SWQiB2tleVVzZWQiB2FkZHJlc3MiB2tleVZvdGUiCyR0MDIwMDcyMDQ3Ig9rZXlWb3RpbmdSZXN1bHQiCyR0MDIyMjkyMjY5IhVrZXlWb3RpbmdSZXN1bHRTdGFrZWQiDGxwQXNzZXRJZFN0ciIMa2V5UG9vbFNoYXJlIgskdDAyNTkwMjYzMCINa2V5VG90YWxWb3RlcyIPa2V5U3Rha2VkQnlVc2VyIg51c2VyQWRkcmVzc1N0ciIHd3JhcEVyciIDbXNnIgh0aHJvd0VyciIOZ2V0VmFsdWVPckZhaWwiA2tleSIEdHlwZSIFZXJyb3IiByRtYXRjaDAiA3N0ciIDaW50IgxnZXRTdHJPckZhaWwiAUAiDGdldEludE9yRmFpbCIMcG9vbFRvU3RyaW5nIgxzdHJpbmdUb1Bvb2wiBXBhcnRzIg9mYWN0b3J5Q29udHJhY3QiGklkeEZhY3RvcnlDZmdHd3hSZXdhcmREYXBwIg1rZXlGYWN0b3J5Q2ZnIhRyZWFkRmFjdG9yeUNmZ09yRmFpbCIHZmFjdG9yeSIZZ2V0R3d4UmV3YXJkQWRkcmVzc09yRmFpbCIKZmFjdG9yeUNmZyIWZ2V0THBBc3NldEJ5UG9vbEFzc2V0cyIfa2V5TWFwcGluZ3NCYXNlQXNzZXQyaW50ZXJuYWxJZCIMYmFzZUFzc2V0U3RyIilrZXlNYXBwaW5nUG9vbEFzc2V0c1RvUG9vbENvbnRyYWN0QWRkcmVzcyIYaW50ZXJuYWxBbW91bnRBc3NldElkU3RyIhdpbnRlcm5hbFByaWNlQXNzZXRJZFN0ciIfa2V5TWFwcGluZ1Bvb2xDb250cmFjdFRvTFBBc3NldCITcG9vbENvbnRyYWN0QWRkcmVzcyIVYW1vdW50QXNzZXRJbnRlcm5hbElkIhRwcmljZUFzc2V0SW50ZXJuYWxJZCIJbHBBc3NldElkIhhjaGVja1d4RW1pc3Npb25Qb29sTGFiZWwiCyR0MDU0NzA1NTEwIhBnd3hSZXdhcmREZXBvc2l0IhJnd3hSZXdhcmRzQ29udHJhY3QiDXBvb2xzTGlzdE5hbWUiEGdldFZvdGVzTGlzdE5hbWUiCyR0MDU5Mjc1OTY3IgtrZXlMaXN0SGVhZCIIbGlzdE5hbWUiBG1ldGEiC2tleUxpc3RTaXplIgtrZXlMaXN0UHJldiICaWQiC2tleUxpc3ROZXh0Igxjb250YWluc05vZGUiCmhlYWRPclVuaXQiCnByZXZPclVuaXQiCm5leHRPclVuaXQiEWluc2VydE5vZGVBY3Rpb25zIghsaXN0U2l6ZSIJY2hlY2tOb2RlIhFkZWxldGVOb2RlQWN0aW9ucyIWa2V5TWFuYWdlclZhdWx0QWRkcmVzcyITa2V5TWFuYWdlclB1YmxpY0tleSIcZ2V0TWFuYWdlclZhdWx0QWRkcmVzc09yVGhpcyIBcyIWbWFuYWdlclB1YmxpY0tleU9yVW5pdCITbWFuYWdlclZhdWx0QWRkcmVzcyIJaXNNYW5hZ2VyIgFpIgJwayILbXVzdE1hbmFnZXIiCG11c3RUaGlzIgt1c2VyQWRkcmVzcyIMdGFyZ2V0SGVpZ2h0Ihdib29zdGluZ0NvbnRyYWN0QWRkcmVzcyIfdm90aW5nRW1pc3Npb25DYW5kaWRhdGVDb250cmFjdCIQYm9vc3RpbmdDb250cmFjdCIPc3Rha2luZ0NvbnRyYWN0IgtlcG9jaExlbmd0aCIGY2hlY2tzIg1pbkxpc3RBY3Rpb25zIhhjdXJyZW50RXBvY2hJc05vdERlZmluZWQiEnN0YXJ0SGVpZ2h0QWN0aW9ucyIGYW1vdW50IgtzdGFydEhlaWdodCIJZW5kSGVpZ2h0IhdmaW5hbGl6YXRpb25TdGFnZU9yVW5pdCIEdXNlZCIEdm90ZSIKcG9vbFJlc3VsdCIKdG90YWxWb3RlcyITZ3d4QW1vdW50QXRFbmRUb3RhbCIJYXZhaWxhYmxlIgduZXdWb3RlIgp3eEVtaXNzaW9uIg12b3Rlc0xpc3ROYW1lIhB2b3Rlc0xpc3RBY3Rpb25zIg5uZXdFcG9jaExlbmd0aCILbmV3TWF4RGVwdGgiB3Bvb2xTdHIiC2NoZWNrQ2FsbGVyIg1lcG9jaFByZXZpb3VzIhNzdGFydEhlaWdodFByZXZpb3VzIhNlcG9jaExlbmd0aFByZXZpb3VzIhFlbmRIZWlnaHRQcmV2aW91cyIQY2hlY2tUYXJnZXRFcG9jaCINJHQwMTc5NzAxODAxMCIbZ3d4QW1vdW50QXRFbmRUb3RhbFByZXZpb3VzIgx2b3RpbmdSZXN1bHQiDHZvdGVQcmV2aW91cyIadm90aW5nUmVzdWx0U3Rha2VkUHJldmlvdXMiDHN0YWtlZEJ5VXNlciIZdm90aW5nUmVzdWx0U3Rha2VkQWN0aW9ucyIHYWN0aW9ucyIFZm9yY2UiC3RhcmdldEVwb2NoIgxjdXJyZW50RXBvY2giDSR0MDIwMzY3MjA0MDciAXIiBXNoYXJlIg9tb2RpZnlXZWlnaHRJbnYiEHBvb2xzTGlzdEFjdGlvbnMiDXByZXZpb3VzRXBvY2giCG5ld0Vwb2NoIhRuZXdFcG9jaExlbmd0aE9wdGlvbiIVbmV3RXBvY2hMZW5ndGhBY3Rpb25zIgpwb29sT3JVbml0Igp1c2VyT3JVbml0IgckbWF0Y2gxIgxwb29sc0hlYWRTdHIiDm5leHRVc2VyT3JVbml0IgR1c2VyIgRuZXh0Ig5wcm9jZXNzVm90ZUludiIObmV4dFBvb2xPclVuaXQiByRtYXRjaDIiCG5leHRVc2VyIhNnd3hSZXdhcmREZXBvc2l0SW52IgtuZXh0UG9vbFN0ciIHY291bnRlciIGcmVzdWx0IghtYXhEZXB0aCIDaW52IgJ0eCIGdmVyaWZ5Ig90YXJnZXRQdWJsaWNLZXk+AAFhAgJfXwABYgCAwtcvAAFjAAoAAWQAAAABZQABAAFmCQC5CQIJAMwIAgICJXMJAMwIAgILZXBvY2hMZW5ndGgFA25pbAUBYQABZwkAuQkCCQDMCAICBCVzJXMJAMwIAgIQZXBvY2hMZW5ndGhfX25ldwUDbmlsBQFhAQFoAQFpCQC5CQIJAMwIAgIEJXMlZAkAzAgCAgtlcG9jaExlbmd0aAkAzAgCCQCkAwEFAWkFA25pbAUBYQABagkAuQkCCQDMCAICAiVzCQDMCAICDGN1cnJlbnRFcG9jaAUDbmlsBQFhAAFrCQC5CQIJAMwIAgICJXMJAMwIAgIIbWF4RGVwdGgFA25pbAUBYQABbAkAuQkCCQDMCAICAiVzCQDMCAICH3ZvdGluZ0VtaXNzaW9uQ2FuZGlkYXRlQ29udHJhY3QFA25pbAUBYQABbQkAuQkCCQDMCAICAiVzCQDMCAICD2ZhY3RvcnlDb250cmFjdAUDbmlsBQFhAAFuCQC5CQIJAMwIAgICJXMJAMwIAgIQYm9vc3RpbmdDb250cmFjdAUDbmlsBQFhAAFvCQC5CQIJAMwIAgICJXMJAMwIAgIPc3Rha2luZ0NvbnRyYWN0BQNuaWwFAWEAAXAJALkJAgkAzAgCAgIlcwkAzAgCAhFmaW5hbGl6YXRpb25TdGFnZQUDbmlsBQFhAAFxCQC5CQIJAMwIAgICJXMJAMwIAgIIbmV4dFBvb2wFA25pbAUBYQABcgkAuQkCCQDMCAICAiVzCQDMCAICCG5leHRVc2VyBQNuaWwFAWEAAXMJALkJAgkAzAgCAgIlcwkAzAgCAgtzdGFydEhlaWdodAUDbmlsBQFhAAF0CQC5CQIJAMwIAgICJXMJAMwIAgIOY3VycmVudEVwb2NoVWkFA25pbAUBYQABdQkAuQkCCQDMCAICAiVzCQDMCAICDXN0YXJ0SGVpZ2h0VWkFA25pbAUBYQABdgkAuQkCCQDMCAICAiVzCQDMCAICBWZvcmNlBQNuaWwFAWEBAXcBAWkJALkJAgkAzAgCAgQlcyVkCQDMCAICC3N0YXJ0SGVpZ2h0CQDMCAIJAKQDAQUBaQUDbmlsBQFhAQF4AQFpCQC5CQIJAMwIAgIEJXMlZAkAzAgCAglmaW5hbGl6ZWQJAMwIAgkApAMBBQFpBQNuaWwFAWEBAXkBAXoEAUEFAXoEAUIIBQFBAl8xBAFDCAUBQQJfMgkAuQkCCQDMCAICBiVzJXMlcwkAzAgCAgZpbkxpc3QJAMwIAgUBQgkAzAgCBQFDBQNuaWwFAWEBAUQCAUUBaQkAuQkCCQDMCAICBiVzJXMlZAkAzAgCAgR1c2VkCQDMCAIJAKUIAQUBRQkAzAgCCQCkAwEFAWkFA25pbAUBYQEBRgMBegFFAWkEAUcFAXoEAUIIBQFHAl8xBAFDCAUBRwJfMgkAuQkCCQDMCAICCiVzJXMlcyVzJWQJAMwIAgIEdm90ZQkAzAgCBQFCCQDMCAIFAUMJAMwIAgkApQgBBQFFCQDMCAIJAKQDAQUBaQUDbmlsBQFhAQFIAgF6AWkEAUkFAXoEAUIIBQFJAl8xBAFDCAUBSQJfMgkAuQkCCQDMCAICCCVzJXMlcyVkCQDMCAICDHZvdGluZ1Jlc3VsdAkAzAgCBQFCCQDMCAIFAUMJAMwIAgkApAMBBQFpBQNuaWwFAWEBAUoCAUsBaQkAuQkCCQDMCAICBiVzJXMlZAkAzAgCAhJ2b3RpbmdSZXN1bHRTdGFrZWQJAMwIAgUBSwkAzAgCCQCkAwEFAWkFA25pbAUBYQEBTAIBegFpBAFNBQF6BAFCCAUBTQJfMQQBQwgFAU0CXzIJALkJAgkAzAgCAgglcyVzJXMlZAkAzAgCAglwb29sU2hhcmUJAMwIAgUBQgkAzAgCBQFDCQDMCAIJAKQDAQUBaQUDbmlsBQFhAQFOAQFpCQC5CQIJAMwIAgIEJXMlZAkAzAgCAgp0b3RhbFZvdGVzCQDMCAIJAKQDAQUBaQUDbmlsBQFhAQFPAgFLAVAJALkJAgkAzAgCAgYlcyVzJXMJAMwIAgIGc3Rha2VkCQDMCAIFAVAJAMwIAgUBSwUDbmlsBQFhAQFRAQFSCQC5CQIJAMwIAgIVdm90aW5nX2VtaXNzaW9uLnJpZGU6CQDMCAIFAVIFA25pbAIBIAEBUwEBUgkAAgEJAQFRAQUBUgEBVAMBRQFVAVYEAVcJAQFRAQkAuQkCCQDMCAICCm1hbmRhdG9yeSAJAMwIAgkApQgBBQFFCQDMCAICAS4JAMwIAgUBVQkAzAgCAg8gaXMgbm90IGRlZmluZWQFA25pbAIACQETdmFsdWVPckVycm9yTWVzc2FnZQIEAVgFAVYDCQABAgUBWAIGU3RyaW5nBAFZBQFYCQCdCAIFAUUFAVUDCQABAgUBWAIDSW50BAFaBQFYCQCaCAIFAUUFAVUJAQFTAQISaW52YWxpZCBlbnRyeSB0eXBlBQFXAQJhYQIBRQFVCgACYWIJAQFUAwUBRQUBVQIAAwkAAQIFAmFiAgZTdHJpbmcFAmFiCQACAQkArAICCQADAQUCYWICGyBjb3VsZG4ndCBiZSBjYXN0IHRvIFN0cmluZwECYWMCAUUBVQoAAmFiCQEBVAMFAUUFAVUAAAMJAAECBQJhYgIDSW50BQJhYgkAAgEJAKwCAgkAAwEFAmFiAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQBAmFkAQF6CQCsAgIJAKwCAggFAXoCXzEFAWEIBQF6Al8yAQJhZQEBWQQCYWYJALUJAgUBWQUBYQMJAAACCQCQAwEFAmFmAAIJAJQKAgkAkQMCBQJhZgAACQCRAwIFAmFmAAEJAQFTAQITaW52YWxpZCBwb29sIHN0cmluZwACYWcJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQJhYQIFBHRoaXMFAW0AAmFoAAoBAmFpAAIRJXNfX2ZhY3RvcnlDb25maWcBAmFqAQJhawkAtQkCCQECYWECBQJhawkBAmFpAAUBYQECYWwBAmFtCQERQGV4dHJOYXRpdmUoMTA2MikBCQCRAwIFAmFtBQJhaAECYW4CAUIBQwoBAmFvAQJhcAkArAICAiglcyVzJXNfX21hcHBpbmdzX19iYXNlQXNzZXQyaW50ZXJuYWxJZF9fBQJhcAoBAmFxAgJhcgJhcwkArAICCQCsAgIJAKwCAgkArAICAgolZCVkJXMlc19fCQCkAwEFAmFyAgJfXwkApAMBBQJhcwIjX19tYXBwaW5nc19fcG9vbEFzc2V0czJQb29sQ29udHJhY3QKAQJhdAECYXUJAKwCAgkArAICAgglcyVzJXNfXwUCYXUCIF9fbWFwcGluZ3NfX3Bvb2xDb250cmFjdDJMcEFzc2V0BAJhdgkBAmFjAgUCYWcJAQJhbwEFAUIEAmF3CQECYWMCBQJhZwkBAmFvAQUBQwQCYXUJAQJhYQIFAmFnCQECYXECBQJhdgUCYXcEAmF4CQECYWECBQJhZwkBAmF0AQUCYXUFAmF4AQJheQEBegQCYXoFAXoEAUIIBQJhegJfMQQBQwgFAmF6Al8yCgACYWIJAPwHBAUCYWcCGGNoZWNrV3hFbWlzc2lvblBvb2xMYWJlbAkAzAgCBQFCCQDMCAIFAUMFA25pbAUDbmlsAwkAAQIFAmFiAgdCb29sZWFuBQJhYgkAAgEJAKwCAgkAAwEFAmFiAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuAQJhQQAEAmFtCQECYWoBBQJhZwQCYUIJAQJhbAEFAmFtCQD8BwQFAmFCAgdkZXBvc2l0BQNuaWwFA25pbAACYUMCBXBvb2xzAQJhRAEBegQCYUUFAXoEAUIIBQJhRQJfMQQBQwgFAmFFAl8yCQC5CQIJAMwIAgIFdm90ZXMJAMwIAgUBQgkAzAgCBQFDBQNuaWwFAWEBAmFGAQJhRwQCYUgDCQAAAgUCYUcFAmFDAgQlcyVzAgglcyVzJXMlcwkAuQkCCQDMCAIFAmFICQDMCAIFAmFHCQDMCAICBGhlYWQFA25pbAUBYQECYUkBAmFHBAJhSAMJAAACBQJhRwUCYUMCBCVzJXMCCCVzJXMlcyVzCQC5CQIJAMwIAgUCYUgJAMwIAgUCYUcJAMwIAgIEc2l6ZQUDbmlsBQFhAQJhSgICYUcCYUsEAmFIAwkAAAIFAmFHBQJhQwIIJXMlcyVzJXMCCiVzJXMlcyVzJXMJALkJAgkAzAgCBQJhSAkAzAgCBQJhRwkAzAgCBQJhSwkAzAgCAgRwcmV2BQNuaWwFAWEBAmFMAgJhRwJhSwQCYUgDCQAAAgUCYUcFAmFDAgglcyVzJXMlcwIKJXMlcyVzJXMlcwkAuQkCCQDMCAIFAmFICQDMCAIFAmFHCQDMCAIFAmFLCQDMCAICBG5leHQFA25pbAUBYQECYU0CAmFHAmFLBAJhTgkAnQgCBQR0aGlzCQECYUYBBQJhRwQCYU8JAJ0IAgUEdGhpcwkBAmFKAgUCYUcFAmFLBAJhUAkAnQgCBQR0aGlzCQECYUwCBQJhRwUCYUsDAwkAAAIFAmFLCQELdmFsdWVPckVsc2UCBQJhTgIABgkBAiE9AgUCYU8FBHVuaXQGCQECIT0CBQJhUAUEdW5pdAECYVECAmFHAmFLBAJhTgkAnQgCBQR0aGlzCQECYUYBBQJhRwQCYVIJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBAmFJAQUCYUcAAAQCYVMDCQEBIQEJAQJhTQIFAmFHBQJhSwYJAQFTAQILTm9kZSBleGlzdHMDCQAAAgUCYVMFAmFTCQDOCAIJAM4IAgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAmFJAQUCYUcJAGQCBQJhUgABBQNuaWwDCQECIT0CBQJhTgUEdW5pdAkAzAgCCQELU3RyaW5nRW50cnkCCQECYUwCBQJhRwUCYUsJAQV2YWx1ZQEFAmFOCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhSgIFAmFHCQEFdmFsdWUBBQJhTgUCYUsFA25pbAUDbmlsCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhRgEFAmFHBQJhSwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJhVAICYUcCYUsEAmFOCQCdCAIFBHRoaXMJAQJhRgEFAmFHBAJhUgkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQECYUkBBQJhRwAABAJhTwkAnQgCBQR0aGlzCQECYUoCBQJhRwUCYUsEAmFQCQCdCAIFBHRoaXMJAQJhTAIFAmFHBQJhSwkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYUkBBQJhRwkAZQIFAmFSAAEFA25pbAMDCQECIT0CBQJhTwUEdW5pdAkBAiE9AgUCYVAFBHVuaXQHCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhTAIFAmFHCQEFdmFsdWUBBQJhTwkBBXZhbHVlAQUCYVAJAMwIAgkBC1N0cmluZ0VudHJ5AgkBAmFKAgUCYUcJAQV2YWx1ZQEFAmFQCQEFdmFsdWUBBQJhTwkAzAgCCQELRGVsZXRlRW50cnkBCQECYUoCBQJhRwUCYUsJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAmFMAgUCYUcFAmFLBQNuaWwDCQECIT0CBQJhUAUEdW5pdAkAzAgCCQELU3RyaW5nRW50cnkCCQECYUYBBQJhRwkBBXZhbHVlAQUCYVAJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAmFMAgUCYUcFAmFLCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhSgIFAmFHCQEFdmFsdWUBBQJhUAUDbmlsAwkBAiE9AgUCYU8FBHVuaXQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAmFKAgUCYUcFAmFLCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhTAIFAmFHCQEFdmFsdWUBBQJhTwUDbmlsAwkAAAIFAmFLCQELdmFsdWVPckVsc2UCBQJhTgIACQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhRgEFAmFHBQNuaWwJAQFTAQkArAICCQCsAgIJAKwCAgIOaW52YWxpZCBub2RlOiAFAmFHAgEuBQJhSwECYVUAAhclc19fbWFuYWdlclZhdWx0QWRkcmVzcwECYVYAAhQlc19fbWFuYWdlclB1YmxpY0tleQECYVcABAFYCQCiCAEJAQJhVQADCQABAgUBWAIGU3RyaW5nBAJhWAUBWAkBEUBleHRyTmF0aXZlKDEwNjIpAQUCYVgFBHRoaXMBAmFZAAQCYVoJAQJhVwAEAVgJAJ0IAgUCYVoJAQJhVgADCQABAgUBWAIGU3RyaW5nBAJhWAUBWAkA2QQBBQJhWAMJAAECBQFYAgRVbml0BQR1bml0CQACAQILTWF0Y2ggZXJyb3IBAmJhAQJiYgQBWAkBAmFZAAMJAAECBQFYAgpCeXRlVmVjdG9yBAJiYwUBWAkAAAIIBQJiYg9jYWxsZXJQdWJsaWNLZXkFAmJjAwkAAQIFAVgCBFVuaXQJAAACCAUCYmIGY2FsbGVyBQR0aGlzCQACAQILTWF0Y2ggZXJyb3IBAmJkAQJiYgMJAQJiYQEFAmJiBgkAAgECEXBlcm1pc3Npb24gZGVuaWVkAQJiZQECYmIDCQAAAggFAmJiBmNhbGxlcgUEdGhpcwYJAAIBAhFwZXJtaXNzaW9uIGRlbmllZA8CYmIBGGdldFVzZXJHd3hBbW91bnRBdEhlaWdodAICYmYCYmcEAmJoCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBAmFhAgUEdGhpcwUBbgkBAVEBAiFpbnZhbGlkIGJvb3N0aW5nIGNvbnRyYWN0IGFkZHJlc3MJAJQKAgUDbmlsCgACYWIJAPwHBAUCYmgCIGdldFVzZXJHd3hBbW91bnRBdEhlaWdodFJFQURPTkxZCQDMCAIFAmJmCQDMCAIFAmJnBQNuaWwFA25pbAMJAAECBQJhYgIDSW50BQJhYgkAAgEJAKwCAgkAAwEFAmFiAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQCYmIBC2NvbnN0cnVjdG9yBQJhZwJiaQJiagJiawJibAQCYm0JAMwIAgkBAmJkAQUCYmIJAMwIAgMJAQIhPQIJAKYIAQUCYWcFBHVuaXQGAiBpbnZhbGlkIGZhY3RvcnkgY29udHJhY3QgYWRkcmVzcwkAzAgCAwkBAiE9AgkApggBBQJiaQUEdW5pdAYCMmludmFsaWQgdm90aW5nIGVtaXNzaW9uIGNhbmRpZGF0ZSBjb250cmFjdCBhZGRyZXNzCQDMCAIDCQECIT0CCQCmCAEFAmJqBQR1bml0BgIhaW52YWxpZCBib29zdGluZyBjb250cmFjdCBhZGRyZXNzCQDMCAIDCQECIT0CCQCmCAEFAmJrBQR1bml0BgIgaW52YWxpZCBzdGFraW5nIGNvbnRyYWN0IGFkZHJlc3MJAMwIAgMJAGYCBQJibAAABgkBAVMBAhRpbnZhbGlkIGVwb2NoIGxlbmd0aAUDbmlsAwkAAAIFAmJtBQJibQkAlAoCCQDMCAIJAQtTdHJpbmdFbnRyeQIFAW0FAmFnCQDMCAIJAQtTdHJpbmdFbnRyeQIFAWwFAmJpCQDMCAIJAQtTdHJpbmdFbnRyeQIFAW4FAmJqCQDMCAIJAQtTdHJpbmdFbnRyeQIFAW8FAmJrCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQFmBQJibAUDbmlsBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJiAQZjcmVhdGUCAUIBQwQCYm0JAMwIAgMJAAACCQDYBAEICAUCYmIGY2FsbGVyBWJ5dGVzCQELdmFsdWVPckVsc2UCCQCdCAIFBHRoaXMFAWwCAAYJAQJiZAEFAmJiBQNuaWwDCQAAAgUCYm0FAmJtBAF6CQCUCgIFAUIFAUMEAmJuCQDOCAIJAMwIAgkBDEJvb2xlYW5FbnRyeQIJAQF5AQUBegYFA25pbAkBAmFRAgUCYUMJAQJhZAEFAXoEAmJvCQAAAgkAmggCBQR0aGlzBQFqBQR1bml0BAJicAMFAmJvBAFpAAAJAMwIAgkBDEludGVnZXJFbnRyeQIFAWoFAWkJAMwIAgkBDEludGVnZXJFbnRyeQIJAQF3AQUBaQUGaGVpZ2h0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQFzBQZoZWlnaHQJAMwIAgkBDEludGVnZXJFbnRyeQIFAXQFAWkJAMwIAgkBDEludGVnZXJFbnRyeQIFAXUFBmhlaWdodAUDbmlsBQNuaWwJAJQKAgkAzggCBQJibgUCYnAFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYmIBBHZvdGUDAUIBQwJicQQBegkAlAoCBQFCBQFDBAFpCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFAWoAAAQCYnIJAQJhYwIFBHRoaXMJAQF3AQUBaQQCYmwJAQJhYwIFBHRoaXMFAWYEAmJzCQBkAgUCYnIFAmJsBAJidAkAmggCBQR0aGlzBQFwBAJidQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEBRAIIBQJiYgZjYWxsZXIFAWkAAAQCYnYJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBAUYDBQF6CAUCYmIGY2FsbGVyBQFpAAAEAmJ3CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQFIAgUBegUBaQAABAJieAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEBTgEFAWkAAAQCYnkKAAJhYgkA/AcEBQR0aGlzAhhnZXRVc2VyR3d4QW1vdW50QXRIZWlnaHQJAMwIAgkA2AQBCAgFAmJiBmNhbGxlcgVieXRlcwkAzAgCBQJicwUDbmlsBQNuaWwDCQABAgUCYWICA0ludAUCYWIJAAIBCQCsAgIJAAMBBQJhYgIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50BAJiegkAZQIFAmJ5BQJidQQCYkEJAGQCBQJidgUCYnEEAmJCCQECYXkBBQF6BAJibQkAzAgCAwkBAiE9AgkAoAgBCQEBeQEFAXoFBHVuaXQGCQEBUwECDmludmFsaWQgYXNzZXRzCQDMCAIDCQBmAgUCYnMFBmhlaWdodAYJAQFTAQIOaW52YWxpZCBoZWlnaHQJAMwIAgMJAAACBQJidAUEdW5pdAYJAQFTAQIYZmluYWxpemF0aW9uIGluIHByb2dyZXNzCQDMCAIDCQBmAgUCYnkAAAYJAQFTAQITeW91IGRvIG5vdCBoYXZlIGdXWAkAzAgCAwMJAGYCBQJicQAACQBnAgUCYnoFAmJxBwYJAQFTAQIOaW52YWxpZCBhbW91bnQJAMwIAgMFAmJCBgkBAVMBAh1wb29sIGhhc24ndCBXWF9FTUlTU0lPTiBsYWJlbAUDbmlsAwkAAAIFAmJtBQJibQQCYkMJAQJhRAEFAXoEAVAJAKUIAQgFAmJiBmNhbGxlcgQCYkQDCQECYU0CBQJiQwUBUAUDbmlsCQECYVECBQJiQwUBUAkAlAoCCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFEAggFAmJiBmNhbGxlcgUBaQkAZAIFAmJ1BQJicQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAUYDBQF6CAUCYmIGY2FsbGVyBQFpBQJiQQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAUgCBQF6BQFpCQBkAgUCYncFAmJxCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBTgEFAWkJAGQCBQJieAUCYnEFA25pbAUCYkQFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYmIBCmNhbmNlbFZvdGUCAUIBQwQBegkAlAoCBQFCBQFDBAFpCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFAWoAAAQCYnIJAQJhYwIFBHRoaXMJAQF3AQUBaQQCYmwJAQJhYwIFBHRoaXMFAWYEAmJzCQBkAgUCYnIFAmJsBAJidAkAmggCBQR0aGlzBQFwBAJidQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEBRAIIBQJiYgZjYWxsZXIFAWkAAAQCYnYJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBAUYDBQF6CAUCYmIGY2FsbGVyBQFpAAAEAmJ3CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQFIAgUBegUBaQAABAJieAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEBTgEFAWkAAAQCYm0JAMwIAgMJAQIhPQIJAKAIAQkBAXkBBQF6BQR1bml0BgkBAVMBAg5pbnZhbGlkIGFzc2V0cwkAzAgCAwkAZgIFAmJzBQZoZWlnaHQGCQEBUwECDmludmFsaWQgaGVpZ2h0CQDMCAIDCQAAAgUCYnQFBHVuaXQGCQEBUwECGGZpbmFsaXphdGlvbiBpbiBwcm9ncmVzcwkAzAgCAwkAZgIFAmJ2AAAGCQEBUwECB25vIHZvdGUFA25pbAMJAAACBQJibQUCYm0EAmJDCQECYUQBBQF6BAFQCQClCAEIBQJiYgZjYWxsZXIJAJQKAgkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBRAIIBQJiYgZjYWxsZXIFAWkJAJYDAQkAzAgCCQBlAgUCYnUFAmJ2CQDMCAIAAAUDbmlsCQDMCAIJAQtEZWxldGVFbnRyeQEJAQFGAwUBeggFAmJiBmNhbGxlcgUBaQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAUgCBQF6BQFpCQBlAgUCYncFAmJ2CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBTgEFAWkJAGUCBQJieAUCYnYFA25pbAkBAmFUAgUCYkMFAVAFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYmIBDnNldEVwb2NoTGVuZ3RoAQJiRQQCYm0JAMwIAgkBAmJkAQUCYmIJAMwIAgMJAGYCBQJiRQAABgkBAVMBAhRpbnZhbGlkIGVwb2NoIGxlbmd0aAUDbmlsAwkAAAIFAmJtBQJibQkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQFnBQJiRQUDbmlsBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJiAQtzZXRNYXhEZXB0aAECYkYEAmJtCQDMCAIJAQJiZAEFAmJiCQDMCAIDCQBmAgUCYkYAAAYJAQFTAQIRaW52YWxpZCBtYXggZGVwdGgFA25pbAMJAAACBQJibQUCYm0JAJQKAgkAzAgCCQEMSW50ZWdlckVudHJ5AgUBawUCYkYFA25pbAUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJiYgETcHJvY2Vzc1ZvdGVJTlRFUk5BTAICYkcBUAQCYkgJAQJiZQEFAmJiAwkAAAIFAmJIBQJiSAQCYmYJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBBQFQCQEBUQEJAKwCAgIqcHJvY2Vzc1ZvdGVJTlRFUk5BTDogaW52YWxpZCB1c2VyIGFkZHJlc3MgBQFQBAFpCQECYWMCBQR0aGlzBQFqBAJiSQkAZQIFAWkAAQQCYmwJAQJhYwIFBHRoaXMFAWYEAmJyCQECYWMCBQR0aGlzCQEBdwEFAWkEAmJzCQBkAgUCYnIFAmJsBAJiSgkBAmFjAgUEdGhpcwkBAXcBBQJiSQQCYksJAQJhYwIFBHRoaXMJAQFoAQUCYkkEAmJMCQBkAgUCYkoFAmJLBAJiTQMJAGcCBQJiSQAABgkBAVMBAitwcm9jZXNzVm90ZUlOVEVSTkFMOiBpbnZhbGlkIHByZXZpb3VzIGVwb2NoAwkAAAIFAmJNBQJiTQQBegkBAmFlAQUCYkcEAmJOBQF6BAFCCAUCYk4CXzEEAUMIBQJiTgJfMgQCYkIJAQJheQEFAXoEAmJ5CgACYWIJAPwHBAUEdGhpcwIYZ2V0VXNlckd3eEFtb3VudEF0SGVpZ2h0CQDMCAIFAVAJAMwIAgUCYnMFA25pbAUDbmlsAwkAAQIFAmFiAgNJbnQFAmFiCQACAQkArAICCQADAQUCYWICGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAQCYk8KAAJhYgkA/AcEBQR0aGlzAhhnZXRVc2VyR3d4QW1vdW50QXRIZWlnaHQJAMwIAgUBUAkAzAgCBQJiTAUDbmlsBQNuaWwDCQABAgUCYWICA0ludAUCYWIJAAIBCQCsAgIJAAMBBQJhYgIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50BAJieAkBC3ZhbHVlT3JFbHNlAgkAnwgBCQEBTgEFAWkAAAQCYlAJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBAUgCBQF6BQFpAAAEAmJRCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ8IAQkBAUYDBQF6BQJiZgUCYkkJAQFRAQkArAICCQCsAgIJAKwCAgkArAICAhRwcm9jZXNzVm90ZUlOVEVSTkFMIAUCYkcCASAFAVACEjogbm8gcHJldmlvdXMgdm90ZQQCYnUJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBAUQCBQJiZgUBaQAABAFLCQECYW4CBQFCBQFDBAJiUgkBC3ZhbHVlT3JFbHNlAgkAnwgBCQEBSgIFAUsFAmJJAAAEAmJrCQERQGV4dHJOYXRpdmUoMTA2MikBCQECYWECBQR0aGlzBQFvBAJiUwkBC3ZhbHVlT3JFbHNlAgkAmggCBQJiawkBAU8CBQFLBQFQAAAEAmJUAwkAAAIFAmJTAAAFA25pbAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAUoCBQFLBQJiSQkAZAIFAmJSBQJiUQUDbmlsBAJiQQMJAGYCBQJiTwAACQBrAwUCYlEFAmJ5BQJiTwAABAJiVQMDCQBmAgUCYkEAAAUCYkIHCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBRgMFAXoFAmJmBQFpBQJiQQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAU4BBQFpCQBkAgUCYngFAmJBCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBSAIFAXoFAWkJAGQCBQJiUAUCYkEJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFEAgUCYmYFAWkJAGQCBQJidQUCYkEFA25pbAkBAmFUAgkBAmFEAQUBegUBUAkAlAoCCQDOCAIFAmJVBQJiVAUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJiYgETcHJvY2Vzc1Bvb2xJTlRFUk5BTAICYkcCYlYEAmJICQECYmUBBQJiYgMJAAACBQJiSAUCYkgEAmJXBAJiWAkBAmFjAgUEdGhpcwUBagMFAmJWBQJiWAkAZQIFAmJYAAEEAmJNAwkAZwIFAmJXAAAGCQEBUwECKXByb2Nlc3NQb29sSU5URVJOQUw6IGludmFsaWQgdGFyZ2V0IGVwb2NoAwkAAAIFAmJNBQJiTQQBegkBAmFlAQUCYkcEAmJZBQF6BAFCCAUCYlkCXzEEAUMIBQJiWQJfMgQCYmsJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQJhYQIFBHRoaXMFAW8EAmF4CQECYW4CBQFCBQFDBAJiWgoAAmFiCQD8BwQFAmJrAhJ1c2Vyc0xpc3RUcmF2ZXJzYWwJAMwIAgUCYXgFA25pbAUDbmlsAwkAAQIFAmFiAgdCb29sZWFuBQJhYgkAAgEJAKwCAgkAAwEFAmFiAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuAwkAAAIFAmJaBQJiWgMFAmJaCQCUCgIFA25pbAYEAmJCCQECYXkBBQF6BAJieAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEBTgEFAmJXAAAEAmJQCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQFIAgUBegUCYlcAAAQCY2EDAwkAAAIFAmJ4AAAGCQEBIQEFAmJCAAAJAGsDBQJiUAUBYgUCYngEAmNiCQD8BwQFAmFnAgxtb2RpZnlXZWlnaHQJAMwIAgUCYXgJAMwIAgUCY2EFA25pbAUDbmlsAwkAAAIFAmNiBQJjYgQCY2MDAwUCYkIGBQJiVgUDbmlsCQDOCAIJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAXkBBQF6BQNuaWwJAQJhVAIFAmFDBQJiRwkAlAoCCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFMAgUBegUCYlcFAmNhBQNuaWwFAmNjBwkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJiYgEOZmluYWxpemVIZWxwZXIABAJiVgkBC3ZhbHVlT3JFbHNlAgkAoAgBBQF2BwQBaQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQFqAAAEAmNkCQBlAgUBaQABBAJicgkBAmFjAgUEdGhpcwkBAXcBBQFpBAJibAkBAmFjAgUEdGhpcwUBZgQCYnMJAGQCBQJicgUCYmwEAmJ0CQCaCAIFBHRoaXMFAXADAwMJAGcCBQZoZWlnaHQFAmJzCQAAAgUCYnQFBHVuaXQHCQEBIQEFAmJWBwQCY2UJAGQCBQFpAAEEAmNmCQCaCAIFBHRoaXMFAWcEAmNnBAFYBQJjZgMJAAECBQFYAgNJbnQEAmJFBQFYCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQFmBQJiRQkAzAgCCQELRGVsZXRlRW50cnkBBQFnBQNuaWwDCQABAgUBWAIEVW5pdAUDbmlsCQACAQILTWF0Y2ggZXJyb3IJAJQKAgkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBdwEFAmNlBQZoZWlnaHQJAMwIAgkBDEludGVnZXJFbnRyeQIFAXMFBmhlaWdodAkAzAgCCQEMSW50ZWdlckVudHJ5AgUBagUCY2UJAMwIAgkBDEludGVnZXJFbnRyeQIFAXAFAWQJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFoAQUBaQUCYmwFA25pbAUCY2cGAwMFAmJWCQAAAgUCYnQFBHVuaXQHCQCUCgIJAMwIAgkBDEludGVnZXJFbnRyeQIFAXAFAWUFA25pbAYDCQAAAgUCYnQFBHVuaXQJAJQKAgUDbmlsBwMJAAACBQJidAUBZAQCY2gJAKIIAQUBcQQCY2kJAKIIAQUBcgQBWAUCY2gDCQABAgUBWAIEVW5pdAQCY2oJAKIIAQkBAmFGAQUCYUMDCQABAgUCY2oCBFVuaXQJAJQKAgkAzAgCCQEMSW50ZWdlckVudHJ5AgUBcAUBZQkAzAgCCQELRGVsZXRlRW50cnkBBQFxCQDMCAIJAQtEZWxldGVFbnRyeQEFAXIFA25pbAYDCQABAgUCY2oCBlN0cmluZwQCY2sFAmNqCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgUBcQUCY2sFA25pbAYJAAIBAgtNYXRjaCBlcnJvcgMJAAECBQFYAgZTdHJpbmcEAmJHBQFYBAF6CQECYWUBBQJiRwQCY2wEAmNqBQJjaQMJAAECBQJjagIEVW5pdAkAoggBCQECYUYBCQECYUQBBQF6AwkAAQIFAmNqAgZTdHJpbmcEAmNtBQJjagQCY24JAKIIAQkBAmFMAgkBAmFEAQUBegUCY20DCQAAAgUCY24FAmNuBAJjbwkA/AcEBQR0aGlzAhNwcm9jZXNzVm90ZUlOVEVSTkFMCQDMCAIFAmJHCQDMCAIFAmNtBQNuaWwFA25pbAMJAAACBQJjbwUCY28FAmNuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQILTWF0Y2ggZXJyb3IEAmNqBQJjbAMJAAECBQJjagIEVW5pdAQCY3AJAKIIAQkBAmFMAgUCYUMFAmJHBAJjcQUCY3ADCQABAgUCY3ECBFVuaXQJAJQKAgkAzAgCCQEMSW50ZWdlckVudHJ5AgUBcAUBZQkAzAgCCQELRGVsZXRlRW50cnkBBQFxCQDMCAIJAQtEZWxldGVFbnRyeQEFAXIFA25pbAYDCQABAgUCY3ECBlN0cmluZwQCYVgFAmNxCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgUBcQUCYVgJAMwIAgkBC0RlbGV0ZUVudHJ5AQUBcgUDbmlsBgkAAgECC01hdGNoIGVycm9yAwkAAQIFAmNqAgZTdHJpbmcEAmNyBQJjagkAlAoCCQDMCAIJAQtTdHJpbmdFbnRyeQIFAXIFAmNyBQNuaWwGCQACAQILTWF0Y2ggZXJyb3IJAAIBAgtNYXRjaCBlcnJvcgMJAAACBQJidAUBZQQCY2gJAKIIAQUBcQQBWAUCY2gDCQABAgUBWAIEVW5pdAQCY2oJAKIIAQkBAmFGAQUCYUMDCQABAgUCY2oCBFVuaXQEAmJVAwUCYlYJAMwIAgkBC0RlbGV0ZUVudHJ5AQUBcAkAzAgCCQELRGVsZXRlRW50cnkBBQF2BQNuaWwJAMwIAgkBC0RlbGV0ZUVudHJ5AQUBcAkAzAgCCQEMQm9vbGVhbkVudHJ5AgkBAXgBBQJjZAYJAMwIAgkBDEludGVnZXJFbnRyeQIFAXQFAWkJAMwIAgkBDEludGVnZXJFbnRyeQIFAXUFAmJyBQNuaWwEAmNzCQECYUEAAwkAAAIFAmNzBQJjcwkAlAoCBQJiVQYJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DCQABAgUCY2oCBlN0cmluZwQCY3QFAmNqCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgUBcQUCY3QFA25pbAYJAAIBAgtNYXRjaCBlcnJvcgMJAAECBQFYAgZTdHJpbmcEAmJHBQFYBAJjcAkAoggBCQECYUwCBQJhQwUCYkcDCQAAAgUCY3AFAmNwBAJiWgoAAmFiCQD8BwQFBHRoaXMCE3Byb2Nlc3NQb29sSU5URVJOQUwJAMwIAgUCYkcJAMwIAgUCYlYFA25pbAUDbmlsAwkAAQIFAmFiAgdCb29sZWFuBQJhYgkAAgEJAKwCAgkAAwEFAmFiAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuAwkAAAIFAmJaBQJiWgMFAmJaCQCUCgIFA25pbAYEAmNqBQJjcAMJAAECBQJjagIEVW5pdAQCYlUDBQJiVgkAzAgCCQELRGVsZXRlRW50cnkBBQFwCQDMCAIJAQtEZWxldGVFbnRyeQEFAXYJAMwIAgkBC0RlbGV0ZUVudHJ5AQUBcQUDbmlsCQDMCAIJAQtEZWxldGVFbnRyeQEFAXAJAMwIAgkBDEJvb2xlYW5FbnRyeQIJAQF4AQUCY2QGCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQF0BQFpCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQF1BQJicgkAzAgCCQELRGVsZXRlRW50cnkBBQFxBQNuaWwEAmNzCQECYUEAAwkAAAIFAmNzBQJjcwkAlAoCBQJiVQYJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DCQABAgUCY2oCBlN0cmluZwQCY3QFAmNqCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgUBcQUCY3QFA25pbAYJAAIBAgtNYXRjaCBlcnJvcgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECC01hdGNoIGVycm9yCQEBUwECFmZpbmFsaXphdGlvbiBpcyBicm9rZW4CYmIBD2ZpbmFsaXplV3JhcHBlcgECY3UEAmN2CgACYWIJAPwHBAUEdGhpcwIOZmluYWxpemVIZWxwZXIFA25pbAUDbmlsAwkAAQIFAmFiAgdCb29sZWFuBQJhYgkAAgEJAKwCAgkAAwEFAmFiAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuAwkAAAIFAmN2BQJjdgMJAQEhAQUCY3YDCQAAAgUCY3UAAAkBAVMBAh5DdXJyZW50IHZvdGluZyBpcyBub3Qgb3ZlciB5ZXQJAJQKAgUDbmlsBQR1bml0BAJjdwkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQFrBQFjAwkAZgIFAmN3BQJjdQQCY3gJAPwHBAUEdGhpcwIPZmluYWxpemVXcmFwcGVyCQDMCAIJAGQCBQJjdQABBQNuaWwFA25pbAMJAAACBQJjeAUCY3gJAJQKAgUDbmlsBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQCUCgIFA25pbAUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJiYgEIZmluYWxpemUABAJjeAkA/AcEBQR0aGlzAg9maW5hbGl6ZVdyYXBwZXIJAMwIAgAABQNuaWwFA25pbAMJAAACBQJjeAUCY3gJAJQKAgUDbmlsBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJiARRjb250YWluc05vZGVSRUFET05MWQICYUcCYUsJAJQKAgUDbmlsCQECYU0CBQJhRwUCYUsCYmIBCmluc2VydE5vZGUCAmFHAmFLBAJiSAkBAmJkAQUCYmIDCQAAAgUCYkgFAmJICQCUCgIJAQJhUQIFAmFHBQJhSwUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJiYgEKZGVsZXRlTm9kZQICYUcCYUsEAmJICQECYmQBBQJiYgMJAAACBQJiSAUCYkgJAJQKAgkBAmFUAgUCYUcFAmFLBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJjeQECY3oABAJjQQQBWAkBAmFZAAMJAAECBQFYAgpCeXRlVmVjdG9yBAJiYwUBWAUCYmMDCQABAgUBWAIEVW5pdAgFAmN5D3NlbmRlclB1YmxpY0tleQkAAgECC01hdGNoIGVycm9yCQD0AwMIBQJjeQlib2R5Qnl0ZXMJAJEDAggFAmN5BnByb29mcwAABQJjQX6PrfM=", "height": 2584885, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: AvWs3riEyaiksSpfXbSPf7KrQHhacfsxUpmXji25PZN1 Next: 7KYQJz6bNGU2KQkhS5iu73VCFofNkvPeBrLrqr3JrhF4 Diff:
OldNewDifferences
140140 }
141141
142142
143+let factoryContract = addressFromStringValue(getStrOrFail(this, keyFactoryContract))
144+
145+let IdxFactoryCfgGwxRewardDapp = 10
146+
147+func keyFactoryCfg () = "%s__factoryConfig"
148+
149+
150+func readFactoryCfgOrFail (factory) = split(getStrOrFail(factory, keyFactoryCfg()), separator)
151+
152+
153+func getGwxRewardAddressOrFail (factoryCfg) = addressFromStringValue(factoryCfg[IdxFactoryCfgGwxRewardDapp])
154+
155+
143156 func getLpAssetByPoolAssets (amountAssetId,priceAssetId) = {
144157 func keyMappingsBaseAsset2internalId (baseAssetStr) = ("%s%s%s__mappings__baseAsset2internalId__" + baseAssetStr)
145158
147160
148161 func keyMappingPoolContractToLPAsset (poolContractAddress) = (("%s%s%s__" + poolContractAddress) + "__mappings__poolContract2LpAsset")
149162
150- let factoryContract = addressFromStringValue(getStrOrFail(this, keyFactoryContract))
151163 let amountAssetInternalId = getIntOrFail(factoryContract, keyMappingsBaseAsset2internalId(amountAssetId))
152164 let priceAssetInternalId = getIntOrFail(factoryContract, keyMappingsBaseAsset2internalId(priceAssetId))
153165 let poolContractAddress = getStrOrFail(factoryContract, keyMappingPoolAssetsToPoolContractAddress(amountAssetInternalId, priceAssetInternalId))
157169
158170
159171 func checkWxEmissionPoolLabel (pool) = {
160- let $t051685208 = pool
161- let amountAssetId = $t051685208._1
162- let priceAssetId = $t051685208._2
163- let factoryContract = addressFromStringValue(getStrOrFail(this, keyFactoryContract))
172+ let $t054705510 = pool
173+ let amountAssetId = $t054705510._1
174+ let priceAssetId = $t054705510._2
164175 let @ = invoke(factoryContract, "checkWxEmissionPoolLabel", [amountAssetId, priceAssetId], nil)
165176 if ($isInstanceOf(@, "Boolean"))
166177 then @
168179 }
169180
170181
182+func gwxRewardDeposit () = {
183+ let factoryCfg = readFactoryCfgOrFail(factoryContract)
184+ let gwxRewardsContract = getGwxRewardAddressOrFail(factoryCfg)
185+ invoke(gwxRewardsContract, "deposit", nil, nil)
186+ }
187+
188+
171189 let poolsListName = "pools"
172190
173191 func getVotesListName (pool) = {
174- let $t055095549 = pool
175- let amountAssetId = $t055095549._1
176- let priceAssetId = $t055095549._2
192+ let $t059275967 = pool
193+ let amountAssetId = $t059275967._1
194+ let priceAssetId = $t059275967._2
177195 makeString(["votes", amountAssetId, priceAssetId], separator)
178196 }
179197
484502 if ((checkTargetEpoch == checkTargetEpoch))
485503 then {
486504 let pool = stringToPool(poolStr)
487- let $t01755217592 = pool
488- let amountAssetId = $t01755217592._1
489- let priceAssetId = $t01755217592._2
505+ let $t01797018010 = pool
506+ let amountAssetId = $t01797018010._1
507+ let priceAssetId = $t01797018010._2
490508 let wxEmission = checkWxEmissionPoolLabel(pool)
491509 let gwxAmountAtEndTotal = {
492510 let @ = invoke(this, "getUserGwxAmountAtHeight", [userAddressStr, endHeight], nil)
545563 if ((checkTargetEpoch == checkTargetEpoch))
546564 then {
547565 let pool = stringToPool(poolStr)
548- let $t01994919989 = pool
549- let amountAssetId = $t01994919989._1
550- let priceAssetId = $t01994919989._2
566+ let $t02036720407 = pool
567+ let amountAssetId = $t02036720407._1
568+ let priceAssetId = $t02036720407._2
551569 let stakingContract = addressFromStringValue(getStrOrFail(this, keyStakingContract))
552- let factoryContract = addressFromStringValue(getStrOrFail(this, keyFactoryContract))
553570 let lpAssetId = getLpAssetByPoolAssets(amountAssetId, priceAssetId)
554571 let r = {
555572 let @ = invoke(stakingContract, "usersListTraversal", [lpAssetId], nil)
685702 let actions = if (force)
686703 then [DeleteEntry(keyFinalizationStage), DeleteEntry(keyFinalizationShouldBeForced)]
687704 else [DeleteEntry(keyFinalizationStage), BooleanEntry(keyFinalized(previousEpoch), true), IntegerEntry(keyCurrentEpochUi, epoch), IntegerEntry(keyStartHeightUi, startHeight)]
688- $Tuple2(actions, true)
705+ let gwxRewardDepositInv = gwxRewardDeposit()
706+ if ((gwxRewardDepositInv == gwxRewardDepositInv))
707+ then $Tuple2(actions, true)
708+ else throw("Strict value is not equal to itself.")
689709 case nextPoolStr: String =>
690710 $Tuple2([StringEntry(keyNextPool, nextPoolStr)], true)
691711 case _ =>
709729 let actions = if (force)
710730 then [DeleteEntry(keyFinalizationStage), DeleteEntry(keyFinalizationShouldBeForced), DeleteEntry(keyNextPool)]
711731 else [DeleteEntry(keyFinalizationStage), BooleanEntry(keyFinalized(previousEpoch), true), IntegerEntry(keyCurrentEpochUi, epoch), IntegerEntry(keyStartHeightUi, startHeight), DeleteEntry(keyNextPool)]
712- $Tuple2(actions, true)
732+ let gwxRewardDepositInv = gwxRewardDeposit()
733+ if ((gwxRewardDepositInv == gwxRewardDepositInv))
734+ then $Tuple2(actions, true)
735+ else throw("Strict value is not equal to itself.")
713736 case nextPoolStr: String =>
714737 $Tuple2([StringEntry(keyNextPool, nextPoolStr)], true)
715738 case _ =>
790813 }
791814
792815
793-
794-@Callable(i)
795-func isFinalizationInProgress () = {
796- let finalizationStageOrUnit = getInteger(this, keyFinalizationStage)
797- let finalizationInProgress = (finalizationStageOrUnit != unit)
798- $Tuple2(nil, finalizationInProgress)
799- }
800-
801-
802816 @Verifier(tx)
803817 func verify () = {
804818 let targetPublicKey = match managerPublicKeyOrUnit() {
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) = {
104104 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 _ =>
111111 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])
139139 else throwErr("invalid pool string")
140140 }
141141
142142
143+let factoryContract = addressFromStringValue(getStrOrFail(this, keyFactoryContract))
144+
145+let IdxFactoryCfgGwxRewardDapp = 10
146+
147+func keyFactoryCfg () = "%s__factoryConfig"
148+
149+
150+func readFactoryCfgOrFail (factory) = split(getStrOrFail(factory, keyFactoryCfg()), separator)
151+
152+
153+func getGwxRewardAddressOrFail (factoryCfg) = addressFromStringValue(factoryCfg[IdxFactoryCfgGwxRewardDapp])
154+
155+
143156 func getLpAssetByPoolAssets (amountAssetId,priceAssetId) = {
144157 func keyMappingsBaseAsset2internalId (baseAssetStr) = ("%s%s%s__mappings__baseAsset2internalId__" + baseAssetStr)
145158
146159 func keyMappingPoolAssetsToPoolContractAddress (internalAmountAssetIdStr,internalPriceAssetIdStr) = (((("%d%d%s%s__" + toString(internalAmountAssetIdStr)) + "__") + toString(internalPriceAssetIdStr)) + "__mappings__poolAssets2PoolContract")
147160
148161 func keyMappingPoolContractToLPAsset (poolContractAddress) = (("%s%s%s__" + poolContractAddress) + "__mappings__poolContract2LpAsset")
149162
150- let factoryContract = addressFromStringValue(getStrOrFail(this, keyFactoryContract))
151163 let amountAssetInternalId = getIntOrFail(factoryContract, keyMappingsBaseAsset2internalId(amountAssetId))
152164 let priceAssetInternalId = getIntOrFail(factoryContract, keyMappingsBaseAsset2internalId(priceAssetId))
153165 let poolContractAddress = getStrOrFail(factoryContract, keyMappingPoolAssetsToPoolContractAddress(amountAssetInternalId, priceAssetInternalId))
154166 let lpAssetId = getStrOrFail(factoryContract, keyMappingPoolContractToLPAsset(poolContractAddress))
155167 lpAssetId
156168 }
157169
158170
159171 func checkWxEmissionPoolLabel (pool) = {
160- let $t051685208 = pool
161- let amountAssetId = $t051685208._1
162- let priceAssetId = $t051685208._2
163- let factoryContract = addressFromStringValue(getStrOrFail(this, keyFactoryContract))
172+ let $t054705510 = pool
173+ let amountAssetId = $t054705510._1
174+ let priceAssetId = $t054705510._2
164175 let @ = invoke(factoryContract, "checkWxEmissionPoolLabel", [amountAssetId, priceAssetId], nil)
165176 if ($isInstanceOf(@, "Boolean"))
166177 then @
167178 else throw(($getType(@) + " couldn't be cast to Boolean"))
168179 }
169180
170181
182+func gwxRewardDeposit () = {
183+ let factoryCfg = readFactoryCfgOrFail(factoryContract)
184+ let gwxRewardsContract = getGwxRewardAddressOrFail(factoryCfg)
185+ invoke(gwxRewardsContract, "deposit", nil, nil)
186+ }
187+
188+
171189 let poolsListName = "pools"
172190
173191 func getVotesListName (pool) = {
174- let $t055095549 = pool
175- let amountAssetId = $t055095549._1
176- let priceAssetId = $t055095549._2
192+ let $t059275967 = pool
193+ let amountAssetId = $t059275967._1
194+ let priceAssetId = $t059275967._2
177195 makeString(["votes", amountAssetId, priceAssetId], separator)
178196 }
179197
180198
181199 func keyListHead (listName) = {
182200 let meta = if ((listName == poolsListName))
183201 then "%s%s"
184202 else "%s%s%s%s"
185203 makeString([meta, listName, "head"], separator)
186204 }
187205
188206
189207 func keyListSize (listName) = {
190208 let meta = if ((listName == poolsListName))
191209 then "%s%s"
192210 else "%s%s%s%s"
193211 makeString([meta, listName, "size"], separator)
194212 }
195213
196214
197215 func keyListPrev (listName,id) = {
198216 let meta = if ((listName == poolsListName))
199217 then "%s%s%s%s"
200218 else "%s%s%s%s%s"
201219 makeString([meta, listName, id, "prev"], separator)
202220 }
203221
204222
205223 func keyListNext (listName,id) = {
206224 let meta = if ((listName == poolsListName))
207225 then "%s%s%s%s"
208226 else "%s%s%s%s%s"
209227 makeString([meta, listName, id, "next"], separator)
210228 }
211229
212230
213231 func containsNode (listName,id) = {
214232 let headOrUnit = getString(this, keyListHead(listName))
215233 let prevOrUnit = getString(this, keyListPrev(listName, id))
216234 let nextOrUnit = getString(this, keyListNext(listName, id))
217235 if (if ((id == valueOrElse(headOrUnit, "")))
218236 then true
219237 else (prevOrUnit != unit))
220238 then true
221239 else (nextOrUnit != unit)
222240 }
223241
224242
225243 func insertNodeActions (listName,id) = {
226244 let headOrUnit = getString(this, keyListHead(listName))
227245 let listSize = valueOrElse(getInteger(this, keyListSize(listName)), 0)
228246 let checkNode = if (!(containsNode(listName, id)))
229247 then true
230248 else throwErr("Node exists")
231249 if ((checkNode == checkNode))
232250 then (([IntegerEntry(keyListSize(listName), (listSize + 1))] ++ (if ((headOrUnit != unit))
233251 then [StringEntry(keyListNext(listName, id), value(headOrUnit)), StringEntry(keyListPrev(listName, value(headOrUnit)), id)]
234252 else nil)) ++ [StringEntry(keyListHead(listName), id)])
235253 else throw("Strict value is not equal to itself.")
236254 }
237255
238256
239257 func deleteNodeActions (listName,id) = {
240258 let headOrUnit = getString(this, keyListHead(listName))
241259 let listSize = valueOrElse(getInteger(this, keyListSize(listName)), 0)
242260 let prevOrUnit = getString(this, keyListPrev(listName, id))
243261 let nextOrUnit = getString(this, keyListNext(listName, id))
244262 ([IntegerEntry(keyListSize(listName), (listSize - 1))] ++ (if (if ((prevOrUnit != unit))
245263 then (nextOrUnit != unit)
246264 else false)
247265 then [StringEntry(keyListNext(listName, value(prevOrUnit)), value(nextOrUnit)), StringEntry(keyListPrev(listName, value(nextOrUnit)), value(prevOrUnit)), DeleteEntry(keyListPrev(listName, id)), DeleteEntry(keyListNext(listName, id))]
248266 else if ((nextOrUnit != unit))
249267 then [StringEntry(keyListHead(listName), value(nextOrUnit)), DeleteEntry(keyListNext(listName, id)), DeleteEntry(keyListPrev(listName, value(nextOrUnit)))]
250268 else if ((prevOrUnit != unit))
251269 then [DeleteEntry(keyListPrev(listName, id)), DeleteEntry(keyListNext(listName, value(prevOrUnit)))]
252270 else if ((id == valueOrElse(headOrUnit, "")))
253271 then [DeleteEntry(keyListHead(listName))]
254272 else throwErr(((("invalid node: " + listName) + ".") + id))))
255273 }
256274
257275
258276 func keyManagerVaultAddress () = "%s__managerVaultAddress"
259277
260278
261279 func keyManagerPublicKey () = "%s__managerPublicKey"
262280
263281
264282 func getManagerVaultAddressOrThis () = match getString(keyManagerVaultAddress()) {
265283 case s: String =>
266284 addressFromStringValue(s)
267285 case _ =>
268286 this
269287 }
270288
271289
272290 func managerPublicKeyOrUnit () = {
273291 let managerVaultAddress = getManagerVaultAddressOrThis()
274292 match getString(managerVaultAddress, keyManagerPublicKey()) {
275293 case s: String =>
276294 fromBase58String(s)
277295 case _: Unit =>
278296 unit
279297 case _ =>
280298 throw("Match error")
281299 }
282300 }
283301
284302
285303 func isManager (i) = match managerPublicKeyOrUnit() {
286304 case pk: ByteVector =>
287305 (i.callerPublicKey == pk)
288306 case _: Unit =>
289307 (i.caller == this)
290308 case _ =>
291309 throw("Match error")
292310 }
293311
294312
295313 func mustManager (i) = if (isManager(i))
296314 then true
297315 else throw("permission denied")
298316
299317
300318 func mustThis (i) = if ((i.caller == this))
301319 then true
302320 else throw("permission denied")
303321
304322
305323 @Callable(i)
306324 func getUserGwxAmountAtHeight (userAddress,targetHeight) = {
307325 let boostingContractAddress = valueOrErrorMessage(addressFromString(getStrOrFail(this, keyBoostingContract)), wrapErr("invalid boosting contract address"))
308326 $Tuple2(nil, {
309327 let @ = invoke(boostingContractAddress, "getUserGwxAmountAtHeightREADONLY", [userAddress, targetHeight], nil)
310328 if ($isInstanceOf(@, "Int"))
311329 then @
312330 else throw(($getType(@) + " couldn't be cast to Int"))
313331 })
314332 }
315333
316334
317335
318336 @Callable(i)
319337 func constructor (factoryContract,votingEmissionCandidateContract,boostingContract,stakingContract,epochLength) = {
320338 let checks = [mustManager(i), if ((addressFromString(factoryContract) != unit))
321339 then true
322340 else "invalid factory contract address", if ((addressFromString(votingEmissionCandidateContract) != unit))
323341 then true
324342 else "invalid voting emission candidate contract address", if ((addressFromString(boostingContract) != unit))
325343 then true
326344 else "invalid boosting contract address", if ((addressFromString(stakingContract) != unit))
327345 then true
328346 else "invalid staking contract address", if ((epochLength > 0))
329347 then true
330348 else throwErr("invalid epoch length")]
331349 if ((checks == checks))
332350 then $Tuple2([StringEntry(keyFactoryContract, factoryContract), StringEntry(keyVotingEmissionCandidateContract, votingEmissionCandidateContract), StringEntry(keyBoostingContract, boostingContract), StringEntry(keyStakingContract, stakingContract), IntegerEntry(keyEpochLength, epochLength)], unit)
333351 else throw("Strict value is not equal to itself.")
334352 }
335353
336354
337355
338356 @Callable(i)
339357 func create (amountAssetId,priceAssetId) = {
340358 let checks = [if ((toBase58String(i.caller.bytes) == valueOrElse(getString(this, keyVotingEmissionCandidateContract), "")))
341359 then true
342360 else mustManager(i)]
343361 if ((checks == checks))
344362 then {
345363 let pool = $Tuple2(amountAssetId, priceAssetId)
346364 let inListActions = ([BooleanEntry(keyInList(pool), true)] ++ insertNodeActions(poolsListName, poolToString(pool)))
347365 let currentEpochIsNotDefined = (getInteger(this, keyCurrentEpoch) == unit)
348366 let startHeightActions = if (currentEpochIsNotDefined)
349367 then {
350368 let epoch = 0
351369 [IntegerEntry(keyCurrentEpoch, epoch), IntegerEntry(keyStartHeightByEpoch(epoch), height), IntegerEntry(keyStartHeight, height), IntegerEntry(keyCurrentEpochUi, epoch), IntegerEntry(keyStartHeightUi, height)]
352370 }
353371 else nil
354372 $Tuple2((inListActions ++ startHeightActions), unit)
355373 }
356374 else throw("Strict value is not equal to itself.")
357375 }
358376
359377
360378
361379 @Callable(i)
362380 func vote (amountAssetId,priceAssetId,amount) = {
363381 let pool = $Tuple2(amountAssetId, priceAssetId)
364382 let epoch = valueOrElse(getInteger(this, keyCurrentEpoch), 0)
365383 let startHeight = getIntOrFail(this, keyStartHeightByEpoch(epoch))
366384 let epochLength = getIntOrFail(this, keyEpochLength)
367385 let endHeight = (startHeight + epochLength)
368386 let finalizationStageOrUnit = getInteger(this, keyFinalizationStage)
369387 let used = valueOrElse(getInteger(this, keyUsed(i.caller, epoch)), 0)
370388 let vote = valueOrElse(getInteger(this, keyVote(pool, i.caller, epoch)), 0)
371389 let poolResult = valueOrElse(getInteger(this, keyVotingResult(pool, epoch)), 0)
372390 let totalVotes = valueOrElse(getInteger(this, keyTotalVotes(epoch)), 0)
373391 let gwxAmountAtEndTotal = {
374392 let @ = invoke(this, "getUserGwxAmountAtHeight", [toBase58String(i.caller.bytes), endHeight], nil)
375393 if ($isInstanceOf(@, "Int"))
376394 then @
377395 else throw(($getType(@) + " couldn't be cast to Int"))
378396 }
379397 let available = (gwxAmountAtEndTotal - used)
380398 let newVote = (vote + amount)
381399 let wxEmission = checkWxEmissionPoolLabel(pool)
382400 let checks = [if ((getBoolean(keyInList(pool)) != unit))
383401 then true
384402 else throwErr("invalid assets"), if ((endHeight > height))
385403 then true
386404 else throwErr("invalid height"), if ((finalizationStageOrUnit == unit))
387405 then true
388406 else throwErr("finalization in progress"), if ((gwxAmountAtEndTotal > 0))
389407 then true
390408 else throwErr("you do not have gWX"), if (if ((amount > 0))
391409 then (available >= amount)
392410 else false)
393411 then true
394412 else throwErr("invalid amount"), if (wxEmission)
395413 then true
396414 else throwErr("pool hasn't WX_EMISSION label")]
397415 if ((checks == checks))
398416 then {
399417 let votesListName = getVotesListName(pool)
400418 let userAddressStr = toString(i.caller)
401419 let votesListActions = if (containsNode(votesListName, userAddressStr))
402420 then nil
403421 else insertNodeActions(votesListName, userAddressStr)
404422 $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)
405423 }
406424 else throw("Strict value is not equal to itself.")
407425 }
408426
409427
410428
411429 @Callable(i)
412430 func cancelVote (amountAssetId,priceAssetId) = {
413431 let pool = $Tuple2(amountAssetId, priceAssetId)
414432 let epoch = valueOrElse(getInteger(this, keyCurrentEpoch), 0)
415433 let startHeight = getIntOrFail(this, keyStartHeightByEpoch(epoch))
416434 let epochLength = getIntOrFail(this, keyEpochLength)
417435 let endHeight = (startHeight + epochLength)
418436 let finalizationStageOrUnit = getInteger(this, keyFinalizationStage)
419437 let used = valueOrElse(getInteger(this, keyUsed(i.caller, epoch)), 0)
420438 let vote = valueOrElse(getInteger(this, keyVote(pool, i.caller, epoch)), 0)
421439 let poolResult = valueOrElse(getInteger(this, keyVotingResult(pool, epoch)), 0)
422440 let totalVotes = valueOrElse(getInteger(this, keyTotalVotes(epoch)), 0)
423441 let checks = [if ((getBoolean(keyInList(pool)) != unit))
424442 then true
425443 else throwErr("invalid assets"), if ((endHeight > height))
426444 then true
427445 else throwErr("invalid height"), if ((finalizationStageOrUnit == unit))
428446 then true
429447 else throwErr("finalization in progress"), if ((vote > 0))
430448 then true
431449 else throwErr("no vote")]
432450 if ((checks == checks))
433451 then {
434452 let votesListName = getVotesListName(pool)
435453 let userAddressStr = toString(i.caller)
436454 $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)
437455 }
438456 else throw("Strict value is not equal to itself.")
439457 }
440458
441459
442460
443461 @Callable(i)
444462 func setEpochLength (newEpochLength) = {
445463 let checks = [mustManager(i), if ((newEpochLength > 0))
446464 then true
447465 else throwErr("invalid epoch length")]
448466 if ((checks == checks))
449467 then $Tuple2([IntegerEntry(keyEpochLengthNew, newEpochLength)], unit)
450468 else throw("Strict value is not equal to itself.")
451469 }
452470
453471
454472
455473 @Callable(i)
456474 func setMaxDepth (newMaxDepth) = {
457475 let checks = [mustManager(i), if ((newMaxDepth > 0))
458476 then true
459477 else throwErr("invalid max depth")]
460478 if ((checks == checks))
461479 then $Tuple2([IntegerEntry(keyMaxDepth, newMaxDepth)], unit)
462480 else throw("Strict value is not equal to itself.")
463481 }
464482
465483
466484
467485 @Callable(i)
468486 func processVoteINTERNAL (poolStr,userAddressStr) = {
469487 let checkCaller = mustThis(i)
470488 if ((checkCaller == checkCaller))
471489 then {
472490 let userAddress = valueOrErrorMessage(addressFromString(userAddressStr), wrapErr(("processVoteINTERNAL: invalid user address " + userAddressStr)))
473491 let epoch = getIntOrFail(this, keyCurrentEpoch)
474492 let epochPrevious = (epoch - 1)
475493 let epochLength = getIntOrFail(this, keyEpochLength)
476494 let startHeight = getIntOrFail(this, keyStartHeightByEpoch(epoch))
477495 let endHeight = (startHeight + epochLength)
478496 let startHeightPrevious = getIntOrFail(this, keyStartHeightByEpoch(epochPrevious))
479497 let epochLengthPrevious = getIntOrFail(this, keyEpochLengthByEpoch(epochPrevious))
480498 let endHeightPrevious = (startHeightPrevious + epochLengthPrevious)
481499 let checkTargetEpoch = if ((epochPrevious >= 0))
482500 then true
483501 else throwErr("processVoteINTERNAL: invalid previous epoch")
484502 if ((checkTargetEpoch == checkTargetEpoch))
485503 then {
486504 let pool = stringToPool(poolStr)
487- let $t01755217592 = pool
488- let amountAssetId = $t01755217592._1
489- let priceAssetId = $t01755217592._2
505+ let $t01797018010 = pool
506+ let amountAssetId = $t01797018010._1
507+ let priceAssetId = $t01797018010._2
490508 let wxEmission = checkWxEmissionPoolLabel(pool)
491509 let gwxAmountAtEndTotal = {
492510 let @ = invoke(this, "getUserGwxAmountAtHeight", [userAddressStr, endHeight], nil)
493511 if ($isInstanceOf(@, "Int"))
494512 then @
495513 else throw(($getType(@) + " couldn't be cast to Int"))
496514 }
497515 let gwxAmountAtEndTotalPrevious = {
498516 let @ = invoke(this, "getUserGwxAmountAtHeight", [userAddressStr, endHeightPrevious], nil)
499517 if ($isInstanceOf(@, "Int"))
500518 then @
501519 else throw(($getType(@) + " couldn't be cast to Int"))
502520 }
503521 let totalVotes = valueOrElse(getInteger(keyTotalVotes(epoch)), 0)
504522 let votingResult = valueOrElse(getInteger(keyVotingResult(pool, epoch)), 0)
505523 let votePrevious = valueOrErrorMessage(getInteger(keyVote(pool, userAddress, epochPrevious)), wrapErr((((("processVoteINTERNAL " + poolStr) + " ") + userAddressStr) + ": no previous vote")))
506524 let used = valueOrElse(getInteger(this, keyUsed(userAddress, epoch)), 0)
507525 let lpAssetIdStr = getLpAssetByPoolAssets(amountAssetId, priceAssetId)
508526 let votingResultStakedPrevious = valueOrElse(getInteger(keyVotingResultStaked(lpAssetIdStr, epochPrevious)), 0)
509527 let stakingContract = addressFromStringValue(getStrOrFail(this, keyStakingContract))
510528 let stakedByUser = valueOrElse(getInteger(stakingContract, keyStakedByUser(lpAssetIdStr, userAddressStr)), 0)
511529 let votingResultStakedActions = if ((stakedByUser == 0))
512530 then nil
513531 else [IntegerEntry(keyVotingResultStaked(lpAssetIdStr, epochPrevious), (votingResultStakedPrevious + votePrevious))]
514532 let newVote = if ((gwxAmountAtEndTotalPrevious > 0))
515533 then fraction(votePrevious, gwxAmountAtEndTotal, gwxAmountAtEndTotalPrevious)
516534 else 0
517535 let actions = if (if ((newVote > 0))
518536 then wxEmission
519537 else false)
520538 then [IntegerEntry(keyVote(pool, userAddress, epoch), newVote), IntegerEntry(keyTotalVotes(epoch), (totalVotes + newVote)), IntegerEntry(keyVotingResult(pool, epoch), (votingResult + newVote)), IntegerEntry(keyUsed(userAddress, epoch), (used + newVote))]
521539 else deleteNodeActions(getVotesListName(pool), userAddressStr)
522540 $Tuple2((actions ++ votingResultStakedActions), unit)
523541 }
524542 else throw("Strict value is not equal to itself.")
525543 }
526544 else throw("Strict value is not equal to itself.")
527545 }
528546
529547
530548
531549 @Callable(i)
532550 func processPoolINTERNAL (poolStr,force) = {
533551 let checkCaller = mustThis(i)
534552 if ((checkCaller == checkCaller))
535553 then {
536554 let targetEpoch = {
537555 let currentEpoch = getIntOrFail(this, keyCurrentEpoch)
538556 if (force)
539557 then currentEpoch
540558 else (currentEpoch - 1)
541559 }
542560 let checkTargetEpoch = if ((targetEpoch >= 0))
543561 then true
544562 else throwErr("processPoolINTERNAL: invalid target epoch")
545563 if ((checkTargetEpoch == checkTargetEpoch))
546564 then {
547565 let pool = stringToPool(poolStr)
548- let $t01994919989 = pool
549- let amountAssetId = $t01994919989._1
550- let priceAssetId = $t01994919989._2
566+ let $t02036720407 = pool
567+ let amountAssetId = $t02036720407._1
568+ let priceAssetId = $t02036720407._2
551569 let stakingContract = addressFromStringValue(getStrOrFail(this, keyStakingContract))
552- let factoryContract = addressFromStringValue(getStrOrFail(this, keyFactoryContract))
553570 let lpAssetId = getLpAssetByPoolAssets(amountAssetId, priceAssetId)
554571 let r = {
555572 let @ = invoke(stakingContract, "usersListTraversal", [lpAssetId], nil)
556573 if ($isInstanceOf(@, "Boolean"))
557574 then @
558575 else throw(($getType(@) + " couldn't be cast to Boolean"))
559576 }
560577 if ((r == r))
561578 then if (r)
562579 then $Tuple2(nil, true)
563580 else {
564581 let wxEmission = checkWxEmissionPoolLabel(pool)
565582 let totalVotes = valueOrElse(getInteger(this, keyTotalVotes(targetEpoch)), 0)
566583 let votingResult = valueOrElse(getInteger(this, keyVotingResult(pool, targetEpoch)), 0)
567584 let share = if (if ((totalVotes == 0))
568585 then true
569586 else !(wxEmission))
570587 then 0
571588 else fraction(votingResult, poolWeightMult, totalVotes)
572589 let modifyWeightInv = invoke(factoryContract, "modifyWeight", [lpAssetId, share], nil)
573590 if ((modifyWeightInv == modifyWeightInv))
574591 then {
575592 let poolsListActions = if (if (wxEmission)
576593 then true
577594 else force)
578595 then nil
579596 else ([DeleteEntry(keyInList(pool))] ++ deleteNodeActions(poolsListName, poolStr))
580597 $Tuple2(([IntegerEntry(keyPoolShare(pool, targetEpoch), share)] ++ poolsListActions), false)
581598 }
582599 else throw("Strict value is not equal to itself.")
583600 }
584601 else throw("Strict value is not equal to itself.")
585602 }
586603 else throw("Strict value is not equal to itself.")
587604 }
588605 else throw("Strict value is not equal to itself.")
589606 }
590607
591608
592609
593610 @Callable(i)
594611 func finalizeHelper () = {
595612 let force = valueOrElse(getBoolean(keyFinalizationShouldBeForced), false)
596613 let epoch = valueOrElse(getInteger(this, keyCurrentEpoch), 0)
597614 let previousEpoch = (epoch - 1)
598615 let startHeight = getIntOrFail(this, keyStartHeightByEpoch(epoch))
599616 let epochLength = getIntOrFail(this, keyEpochLength)
600617 let endHeight = (startHeight + epochLength)
601618 let finalizationStageOrUnit = getInteger(this, keyFinalizationStage)
602619 if (if (if ((height >= endHeight))
603620 then (finalizationStageOrUnit == unit)
604621 else false)
605622 then !(force)
606623 else false)
607624 then {
608625 let newEpoch = (epoch + 1)
609626 let newEpochLengthOption = getInteger(this, keyEpochLengthNew)
610627 let newEpochLengthActions = match newEpochLengthOption {
611628 case newEpochLength: Int =>
612629 [IntegerEntry(keyEpochLength, newEpochLength), DeleteEntry(keyEpochLengthNew)]
613630 case _: Unit =>
614631 nil
615632 case _ =>
616633 throw("Match error")
617634 }
618635 $Tuple2(([IntegerEntry(keyStartHeightByEpoch(newEpoch), height), IntegerEntry(keyStartHeight, height), IntegerEntry(keyCurrentEpoch, newEpoch), IntegerEntry(keyFinalizationStage, finalizationStageTotal), IntegerEntry(keyEpochLengthByEpoch(epoch), epochLength)] ++ newEpochLengthActions), true)
619636 }
620637 else if (if (force)
621638 then (finalizationStageOrUnit == unit)
622639 else false)
623640 then $Tuple2([IntegerEntry(keyFinalizationStage, finalizationStageShares)], true)
624641 else if ((finalizationStageOrUnit == unit))
625642 then $Tuple2(nil, false)
626643 else if ((finalizationStageOrUnit == finalizationStageTotal))
627644 then {
628645 let poolOrUnit = getString(keyNextPool)
629646 let userOrUnit = getString(keyNextUser)
630647 match poolOrUnit {
631648 case _: Unit =>
632649 match getString(keyListHead(poolsListName)) {
633650 case _: Unit =>
634651 $Tuple2([IntegerEntry(keyFinalizationStage, finalizationStageShares), DeleteEntry(keyNextPool), DeleteEntry(keyNextUser)], true)
635652 case poolsHeadStr: String =>
636653 $Tuple2([StringEntry(keyNextPool, poolsHeadStr)], true)
637654 case _ =>
638655 throw("Match error")
639656 }
640657 case poolStr: String =>
641658 let pool = stringToPool(poolStr)
642659 let nextUserOrUnit = match userOrUnit {
643660 case _: Unit =>
644661 getString(keyListHead(getVotesListName(pool)))
645662 case user: String =>
646663 let next = getString(keyListNext(getVotesListName(pool), user))
647664 if ((next == next))
648665 then {
649666 let processVoteInv = invoke(this, "processVoteINTERNAL", [poolStr, user], nil)
650667 if ((processVoteInv == processVoteInv))
651668 then next
652669 else throw("Strict value is not equal to itself.")
653670 }
654671 else throw("Strict value is not equal to itself.")
655672 case _ =>
656673 throw("Match error")
657674 }
658675 match nextUserOrUnit {
659676 case _: Unit =>
660677 let nextPoolOrUnit = getString(keyListNext(poolsListName, poolStr))
661678 match nextPoolOrUnit {
662679 case _: Unit =>
663680 $Tuple2([IntegerEntry(keyFinalizationStage, finalizationStageShares), DeleteEntry(keyNextPool), DeleteEntry(keyNextUser)], true)
664681 case s: String =>
665682 $Tuple2([StringEntry(keyNextPool, s), DeleteEntry(keyNextUser)], true)
666683 case _ =>
667684 throw("Match error")
668685 }
669686 case nextUser: String =>
670687 $Tuple2([StringEntry(keyNextUser, nextUser)], true)
671688 case _ =>
672689 throw("Match error")
673690 }
674691 case _ =>
675692 throw("Match error")
676693 }
677694 }
678695 else if ((finalizationStageOrUnit == finalizationStageShares))
679696 then {
680697 let poolOrUnit = getString(keyNextPool)
681698 match poolOrUnit {
682699 case _: Unit =>
683700 match getString(keyListHead(poolsListName)) {
684701 case _: Unit =>
685702 let actions = if (force)
686703 then [DeleteEntry(keyFinalizationStage), DeleteEntry(keyFinalizationShouldBeForced)]
687704 else [DeleteEntry(keyFinalizationStage), BooleanEntry(keyFinalized(previousEpoch), true), IntegerEntry(keyCurrentEpochUi, epoch), IntegerEntry(keyStartHeightUi, startHeight)]
688- $Tuple2(actions, true)
705+ let gwxRewardDepositInv = gwxRewardDeposit()
706+ if ((gwxRewardDepositInv == gwxRewardDepositInv))
707+ then $Tuple2(actions, true)
708+ else throw("Strict value is not equal to itself.")
689709 case nextPoolStr: String =>
690710 $Tuple2([StringEntry(keyNextPool, nextPoolStr)], true)
691711 case _ =>
692712 throw("Match error")
693713 }
694714 case poolStr: String =>
695715 let nextPoolOrUnit = getString(keyListNext(poolsListName, poolStr))
696716 if ((nextPoolOrUnit == nextPoolOrUnit))
697717 then {
698718 let r = {
699719 let @ = invoke(this, "processPoolINTERNAL", [poolStr, force], nil)
700720 if ($isInstanceOf(@, "Boolean"))
701721 then @
702722 else throw(($getType(@) + " couldn't be cast to Boolean"))
703723 }
704724 if ((r == r))
705725 then if (r)
706726 then $Tuple2(nil, true)
707727 else match nextPoolOrUnit {
708728 case _: Unit =>
709729 let actions = if (force)
710730 then [DeleteEntry(keyFinalizationStage), DeleteEntry(keyFinalizationShouldBeForced), DeleteEntry(keyNextPool)]
711731 else [DeleteEntry(keyFinalizationStage), BooleanEntry(keyFinalized(previousEpoch), true), IntegerEntry(keyCurrentEpochUi, epoch), IntegerEntry(keyStartHeightUi, startHeight), DeleteEntry(keyNextPool)]
712- $Tuple2(actions, true)
732+ let gwxRewardDepositInv = gwxRewardDeposit()
733+ if ((gwxRewardDepositInv == gwxRewardDepositInv))
734+ then $Tuple2(actions, true)
735+ else throw("Strict value is not equal to itself.")
713736 case nextPoolStr: String =>
714737 $Tuple2([StringEntry(keyNextPool, nextPoolStr)], true)
715738 case _ =>
716739 throw("Match error")
717740 }
718741 else throw("Strict value is not equal to itself.")
719742 }
720743 else throw("Strict value is not equal to itself.")
721744 case _ =>
722745 throw("Match error")
723746 }
724747 }
725748 else throwErr("finalization is broken")
726749 }
727750
728751
729752
730753 @Callable(i)
731754 func finalizeWrapper (counter) = {
732755 let result = {
733756 let @ = invoke(this, "finalizeHelper", nil, nil)
734757 if ($isInstanceOf(@, "Boolean"))
735758 then @
736759 else throw(($getType(@) + " couldn't be cast to Boolean"))
737760 }
738761 if ((result == result))
739762 then if (!(result))
740763 then if ((counter == 0))
741764 then throwErr("Current voting is not over yet")
742765 else $Tuple2(nil, unit)
743766 else {
744767 let maxDepth = valueOrElse(getInteger(this, keyMaxDepth), maxDepthDefault)
745768 if ((maxDepth > counter))
746769 then {
747770 let inv = invoke(this, "finalizeWrapper", [(counter + 1)], nil)
748771 if ((inv == inv))
749772 then $Tuple2(nil, unit)
750773 else throw("Strict value is not equal to itself.")
751774 }
752775 else $Tuple2(nil, unit)
753776 }
754777 else throw("Strict value is not equal to itself.")
755778 }
756779
757780
758781
759782 @Callable(i)
760783 func finalize () = {
761784 let inv = invoke(this, "finalizeWrapper", [0], nil)
762785 if ((inv == inv))
763786 then $Tuple2(nil, unit)
764787 else throw("Strict value is not equal to itself.")
765788 }
766789
767790
768791
769792 @Callable(i)
770793 func containsNodeREADONLY (listName,id) = $Tuple2(nil, containsNode(listName, id))
771794
772795
773796
774797 @Callable(i)
775798 func insertNode (listName,id) = {
776799 let checkCaller = mustManager(i)
777800 if ((checkCaller == checkCaller))
778801 then $Tuple2(insertNodeActions(listName, id), unit)
779802 else throw("Strict value is not equal to itself.")
780803 }
781804
782805
783806
784807 @Callable(i)
785808 func deleteNode (listName,id) = {
786809 let checkCaller = mustManager(i)
787810 if ((checkCaller == checkCaller))
788811 then $Tuple2(deleteNodeActions(listName, id), unit)
789812 else throw("Strict value is not equal to itself.")
790813 }
791814
792815
793-
794-@Callable(i)
795-func isFinalizationInProgress () = {
796- let finalizationStageOrUnit = getInteger(this, keyFinalizationStage)
797- let finalizationInProgress = (finalizationStageOrUnit != unit)
798- $Tuple2(nil, finalizationInProgress)
799- }
800-
801-
802816 @Verifier(tx)
803817 func verify () = {
804818 let targetPublicKey = match managerPublicKeyOrUnit() {
805819 case pk: ByteVector =>
806820 pk
807821 case _: Unit =>
808822 tx.senderPublicKey
809823 case _ =>
810824 throw("Match error")
811825 }
812826 sigVerify(tx.bodyBytes, tx.proofs[0], targetPublicKey)
813827 }
814828

github/deemru/w8io/3ef1775 
120.96 ms