tx · 49c3vZz6BgY45jsxTz3UmuMteDRpr6f5GLGZkBzxynQ4 3N9Zi6AcWcGbM23jQJ4fnzFsoHoTsxYDznr: -0.02200000 Waves 2023.06.01 12:22 [2603411] smart account 3N9Zi6AcWcGbM23jQJ4fnzFsoHoTsxYDznr > SELF 0.00000000 Waves
{ "type": 13, "id": "49c3vZz6BgY45jsxTz3UmuMteDRpr6f5GLGZkBzxynQ4", "fee": 2200000, "feeAssetId": null, "timestamp": 1685611396932, "version": 2, "chainId": 84, "sender": "3N9Zi6AcWcGbM23jQJ4fnzFsoHoTsxYDznr", "senderPublicKey": "GFbasS3jufhZkK4xR7tdTjjnP8K33KvJFEDHRtxXDkaJ", "proofs": [ "1AsWcJEP4mFLzvQ4gYUd2FfH3GjPvbrFLR1m3XnLBD69vMmkS4kGiHx6FbHKv4XbWfhgXgQhnDZ9xyyW1RpqjrS" ], "script": "base64:BgKpFggCEgQKAggBEgcKBQgICAgBEgQKAggIEgUKAwgIARIECgIICBIDCgEBEgMKAQESBAoCCAgSBAoCCAQSABIDCgEBEgASBAoCCAgSBAoCCAgSBAoCCAgiCXNlcGFyYXRvciIOcG9vbFdlaWdodE11bHQiD21heERlcHRoRGVmYXVsdCIWZmluYWxpemF0aW9uU3RhZ2VUb3RhbCIXZmluYWxpemF0aW9uU3RhZ2VTaGFyZXMiDmtleUVwb2NoTGVuZ3RoIhFrZXlFcG9jaExlbmd0aE5ldyIVa2V5RXBvY2hMZW5ndGhCeUVwb2NoIgVlcG9jaCIPa2V5Q3VycmVudEVwb2NoIgtrZXlNYXhEZXB0aCIia2V5Vm90aW5nRW1pc3Npb25DYW5kaWRhdGVDb250cmFjdCISa2V5RmFjdG9yeUNvbnRyYWN0IhNrZXlCb29zdGluZ0NvbnRyYWN0IhJrZXlTdGFraW5nQ29udHJhY3QiFGtleUZpbmFsaXphdGlvblN0YWdlIgtrZXlOZXh0UG9vbCILa2V5TmV4dFVzZXIiDmtleVN0YXJ0SGVpZ2h0IhFrZXlDdXJyZW50RXBvY2hVaSIQa2V5U3RhcnRIZWlnaHRVaSIda2V5RmluYWxpemF0aW9uU2hvdWxkQmVGb3JjZWQiFWtleVN0YXJ0SGVpZ2h0QnlFcG9jaCIMa2V5RmluYWxpemVkIglrZXlJbkxpc3QiBHBvb2wiCyR0MDE2OTMxNzMzIg1hbW91bnRBc3NldElkIgxwcmljZUFzc2V0SWQiB2tleVVzZWQiB2FkZHJlc3MiB2tleVZvdGUiCyR0MDIwMDcyMDQ3Ig9rZXlWb3RpbmdSZXN1bHQiCyR0MDIyMjkyMjY5IhVrZXlWb3RpbmdSZXN1bHRTdGFrZWQiDGxwQXNzZXRJZFN0ciIMa2V5UG9vbFNoYXJlIgskdDAyNTkwMjYzMCINa2V5VG90YWxWb3RlcyIPa2V5U3Rha2VkQnlVc2VyIg51c2VyQWRkcmVzc1N0ciIHd3JhcEVyciIDbXNnIgh0aHJvd0VyciIOZ2V0VmFsdWVPckZhaWwiA2tleSIEdHlwZSIFZXJyb3IiByRtYXRjaDAiA3N0ciIDaW50IgxnZXRTdHJPckZhaWwiAUAiDGdldEludE9yRmFpbCIMcG9vbFRvU3RyaW5nIgxzdHJpbmdUb1Bvb2wiBXBhcnRzIg9mYWN0b3J5Q29udHJhY3QiGklkeEZhY3RvcnlDZmdHd3hSZXdhcmREYXBwIg1rZXlGYWN0b3J5Q2ZnIhRyZWFkRmFjdG9yeUNmZ09yRmFpbCIHZmFjdG9yeSIZZ2V0R3d4UmV3YXJkQWRkcmVzc09yRmFpbCIKZmFjdG9yeUNmZyIWZ2V0THBBc3NldEJ5UG9vbEFzc2V0cyIfa2V5TWFwcGluZ3NCYXNlQXNzZXQyaW50ZXJuYWxJZCIMYmFzZUFzc2V0U3RyIilrZXlNYXBwaW5nUG9vbEFzc2V0c1RvUG9vbENvbnRyYWN0QWRkcmVzcyIYaW50ZXJuYWxBbW91bnRBc3NldElkU3RyIhdpbnRlcm5hbFByaWNlQXNzZXRJZFN0ciIfa2V5TWFwcGluZ1Bvb2xDb250cmFjdFRvTFBBc3NldCITcG9vbENvbnRyYWN0QWRkcmVzcyIVYW1vdW50QXNzZXRJbnRlcm5hbElkIhRwcmljZUFzc2V0SW50ZXJuYWxJZCIJbHBBc3NldElkIhhjaGVja1d4RW1pc3Npb25Qb29sTGFiZWwiCyR0MDU0NzA1NTEwIhBnd3hSZXdhcmREZXBvc2l0IhJnd3hSZXdhcmRzQ29udHJhY3QiDXBvb2xzTGlzdE5hbWUiEGdldFZvdGVzTGlzdE5hbWUiCyR0MDU5Mjc1OTY3IgtrZXlMaXN0SGVhZCIIbGlzdE5hbWUiBG1ldGEiC2tleUxpc3RTaXplIgtrZXlMaXN0UHJldiICaWQiC2tleUxpc3ROZXh0Igxjb250YWluc05vZGUiCmhlYWRPclVuaXQiCnByZXZPclVuaXQiCm5leHRPclVuaXQiEWluc2VydE5vZGVBY3Rpb25zIghsaXN0U2l6ZSIJY2hlY2tOb2RlIhFkZWxldGVOb2RlQWN0aW9ucyIWa2V5TWFuYWdlclZhdWx0QWRkcmVzcyITa2V5TWFuYWdlclB1YmxpY0tleSIcZ2V0TWFuYWdlclZhdWx0QWRkcmVzc09yVGhpcyIBcyIWbWFuYWdlclB1YmxpY0tleU9yVW5pdCITbWFuYWdlclZhdWx0QWRkcmVzcyIJaXNNYW5hZ2VyIgFpIgJwayILbXVzdE1hbmFnZXIiCG11c3RUaGlzIgt1c2VyQWRkcmVzcyIMdGFyZ2V0SGVpZ2h0Ihdib29zdGluZ0NvbnRyYWN0QWRkcmVzcyIfdm90aW5nRW1pc3Npb25DYW5kaWRhdGVDb250cmFjdCIQYm9vc3RpbmdDb250cmFjdCIPc3Rha2luZ0NvbnRyYWN0IgtlcG9jaExlbmd0aCIGY2hlY2tzIg1pbkxpc3RBY3Rpb25zIhhjdXJyZW50RXBvY2hJc05vdERlZmluZWQiEnN0YXJ0SGVpZ2h0QWN0aW9ucyIGYW1vdW50IgtzdGFydEhlaWdodCIJZW5kSGVpZ2h0IhdmaW5hbGl6YXRpb25TdGFnZU9yVW5pdCIEdXNlZCIEdm90ZSIKcG9vbFJlc3VsdCIKdG90YWxWb3RlcyITZ3d4QW1vdW50QXRFbmRUb3RhbCIJYXZhaWxhYmxlIgduZXdWb3RlIgp3eEVtaXNzaW9uIg12b3Rlc0xpc3ROYW1lIhB2b3Rlc0xpc3RBY3Rpb25zIg5uZXdFcG9jaExlbmd0aCILbmV3TWF4RGVwdGgiB3Bvb2xTdHIiC2NoZWNrQ2FsbGVyIg1lcG9jaFByZXZpb3VzIhNzdGFydEhlaWdodFByZXZpb3VzIhNlcG9jaExlbmd0aFByZXZpb3VzIhFlbmRIZWlnaHRQcmV2aW91cyIQY2hlY2tUYXJnZXRFcG9jaCINJHQwMTc5NzAxODAxMCIbZ3d4QW1vdW50QXRFbmRUb3RhbFByZXZpb3VzIgx2b3RpbmdSZXN1bHQiDHZvdGVQcmV2aW91cyIadm90aW5nUmVzdWx0U3Rha2VkUHJldmlvdXMiDHN0YWtlZEJ5VXNlciIZdm90aW5nUmVzdWx0U3Rha2VkQWN0aW9ucyIHYWN0aW9ucyIFZm9yY2UiC3RhcmdldEVwb2NoIgxjdXJyZW50RXBvY2giDSR0MDIwMzY3MjA0MDciAXIiBXNoYXJlIg9tb2RpZnlXZWlnaHRJbnYiEHBvb2xzTGlzdEFjdGlvbnMiDXByZXZpb3VzRXBvY2giCG5ld0Vwb2NoIhRuZXdFcG9jaExlbmd0aE9wdGlvbiIVbmV3RXBvY2hMZW5ndGhBY3Rpb25zIgpwb29sT3JVbml0Igp1c2VyT3JVbml0IgckbWF0Y2gxIgxwb29sc0hlYWRTdHIiDm5leHRVc2VyT3JVbml0IgR1c2VyIgRuZXh0Ig5wcm9jZXNzVm90ZUludiIObmV4dFBvb2xPclVuaXQiByRtYXRjaDIiCG5leHRVc2VyIhNnd3hSZXdhcmREZXBvc2l0SW52IgtuZXh0UG9vbFN0ciIHY291bnRlciIGcmVzdWx0IghtYXhEZXB0aCIDaW52IgJ0eCIGdmVyaWZ5Ig90YXJnZXRQdWJsaWNLZXk+AAFhAgJfXwABYgCAwtcvAAFjAAoAAWQAAAABZQABAAFmCQC5CQIJAMwIAgICJXMJAMwIAgILZXBvY2hMZW5ndGgFA25pbAUBYQABZwkAuQkCCQDMCAICBCVzJXMJAMwIAgIQZXBvY2hMZW5ndGhfX25ldwUDbmlsBQFhAQFoAQFpCQC5CQIJAMwIAgIEJXMlZAkAzAgCAgtlcG9jaExlbmd0aAkAzAgCCQCkAwEFAWkFA25pbAUBYQABagkAuQkCCQDMCAICAiVzCQDMCAICDGN1cnJlbnRFcG9jaAUDbmlsBQFhAAFrCQC5CQIJAMwIAgICJXMJAMwIAgIIbWF4RGVwdGgFA25pbAUBYQABbAkAuQkCCQDMCAICAiVzCQDMCAICH3ZvdGluZ0VtaXNzaW9uQ2FuZGlkYXRlQ29udHJhY3QFA25pbAUBYQABbQkAuQkCCQDMCAICAiVzCQDMCAICD2ZhY3RvcnlDb250cmFjdAUDbmlsBQFhAAFuCQC5CQIJAMwIAgICJXMJAMwIAgIQYm9vc3RpbmdDb250cmFjdAUDbmlsBQFhAAFvCQC5CQIJAMwIAgICJXMJAMwIAgIPc3Rha2luZ0NvbnRyYWN0BQNuaWwFAWEAAXAJALkJAgkAzAgCAgIlcwkAzAgCAhFmaW5hbGl6YXRpb25TdGFnZQUDbmlsBQFhAAFxCQC5CQIJAMwIAgICJXMJAMwIAgIIbmV4dFBvb2wFA25pbAUBYQABcgkAuQkCCQDMCAICAiVzCQDMCAICCG5leHRVc2VyBQNuaWwFAWEAAXMJALkJAgkAzAgCAgIlcwkAzAgCAgtzdGFydEhlaWdodAUDbmlsBQFhAAF0CQC5CQIJAMwIAgICJXMJAMwIAgIOY3VycmVudEVwb2NoVWkFA25pbAUBYQABdQkAuQkCCQDMCAICAiVzCQDMCAICDXN0YXJ0SGVpZ2h0VWkFA25pbAUBYQABdgkAuQkCCQDMCAICAiVzCQDMCAICBWZvcmNlBQNuaWwFAWEBAXcBAWkJALkJAgkAzAgCAgQlcyVkCQDMCAICC3N0YXJ0SGVpZ2h0CQDMCAIJAKQDAQUBaQUDbmlsBQFhAQF4AQFpCQC5CQIJAMwIAgIEJXMlZAkAzAgCAglmaW5hbGl6ZWQJAMwIAgkApAMBBQFpBQNuaWwFAWEBAXkBAXoEAUEFAXoEAUIIBQFBAl8xBAFDCAUBQQJfMgkAuQkCCQDMCAICBiVzJXMlcwkAzAgCAgZpbkxpc3QJAMwIAgUBQgkAzAgCBQFDBQNuaWwFAWEBAUQCAUUBaQkAuQkCCQDMCAICBiVzJXMlZAkAzAgCAgR1c2VkCQDMCAIJAKUIAQUBRQkAzAgCCQCkAwEFAWkFA25pbAUBYQEBRgMBegFFAWkEAUcFAXoEAUIIBQFHAl8xBAFDCAUBRwJfMgkAuQkCCQDMCAICCiVzJXMlcyVzJWQJAMwIAgIEdm90ZQkAzAgCBQFCCQDMCAIFAUMJAMwIAgkApQgBBQFFCQDMCAIJAKQDAQUBaQUDbmlsBQFhAQFIAgF6AWkEAUkFAXoEAUIIBQFJAl8xBAFDCAUBSQJfMgkAuQkCCQDMCAICCCVzJXMlcyVkCQDMCAICDHZvdGluZ1Jlc3VsdAkAzAgCBQFCCQDMCAIFAUMJAMwIAgkApAMBBQFpBQNuaWwFAWEBAUoCAUsBaQkAuQkCCQDMCAICBiVzJXMlZAkAzAgCAhJ2b3RpbmdSZXN1bHRTdGFrZWQJAMwIAgUBSwkAzAgCCQCkAwEFAWkFA25pbAUBYQEBTAIBegFpBAFNBQF6BAFCCAUBTQJfMQQBQwgFAU0CXzIJALkJAgkAzAgCAgglcyVzJXMlZAkAzAgCAglwb29sU2hhcmUJAMwIAgUBQgkAzAgCBQFDCQDMCAIJAKQDAQUBaQUDbmlsBQFhAQFOAQFpCQC5CQIJAMwIAgIEJXMlZAkAzAgCAgp0b3RhbFZvdGVzCQDMCAIJAKQDAQUBaQUDbmlsBQFhAQFPAgFLAVAJALkJAgkAzAgCAgYlcyVzJXMJAMwIAgIGc3Rha2VkCQDMCAIFAVAJAMwIAgUBSwUDbmlsBQFhAQFRAQFSCQC5CQIJAMwIAgIVdm90aW5nX2VtaXNzaW9uLnJpZGU6CQDMCAIFAVIFA25pbAIBIAEBUwEBUgkAAgEJAQFRAQUBUgEBVAMBRQFVAVYEAVcJAQFRAQkAuQkCCQDMCAICCm1hbmRhdG9yeSAJAMwIAgkApQgBBQFFCQDMCAICAS4JAMwIAgUBVQkAzAgCAg8gaXMgbm90IGRlZmluZWQFA25pbAIACQETdmFsdWVPckVycm9yTWVzc2FnZQIEAVgFAVYDCQABAgUBWAIGU3RyaW5nBAFZBQFYCQCdCAIFAUUFAVUDCQABAgUBWAIDSW50BAFaBQFYCQCaCAIFAUUFAVUJAQFTAQISaW52YWxpZCBlbnRyeSB0eXBlBQFXAQJhYQIBRQFVCgACYWIJAQFUAwUBRQUBVQIAAwkAAQIFAmFiAgZTdHJpbmcFAmFiCQACAQkArAICCQADAQUCYWICGyBjb3VsZG4ndCBiZSBjYXN0IHRvIFN0cmluZwECYWMCAUUBVQoAAmFiCQEBVAMFAUUFAVUAAAMJAAECBQJhYgIDSW50BQJhYgkAAgEJAKwCAgkAAwEFAmFiAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQBAmFkAQF6CQCsAgIJAKwCAggFAXoCXzEFAWEIBQF6Al8yAQJhZQEBWQQCYWYJALUJAgUBWQUBYQMJAAACCQCQAwEFAmFmAAIJAJQKAgkAkQMCBQJhZgAACQCRAwIFAmFmAAEJAQFTAQITaW52YWxpZCBwb29sIHN0cmluZwACYWcJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQJhYQIFBHRoaXMFAW0AAmFoAAoBAmFpAAIRJXNfX2ZhY3RvcnlDb25maWcBAmFqAQJhawkAtQkCCQECYWECBQJhawkBAmFpAAUBYQECYWwBAmFtCQERQGV4dHJOYXRpdmUoMTA2MikBCQCRAwIFAmFtBQJhaAECYW4CAUIBQwoBAmFvAQJhcAkArAICAiglcyVzJXNfX21hcHBpbmdzX19iYXNlQXNzZXQyaW50ZXJuYWxJZF9fBQJhcAoBAmFxAgJhcgJhcwkArAICCQCsAgIJAKwCAgkArAICAgolZCVkJXMlc19fCQCkAwEFAmFyAgJfXwkApAMBBQJhcwIjX19tYXBwaW5nc19fcG9vbEFzc2V0czJQb29sQ29udHJhY3QKAQJhdAECYXUJAKwCAgkArAICAgglcyVzJXNfXwUCYXUCIF9fbWFwcGluZ3NfX3Bvb2xDb250cmFjdDJMcEFzc2V0BAJhdgkBAmFjAgUCYWcJAQJhbwEFAUIEAmF3CQECYWMCBQJhZwkBAmFvAQUBQwQCYXUJAQJhYQIFAmFnCQECYXECBQJhdgUCYXcEAmF4CQECYWECBQJhZwkBAmF0AQUCYXUFAmF4AQJheQEBegQCYXoFAXoEAUIIBQJhegJfMQQBQwgFAmF6Al8yCgACYWIJAPwHBAUCYWcCGGNoZWNrV3hFbWlzc2lvblBvb2xMYWJlbAkAzAgCBQFCCQDMCAIFAUMFA25pbAUDbmlsAwkAAQIFAmFiAgdCb29sZWFuBQJhYgkAAgEJAKwCAgkAAwEFAmFiAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuAQJhQQAEAmFtCQECYWoBBQJhZwQCYUIJAQJhbAEFAmFtCQD8BwQFAmFCAgdkZXBvc2l0BQNuaWwFA25pbAACYUMCBXBvb2xzAQJhRAEBegQCYUUFAXoEAUIIBQJhRQJfMQQBQwgFAmFFAl8yCQC5CQIJAMwIAgIFdm90ZXMJAMwIAgUBQgkAzAgCBQFDBQNuaWwFAWEBAmFGAQJhRwQCYUgDCQAAAgUCYUcFAmFDAgQlcyVzAgglcyVzJXMlcwkAuQkCCQDMCAIFAmFICQDMCAIFAmFHCQDMCAICBGhlYWQFA25pbAUBYQECYUkBAmFHBAJhSAMJAAACBQJhRwUCYUMCBCVzJXMCCCVzJXMlcyVzCQC5CQIJAMwIAgUCYUgJAMwIAgUCYUcJAMwIAgIEc2l6ZQUDbmlsBQFhAQJhSgICYUcCYUsEAmFIAwkAAAIFAmFHBQJhQwIIJXMlcyVzJXMCCiVzJXMlcyVzJXMJALkJAgkAzAgCBQJhSAkAzAgCBQJhRwkAzAgCBQJhSwkAzAgCAgRwcmV2BQNuaWwFAWEBAmFMAgJhRwJhSwQCYUgDCQAAAgUCYUcFAmFDAgglcyVzJXMlcwIKJXMlcyVzJXMlcwkAuQkCCQDMCAIFAmFICQDMCAIFAmFHCQDMCAIFAmFLCQDMCAICBG5leHQFA25pbAUBYQECYU0CAmFHAmFLBAJhTgkAnQgCBQR0aGlzCQECYUYBBQJhRwQCYU8JAJ0IAgUEdGhpcwkBAmFKAgUCYUcFAmFLBAJhUAkAnQgCBQR0aGlzCQECYUwCBQJhRwUCYUsDAwkAAAIFAmFLCQELdmFsdWVPckVsc2UCBQJhTgIABgkBAiE9AgUCYU8FBHVuaXQGCQECIT0CBQJhUAUEdW5pdAECYVECAmFHAmFLBAJhTgkAnQgCBQR0aGlzCQECYUYBBQJhRwQCYVIJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBAmFJAQUCYUcAAAQCYVMDCQEBIQEJAQJhTQIFAmFHBQJhSwYJAQFTAQILTm9kZSBleGlzdHMDCQAAAgUCYVMFAmFTCQDOCAIJAM4IAgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAmFJAQUCYUcJAGQCBQJhUgABBQNuaWwDCQECIT0CBQJhTgUEdW5pdAkAzAgCCQELU3RyaW5nRW50cnkCCQECYUwCBQJhRwUCYUsJAQV2YWx1ZQEFAmFOCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhSgIFAmFHCQEFdmFsdWUBBQJhTgUCYUsFA25pbAUDbmlsCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhRgEFAmFHBQJhSwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJhVAICYUcCYUsEAmFOCQCdCAIFBHRoaXMJAQJhRgEFAmFHBAJhUgkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQECYUkBBQJhRwAABAJhTwkAnQgCBQR0aGlzCQECYUoCBQJhRwUCYUsEAmFQCQCdCAIFBHRoaXMJAQJhTAIFAmFHBQJhSwkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYUkBBQJhRwkAZQIFAmFSAAEFA25pbAMDCQECIT0CBQJhTwUEdW5pdAkBAiE9AgUCYVAFBHVuaXQHCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhTAIFAmFHCQEFdmFsdWUBBQJhTwkBBXZhbHVlAQUCYVAJAMwIAgkBC1N0cmluZ0VudHJ5AgkBAmFKAgUCYUcJAQV2YWx1ZQEFAmFQCQEFdmFsdWUBBQJhTwkAzAgCCQELRGVsZXRlRW50cnkBCQECYUoCBQJhRwUCYUsJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAmFMAgUCYUcFAmFLBQNuaWwDCQECIT0CBQJhUAUEdW5pdAkAzAgCCQELU3RyaW5nRW50cnkCCQECYUYBBQJhRwkBBXZhbHVlAQUCYVAJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAmFMAgUCYUcFAmFLCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhSgIFAmFHCQEFdmFsdWUBBQJhUAUDbmlsAwkBAiE9AgUCYU8FBHVuaXQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAmFKAgUCYUcFAmFLCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhTAIFAmFHCQEFdmFsdWUBBQJhTwUDbmlsAwkAAAIFAmFLCQELdmFsdWVPckVsc2UCBQJhTgIACQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhRgEFAmFHBQNuaWwJAQFTAQkArAICCQCsAgIJAKwCAgIOaW52YWxpZCBub2RlOiAFAmFHAgEuBQJhSwECYVUAAhclc19fbWFuYWdlclZhdWx0QWRkcmVzcwECYVYAAhQlc19fbWFuYWdlclB1YmxpY0tleQECYVcABAFYCQCiCAEJAQJhVQADCQABAgUBWAIGU3RyaW5nBAJhWAUBWAkBEUBleHRyTmF0aXZlKDEwNjIpAQUCYVgFBHRoaXMBAmFZAAQCYVoJAQJhVwAEAVgJAJ0IAgUCYVoJAQJhVgADCQABAgUBWAIGU3RyaW5nBAJhWAUBWAkA2QQBBQJhWAMJAAECBQFYAgRVbml0BQR1bml0CQACAQILTWF0Y2ggZXJyb3IBAmJhAQJiYgQBWAkBAmFZAAMJAAECBQFYAgpCeXRlVmVjdG9yBAJiYwUBWAkAAAIIBQJiYg9jYWxsZXJQdWJsaWNLZXkFAmJjAwkAAQIFAVgCBFVuaXQJAAACCAUCYmIGY2FsbGVyBQR0aGlzCQACAQILTWF0Y2ggZXJyb3IBAmJkAQJiYgMJAQJiYQEFAmJiBgkAAgECEXBlcm1pc3Npb24gZGVuaWVkAQJiZQECYmIDCQAAAggFAmJiBmNhbGxlcgUEdGhpcwYJAAIBAhFwZXJtaXNzaW9uIGRlbmllZA8CYmIBGGdldFVzZXJHd3hBbW91bnRBdEhlaWdodAICYmYCYmcEAmJoCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBAmFhAgUEdGhpcwUBbgkBAVEBAiFpbnZhbGlkIGJvb3N0aW5nIGNvbnRyYWN0IGFkZHJlc3MJAJQKAgUDbmlsCgACYWIJAPwHBAUCYmgCIGdldFVzZXJHd3hBbW91bnRBdEhlaWdodFJFQURPTkxZCQDMCAIFAmJmCQDMCAIFAmJnBQNuaWwFA25pbAMJAAECBQJhYgIDSW50BQJhYgkAAgEJAKwCAgkAAwEFAmFiAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQCYmIBC2NvbnN0cnVjdG9yBQJhZwJiaQJiagJiawJibAQCYm0JAMwIAgkBAmJkAQUCYmIJAMwIAgMJAQIhPQIJAKYIAQUCYWcFBHVuaXQGAiBpbnZhbGlkIGZhY3RvcnkgY29udHJhY3QgYWRkcmVzcwkAzAgCAwkBAiE9AgkApggBBQJiaQUEdW5pdAYCMmludmFsaWQgdm90aW5nIGVtaXNzaW9uIGNhbmRpZGF0ZSBjb250cmFjdCBhZGRyZXNzCQDMCAIDCQECIT0CCQCmCAEFAmJqBQR1bml0BgIhaW52YWxpZCBib29zdGluZyBjb250cmFjdCBhZGRyZXNzCQDMCAIDCQECIT0CCQCmCAEFAmJrBQR1bml0BgIgaW52YWxpZCBzdGFraW5nIGNvbnRyYWN0IGFkZHJlc3MJAMwIAgMJAGYCBQJibAAABgkBAVMBAhRpbnZhbGlkIGVwb2NoIGxlbmd0aAUDbmlsAwkAAAIFAmJtBQJibQkAlAoCCQDMCAIJAQtTdHJpbmdFbnRyeQIFAW0FAmFnCQDMCAIJAQtTdHJpbmdFbnRyeQIFAWwFAmJpCQDMCAIJAQtTdHJpbmdFbnRyeQIFAW4FAmJqCQDMCAIJAQtTdHJpbmdFbnRyeQIFAW8FAmJrCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQFmBQJibAUDbmlsBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJiAQZjcmVhdGUCAUIBQwQCYm0JAMwIAgMJAAACCQDYBAEICAUCYmIGY2FsbGVyBWJ5dGVzCQELdmFsdWVPckVsc2UCCQCdCAIFBHRoaXMFAWwCAAYJAQJiZAEFAmJiBQNuaWwDCQAAAgUCYm0FAmJtBAF6CQCUCgIFAUIFAUMEAmJuCQDOCAIJAMwIAgkBDEJvb2xlYW5FbnRyeQIJAQF5AQUBegYFA25pbAkBAmFRAgUCYUMJAQJhZAEFAXoEAmJvCQAAAgkAmggCBQR0aGlzBQFqBQR1bml0BAJicAMFAmJvBAFpAAAJAMwIAgkBDEludGVnZXJFbnRyeQIFAWoFAWkJAMwIAgkBDEludGVnZXJFbnRyeQIJAQF3AQUBaQUGaGVpZ2h0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQFzBQZoZWlnaHQJAMwIAgkBDEludGVnZXJFbnRyeQIFAXQFAWkJAMwIAgkBDEludGVnZXJFbnRyeQIFAXUFBmhlaWdodAUDbmlsBQNuaWwJAJQKAgkAzggCBQJibgUCYnAFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYmIBBHZvdGUDAUIBQwJicQQBegkAlAoCBQFCBQFDBAFpCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFAWoAAAQCYnIJAQJhYwIFBHRoaXMJAQF3AQUBaQQCYmwJAQJhYwIFBHRoaXMFAWYEAmJzCQBkAgUCYnIFAmJsBAJidAkAmggCBQR0aGlzBQFwBAJidQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEBRAIIBQJiYgZjYWxsZXIFAWkAAAQCYnYJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBAUYDBQF6CAUCYmIGY2FsbGVyBQFpAAAEAmJ3CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQFIAgUBegUBaQAABAJieAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEBTgEFAWkAAAQCYnkKAAJhYgkA/AcEBQR0aGlzAhhnZXRVc2VyR3d4QW1vdW50QXRIZWlnaHQJAMwIAgkA2AQBCAgFAmJiBmNhbGxlcgVieXRlcwkAzAgCBQJicwUDbmlsBQNuaWwDCQABAgUCYWICA0ludAUCYWIJAAIBCQCsAgIJAAMBBQJhYgIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50BAJiegkAZQIFAmJ5BQJidQQCYkEJAGQCBQJidgUCYnEEAmJCCQECYXkBBQF6BAJibQkAzAgCAwkBAiE9AgkAoAgBCQEBeQEFAXoFBHVuaXQGCQEBUwECDmludmFsaWQgYXNzZXRzCQDMCAIDCQBmAgUCYnMFBmhlaWdodAYJAQFTAQIOaW52YWxpZCBoZWlnaHQJAMwIAgMJAAACBQJidAUEdW5pdAYJAQFTAQIYZmluYWxpemF0aW9uIGluIHByb2dyZXNzCQDMCAIDCQBmAgUCYnkAAAYJAQFTAQITeW91IGRvIG5vdCBoYXZlIGdXWAkAzAgCAwMJAGYCBQJicQAACQBnAgUCYnoFAmJxBwYJAQFTAQIOaW52YWxpZCBhbW91bnQJAMwIAgMFAmJCBgkBAVMBAh1wb29sIGhhc24ndCBXWF9FTUlTU0lPTiBsYWJlbAUDbmlsAwkAAAIFAmJtBQJibQQCYkMJAQJhRAEFAXoEAVAJAKUIAQgFAmJiBmNhbGxlcgQCYkQDCQECYU0CBQJiQwUBUAUDbmlsCQECYVECBQJiQwUBUAkAlAoCCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFEAggFAmJiBmNhbGxlcgUBaQkAZAIFAmJ1BQJicQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAUYDBQF6CAUCYmIGY2FsbGVyBQFpBQJiQQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAUgCBQF6BQFpCQBkAgUCYncFAmJxCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBTgEFAWkJAGQCBQJieAUCYnEFA25pbAUCYkQFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYmIBCmNhbmNlbFZvdGUCAUIBQwQBegkAlAoCBQFCBQFDBAFpCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFAWoAAAQCYnIJAQJhYwIFBHRoaXMJAQF3AQUBaQQCYmwJAQJhYwIFBHRoaXMFAWYEAmJzCQBkAgUCYnIFAmJsBAJidAkAmggCBQR0aGlzBQFwBAJidQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEBRAIIBQJiYgZjYWxsZXIFAWkAAAQCYnYJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBAUYDBQF6CAUCYmIGY2FsbGVyBQFpAAAEAmJ3CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQFIAgUBegUBaQAABAJieAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEBTgEFAWkAAAQCYm0JAMwIAgMJAQIhPQIJAKAIAQkBAXkBBQF6BQR1bml0BgkBAVMBAg5pbnZhbGlkIGFzc2V0cwkAzAgCAwkAZgIFAmJzBQZoZWlnaHQGCQEBUwECDmludmFsaWQgaGVpZ2h0CQDMCAIDCQAAAgUCYnQFBHVuaXQGCQEBUwECGGZpbmFsaXphdGlvbiBpbiBwcm9ncmVzcwkAzAgCAwkAZgIFAmJ2AAAGCQEBUwECB25vIHZvdGUFA25pbAMJAAACBQJibQUCYm0EAmJDCQECYUQBBQF6BAFQCQClCAEIBQJiYgZjYWxsZXIJAJQKAgkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBRAIIBQJiYgZjYWxsZXIFAWkJAJYDAQkAzAgCCQBlAgUCYnUFAmJ2CQDMCAIAAAUDbmlsCQDMCAIJAQtEZWxldGVFbnRyeQEJAQFGAwUBeggFAmJiBmNhbGxlcgUBaQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAUgCBQF6BQFpCQBlAgUCYncFAmJ2CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBTgEFAWkJAGUCBQJieAUCYnYFA25pbAkBAmFUAgUCYkMFAVAFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYmIBDnNldEVwb2NoTGVuZ3RoAQJiRQQCYm0JAMwIAgkBAmJkAQUCYmIJAMwIAgMJAGYCBQJiRQAABgkBAVMBAhRpbnZhbGlkIGVwb2NoIGxlbmd0aAUDbmlsAwkAAAIFAmJtBQJibQkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQFnBQJiRQUDbmlsBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJiAQtzZXRNYXhEZXB0aAECYkYEAmJtCQDMCAIJAQJiZAEFAmJiCQDMCAIDCQBmAgUCYkYAAAYJAQFTAQIRaW52YWxpZCBtYXggZGVwdGgFA25pbAMJAAACBQJibQUCYm0JAJQKAgkAzAgCCQEMSW50ZWdlckVudHJ5AgUBawUCYkYFA25pbAUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJiYgETcHJvY2Vzc1ZvdGVJTlRFUk5BTAICYkcBUAQCYkgJAQJiZQEFAmJiAwkAAAIFAmJIBQJiSAQCYmYJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBBQFQCQEBUQEJAKwCAgIqcHJvY2Vzc1ZvdGVJTlRFUk5BTDogaW52YWxpZCB1c2VyIGFkZHJlc3MgBQFQBAFpCQECYWMCBQR0aGlzBQFqBAJiSQkAZQIFAWkAAQQCYmwJAQJhYwIFBHRoaXMFAWYEAmJyCQECYWMCBQR0aGlzCQEBdwEFAWkEAmJzCQBkAgUCYnIFAmJsBAJiSgkBAmFjAgUEdGhpcwkBAXcBBQJiSQQCYksJAQJhYwIFBHRoaXMJAQFoAQUCYkkEAmJMCQBkAgUCYkoFAmJLBAJiTQMJAGcCBQJiSQAABgkBAVMBAitwcm9jZXNzVm90ZUlOVEVSTkFMOiBpbnZhbGlkIHByZXZpb3VzIGVwb2NoAwkAAAIFAmJNBQJiTQQBegkBAmFlAQUCYkcEAmJOBQF6BAFCCAUCYk4CXzEEAUMIBQJiTgJfMgQCYkIJAQJheQEFAXoEAmJ5CgACYWIJAPwHBAUEdGhpcwIYZ2V0VXNlckd3eEFtb3VudEF0SGVpZ2h0CQDMCAIFAVAJAMwIAgUCYnMFA25pbAUDbmlsAwkAAQIFAmFiAgNJbnQFAmFiCQACAQkArAICCQADAQUCYWICGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAQCYk8KAAJhYgkA/AcEBQR0aGlzAhhnZXRVc2VyR3d4QW1vdW50QXRIZWlnaHQJAMwIAgUBUAkAzAgCBQJiTAUDbmlsBQNuaWwDCQABAgUCYWICA0ludAUCYWIJAAIBCQCsAgIJAAMBBQJhYgIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50BAJieAkBC3ZhbHVlT3JFbHNlAgkAnwgBCQEBTgEFAWkAAAQCYlAJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBAUgCBQF6BQFpAAAEAmJRCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ8IAQkBAUYDBQF6BQJiZgUCYkkJAQFRAQkArAICCQCsAgIJAKwCAgkArAICAhRwcm9jZXNzVm90ZUlOVEVSTkFMIAUCYkcCASAFAVACEjogbm8gcHJldmlvdXMgdm90ZQQCYnUJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBAUQCBQJiZgUBaQAABAFLCQECYW4CBQFCBQFDBAJiUgkBC3ZhbHVlT3JFbHNlAgkAnwgBCQEBSgIFAUsFAmJJAAAEAmJrCQERQGV4dHJOYXRpdmUoMTA2MikBCQECYWECBQR0aGlzBQFvBAJiUwkBC3ZhbHVlT3JFbHNlAgkAmggCBQJiawkBAU8CBQFLBQFQAAAEAmJUAwkAAAIFAmJTAAAFA25pbAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAUoCBQFLBQJiSQkAZAIFAmJSBQJiUQUDbmlsBAJiQQMJAGYCBQJiTwAACQBrAwUCYlEFAmJ5BQJiTwAABAJiVQMDCQBmAgUCYkEAAAUCYkIHCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBRgMFAXoFAmJmBQFpBQJiQQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAU4BBQFpCQBkAgUCYngFAmJBCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBSAIFAXoFAWkJAGQCBQJiUAUCYkEJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFEAgUCYmYFAWkJAGQCBQJidQUCYkEFA25pbAkBAmFUAgkBAmFEAQUBegUBUAkAlAoCCQDOCAIFAmJVBQJiVAUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJiYgETcHJvY2Vzc1Bvb2xJTlRFUk5BTAICYkcCYlYEAmJICQECYmUBBQJiYgMJAAACBQJiSAUCYkgEAmJXBAJiWAkBAmFjAgUEdGhpcwUBagMFAmJWBQJiWAkAZQIFAmJYAAEEAmJNAwkAZwIFAmJXAAAGCQEBUwECKXByb2Nlc3NQb29sSU5URVJOQUw6IGludmFsaWQgdGFyZ2V0IGVwb2NoAwkAAAIFAmJNBQJiTQQBegkBAmFlAQUCYkcEAmJZBQF6BAFCCAUCYlkCXzEEAUMIBQJiWQJfMgQCYmsJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQJhYQIFBHRoaXMFAW8EAmF4CQECYW4CBQFCBQFDBAJiWgoAAmFiCQD8BwQFAmJrAhJ1c2Vyc0xpc3RUcmF2ZXJzYWwJAMwIAgUCYXgFA25pbAUDbmlsAwkAAQIFAmFiAgdCb29sZWFuBQJhYgkAAgEJAKwCAgkAAwEFAmFiAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuAwkAAAIFAmJaBQJiWgMFAmJaCQCUCgIFA25pbAYEAmJCCQECYXkBBQF6BAJieAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEBTgEFAmJXAAAEAmJQCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQFIAgUBegUCYlcAAAQCY2EDAwkAAAIFAmJ4AAAGCQEBIQEFAmJCAAAJAGsDBQJiUAUBYgUCYngEAmNiCQD8BwQFAmFnAgxtb2RpZnlXZWlnaHQJAMwIAgUCYXgJAMwIAgUCY2EFA25pbAUDbmlsAwkAAAIFAmNiBQJjYgQCY2MDAwUCYkIGBQJiVgUDbmlsCQDOCAIJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAXkBBQF6BQNuaWwJAQJhVAIFAmFDBQJiRwkAlAoCCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFMAgUBegUCYlcFAmNhBQNuaWwFAmNjBwkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJiYgEOZmluYWxpemVIZWxwZXIABAJiVgkBC3ZhbHVlT3JFbHNlAgkAoAgBBQF2BwQBaQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQFqAAAEAmNkCQBlAgUBaQABBAJicgkBAmFjAgUEdGhpcwkBAXcBBQFpBAJibAkBAmFjAgUEdGhpcwUBZgQCYnMJAGQCBQJicgUCYmwEAmJ0CQCaCAIFBHRoaXMFAXADAwMJAGcCBQZoZWlnaHQFAmJzCQAAAgUCYnQFBHVuaXQHCQEBIQEFAmJWBwQCY2UJAGQCBQFpAAEEAmNmCQCaCAIFBHRoaXMFAWcEAmNnBAFYBQJjZgMJAAECBQFYAgNJbnQEAmJFBQFYCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQFmBQJiRQkAzAgCCQELRGVsZXRlRW50cnkBBQFnBQNuaWwDCQABAgUBWAIEVW5pdAUDbmlsCQACAQILTWF0Y2ggZXJyb3IJAJQKAgkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBdwEFAmNlBQZoZWlnaHQJAMwIAgkBDEludGVnZXJFbnRyeQIFAXMFBmhlaWdodAkAzAgCCQEMSW50ZWdlckVudHJ5AgUBagUCY2UJAMwIAgkBDEludGVnZXJFbnRyeQIFAXAFAWQJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFoAQUBaQUCYmwFA25pbAUCY2cGAwMFAmJWCQAAAgUCYnQFBHVuaXQHCQCUCgIJAMwIAgkBDEludGVnZXJFbnRyeQIFAXAFAWUFA25pbAYDCQAAAgUCYnQFBHVuaXQJAJQKAgUDbmlsBwMJAAACBQJidAUBZAQCY2gJAKIIAQUBcQQCY2kJAKIIAQUBcgQBWAUCY2gDCQABAgUBWAIEVW5pdAQCY2oJAKIIAQkBAmFGAQUCYUMDCQABAgUCY2oCBFVuaXQJAJQKAgkAzAgCCQEMSW50ZWdlckVudHJ5AgUBcAUBZQkAzAgCCQELRGVsZXRlRW50cnkBBQFxCQDMCAIJAQtEZWxldGVFbnRyeQEFAXIFA25pbAYDCQABAgUCY2oCBlN0cmluZwQCY2sFAmNqCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgUBcQUCY2sFA25pbAYJAAIBAgtNYXRjaCBlcnJvcgMJAAECBQFYAgZTdHJpbmcEAmJHBQFYBAF6CQECYWUBBQJiRwQCY2wEAmNqBQJjaQMJAAECBQJjagIEVW5pdAkAoggBCQECYUYBCQECYUQBBQF6AwkAAQIFAmNqAgZTdHJpbmcEAmNtBQJjagQCY24JAKIIAQkBAmFMAgkBAmFEAQUBegUCY20DCQAAAgUCY24FAmNuBAJjbwkA/AcEBQR0aGlzAhNwcm9jZXNzVm90ZUlOVEVSTkFMCQDMCAIFAmJHCQDMCAIFAmNtBQNuaWwFA25pbAMJAAACBQJjbwUCY28FAmNuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQILTWF0Y2ggZXJyb3IEAmNqBQJjbAMJAAECBQJjagIEVW5pdAQCY3AJAKIIAQkBAmFMAgUCYUMFAmJHBAJjcQUCY3ADCQABAgUCY3ECBFVuaXQJAJQKAgkAzAgCCQEMSW50ZWdlckVudHJ5AgUBcAUBZQkAzAgCCQELRGVsZXRlRW50cnkBBQFxCQDMCAIJAQtEZWxldGVFbnRyeQEFAXIFA25pbAYDCQABAgUCY3ECBlN0cmluZwQCYVgFAmNxCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgUBcQUCYVgJAMwIAgkBC0RlbGV0ZUVudHJ5AQUBcgUDbmlsBgkAAgECC01hdGNoIGVycm9yAwkAAQIFAmNqAgZTdHJpbmcEAmNyBQJjagkAlAoCCQDMCAIJAQtTdHJpbmdFbnRyeQIFAXIFAmNyBQNuaWwGCQACAQILTWF0Y2ggZXJyb3IJAAIBAgtNYXRjaCBlcnJvcgMJAAACBQJidAUBZQQCY2gJAKIIAQUBcQQBWAUCY2gDCQABAgUBWAIEVW5pdAQCY2oJAKIIAQkBAmFGAQUCYUMDCQABAgUCY2oCBFVuaXQEAmJVAwUCYlYJAMwIAgkBC0RlbGV0ZUVudHJ5AQUBcAkAzAgCCQELRGVsZXRlRW50cnkBBQF2BQNuaWwJAMwIAgkBC0RlbGV0ZUVudHJ5AQUBcAkAzAgCCQEMQm9vbGVhbkVudHJ5AgkBAXgBBQJjZAYJAMwIAgkBDEludGVnZXJFbnRyeQIFAXQFAWkJAMwIAgkBDEludGVnZXJFbnRyeQIFAXUFAmJyBQNuaWwEAmNzCQECYUEAAwkAAAIFAmNzBQJjcwkAlAoCBQJiVQYJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DCQABAgUCY2oCBlN0cmluZwQCY3QFAmNqCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgUBcQUCY3QFA25pbAYJAAIBAgtNYXRjaCBlcnJvcgMJAAECBQFYAgZTdHJpbmcEAmJHBQFYBAJjcAkAoggBCQECYUwCBQJhQwUCYkcDCQAAAgUCY3AFAmNwBAJiWgoAAmFiCQD8BwQFBHRoaXMCE3Byb2Nlc3NQb29sSU5URVJOQUwJAMwIAgUCYkcJAMwIAgUCYlYFA25pbAUDbmlsAwkAAQIFAmFiAgdCb29sZWFuBQJhYgkAAgEJAKwCAgkAAwEFAmFiAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuAwkAAAIFAmJaBQJiWgMFAmJaCQCUCgIFA25pbAYEAmNqBQJjcAMJAAECBQJjagIEVW5pdAQCYlUDBQJiVgkAzAgCCQELRGVsZXRlRW50cnkBBQFwCQDMCAIJAQtEZWxldGVFbnRyeQEFAXYJAMwIAgkBC0RlbGV0ZUVudHJ5AQUBcQUDbmlsCQDMCAIJAQtEZWxldGVFbnRyeQEFAXAJAMwIAgkBDEJvb2xlYW5FbnRyeQIJAQF4AQUCY2QGCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQF0BQFpCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQF1BQJicgkAzAgCCQELRGVsZXRlRW50cnkBBQFxBQNuaWwEAmNzCQECYUEAAwkAAAIFAmNzBQJjcwkAlAoCBQJiVQYJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DCQABAgUCY2oCBlN0cmluZwQCY3QFAmNqCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgUBcQUCY3QFA25pbAYJAAIBAgtNYXRjaCBlcnJvcgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECC01hdGNoIGVycm9yCQEBUwECFmZpbmFsaXphdGlvbiBpcyBicm9rZW4CYmIBD2ZpbmFsaXplV3JhcHBlcgECY3UEAmN2CgACYWIJAPwHBAUEdGhpcwIOZmluYWxpemVIZWxwZXIFA25pbAUDbmlsAwkAAQIFAmFiAgdCb29sZWFuBQJhYgkAAgEJAKwCAgkAAwEFAmFiAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuAwkAAAIFAmN2BQJjdgMJAQEhAQUCY3YDCQAAAgUCY3UAAAkBAVMBAh5DdXJyZW50IHZvdGluZyBpcyBub3Qgb3ZlciB5ZXQJAJQKAgUDbmlsBQR1bml0BAJjdwkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQFrBQFjAwkAZgIFAmN3BQJjdQQCY3gJAPwHBAUEdGhpcwIPZmluYWxpemVXcmFwcGVyCQDMCAIJAGQCBQJjdQABBQNuaWwFA25pbAMJAAACBQJjeAUCY3gJAJQKAgUDbmlsBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQCUCgIFA25pbAUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJiYgEIZmluYWxpemUABAJjeAkA/AcEBQR0aGlzAg9maW5hbGl6ZVdyYXBwZXIJAMwIAgAABQNuaWwFA25pbAMJAAACBQJjeAUCY3gJAJQKAgUDbmlsBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJiARRjb250YWluc05vZGVSRUFET05MWQICYUcCYUsJAJQKAgUDbmlsCQECYU0CBQJhRwUCYUsCYmIBCmluc2VydE5vZGUCAmFHAmFLBAJiSAkBAmJkAQUCYmIDCQAAAgUCYkgFAmJICQCUCgIJAQJhUQIFAmFHBQJhSwUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJiYgEKZGVsZXRlTm9kZQICYUcCYUsEAmJICQECYmQBBQJiYgMJAAACBQJiSAUCYkgJAJQKAgkBAmFUAgUCYUcFAmFLBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJjeQECY3oABAJjQQQBWAkBAmFZAAMJAAECBQFYAgpCeXRlVmVjdG9yBAJiYwUBWAUCYmMDCQABAgUBWAIEVW5pdAgFAmN5D3NlbmRlclB1YmxpY0tleQkAAgECC01hdGNoIGVycm9yCQD0AwMIBQJjeQlib2R5Qnl0ZXMJAJEDAggFAmN5BnByb29mcwAABQJjQX6PrfM=", "height": 2603411, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: Eoz4Z5PLKEWMFDfk3qhyAAGGH2R9woswAGDDgd32o3sz Next: 5kgukao7QtUdYscifwwMwk49TTcjoykra9FMENNFcinL Diff:
Old | New | Differences | |
---|---|---|---|
24 | 24 | ||
25 | 25 | let l = makeString(["%s", "votingEmissionCandidateContract"], a) | |
26 | 26 | ||
27 | - | let m = makeString(["%s", " | |
27 | + | let m = makeString(["%s", "factoryContract"], a) | |
28 | 28 | ||
29 | - | let n = makeString(["%s", " | |
29 | + | let n = makeString(["%s", "boostingContract"], a) | |
30 | 30 | ||
31 | - | let o = makeString(["%s", " | |
31 | + | let o = makeString(["%s", "stakingContract"], a) | |
32 | 32 | ||
33 | - | let p = makeString(["%s", " | |
33 | + | let p = makeString(["%s", "finalizationStage"], a) | |
34 | 34 | ||
35 | - | let q = makeString(["%s", " | |
35 | + | let q = makeString(["%s", "nextPool"], a) | |
36 | 36 | ||
37 | - | let r = makeString(["%s", " | |
37 | + | let r = makeString(["%s", "nextUser"], a) | |
38 | 38 | ||
39 | - | let s = makeString(["%s", " | |
39 | + | let s = makeString(["%s", "startHeight"], a) | |
40 | 40 | ||
41 | - | let t = makeString(["%s", " | |
41 | + | let t = makeString(["%s", "currentEpochUi"], a) | |
42 | 42 | ||
43 | - | let u = makeString(["%s", " | |
43 | + | let u = makeString(["%s", "startHeightUi"], a) | |
44 | 44 | ||
45 | - | let v = makeString(["%s", " | |
45 | + | let v = makeString(["%s", "force"], a) | |
46 | 46 | ||
47 | - | let w = makeString(["%s", "force"], a) | |
48 | - | ||
49 | - | func x (i) = makeString(["%s%d", "startHeight", toString(i)], a) | |
47 | + | func w (i) = makeString(["%s%d", "startHeight", toString(i)], a) | |
50 | 48 | ||
51 | 49 | ||
52 | - | func | |
50 | + | func x (i) = makeString(["%s%d", "finalized", toString(i)], a) | |
53 | 51 | ||
54 | 52 | ||
55 | - | func | |
56 | - | let | |
57 | - | let | |
58 | - | let | |
59 | - | makeString(["%s%s%s", "inList", | |
53 | + | func y (z) = { | |
54 | + | let A = z | |
55 | + | let B = A._1 | |
56 | + | let C = A._2 | |
57 | + | makeString(["%s%s%s", "inList", B, C], a) | |
60 | 58 | } | |
61 | 59 | ||
62 | 60 | ||
63 | - | func | |
61 | + | func D (E,i) = makeString(["%s%s%d", "used", toString(E), toString(i)], a) | |
64 | 62 | ||
65 | 63 | ||
66 | - | func | |
67 | - | let | |
68 | - | let | |
69 | - | let | |
70 | - | makeString(["%s%s%s%s%d", "vote", | |
64 | + | func F (z,E,i) = { | |
65 | + | let G = z | |
66 | + | let B = G._1 | |
67 | + | let C = G._2 | |
68 | + | makeString(["%s%s%s%s%d", "vote", B, C, toString(E), toString(i)], a) | |
71 | 69 | } | |
72 | 70 | ||
73 | 71 | ||
74 | - | func | |
75 | - | let | |
76 | - | let | |
77 | - | let | |
78 | - | makeString(["%s%s%s%d", "votingResult", | |
72 | + | func H (z,i) = { | |
73 | + | let I = z | |
74 | + | let B = I._1 | |
75 | + | let C = I._2 | |
76 | + | makeString(["%s%s%s%d", "votingResult", B, C, toString(i)], a) | |
79 | 77 | } | |
80 | 78 | ||
81 | 79 | ||
82 | - | func | |
80 | + | func J (K,i) = makeString(["%s%s%d", "votingResultStaked", K, toString(i)], a) | |
83 | 81 | ||
84 | 82 | ||
85 | - | func | |
86 | - | let | |
87 | - | let | |
88 | - | let | |
89 | - | makeString(["%s%s%s%d", "poolShare", | |
83 | + | func L (z,i) = { | |
84 | + | let M = z | |
85 | + | let B = M._1 | |
86 | + | let C = M._2 | |
87 | + | makeString(["%s%s%s%d", "poolShare", B, C, toString(i)], a) | |
90 | 88 | } | |
91 | 89 | ||
92 | 90 | ||
93 | - | func | |
91 | + | func N (i) = makeString(["%s%d", "totalVotes", toString(i)], a) | |
94 | 92 | ||
95 | 93 | ||
96 | - | func | |
94 | + | func O (K,P) = makeString(["%s%s%s", "staked", P, K], a) | |
97 | 95 | ||
98 | 96 | ||
99 | - | func | |
97 | + | func Q (R) = makeString(["voting_emission.ride:", R], " ") | |
100 | 98 | ||
101 | 99 | ||
102 | - | func | |
100 | + | func S (R) = throw(Q(R)) | |
103 | 101 | ||
104 | 102 | ||
105 | - | func | |
106 | - | let | |
103 | + | func T (E,U,V) = { | |
104 | + | let W = Q(makeString(["mandatory ", toString(E), ".", U, " is not defined"], "")) | |
107 | 105 | valueOrErrorMessage({ | |
108 | - | let | |
109 | - | if ($isInstanceOf( | |
106 | + | let X = V | |
107 | + | if ($isInstanceOf(X, "String")) | |
110 | 108 | then { | |
111 | - | let | |
112 | - | getString( | |
109 | + | let Y = X | |
110 | + | getString(E, U) | |
113 | 111 | } | |
114 | - | else if ($isInstanceOf( | |
112 | + | else if ($isInstanceOf(X, "Int")) | |
115 | 113 | then { | |
116 | - | let | |
117 | - | getInteger( | |
114 | + | let Z = X | |
115 | + | getInteger(E, U) | |
118 | 116 | } | |
119 | - | else | |
120 | - | }, | |
117 | + | else S("invalid entry type") | |
118 | + | }, W) | |
121 | 119 | } | |
122 | 120 | ||
123 | 121 | ||
124 | - | func | |
125 | - | let | |
126 | - | if ($isInstanceOf( | |
127 | - | then | |
128 | - | else throw(($getType( | |
122 | + | func aa (E,U) = { | |
123 | + | let ab = T(E, U, "") | |
124 | + | if ($isInstanceOf(ab, "String")) | |
125 | + | then ab | |
126 | + | else throw(($getType(ab) + " couldn't be cast to String")) | |
129 | 127 | } | |
130 | 128 | ||
131 | 129 | ||
132 | - | func | |
133 | - | let | |
134 | - | if ($isInstanceOf( | |
135 | - | then | |
136 | - | else throw(($getType( | |
130 | + | func ac (E,U) = { | |
131 | + | let ab = T(E, U, 0) | |
132 | + | if ($isInstanceOf(ab, "Int")) | |
133 | + | then ab | |
134 | + | else throw(($getType(ab) + " couldn't be cast to Int")) | |
137 | 135 | } | |
138 | 136 | ||
139 | 137 | ||
140 | - | func | |
138 | + | func ad (z) = ((z._1 + a) + z._2) | |
141 | 139 | ||
142 | 140 | ||
143 | - | func | |
144 | - | let | |
145 | - | if ((size( | |
146 | - | then $Tuple2( | |
147 | - | else | |
141 | + | func ae (Y) = { | |
142 | + | let af = split(Y, a) | |
143 | + | if ((size(af) == 2)) | |
144 | + | then $Tuple2(af[0], af[1]) | |
145 | + | else S("invalid pool string") | |
148 | 146 | } | |
149 | 147 | ||
150 | 148 | ||
151 | - | let | |
149 | + | let ag = addressFromStringValue(aa(this, m)) | |
152 | 150 | ||
153 | - | let | |
151 | + | let ah = 10 | |
154 | 152 | ||
155 | - | func | |
153 | + | func ai () = "%s__factoryConfig" | |
156 | 154 | ||
157 | 155 | ||
158 | - | func | |
156 | + | func aj (ak) = split(aa(ak, ai()), a) | |
159 | 157 | ||
160 | 158 | ||
161 | - | func | |
159 | + | func al (am) = addressFromStringValue(am[ah]) | |
162 | 160 | ||
163 | 161 | ||
164 | - | func | |
165 | - | func | |
162 | + | func an (B,C) = { | |
163 | + | func ao (ap) = ("%s%s%s__mappings__baseAsset2internalId__" + ap) | |
166 | 164 | ||
167 | - | func | |
165 | + | func aq (ar,as) = (((("%d%d%s%s__" + toString(ar)) + "__") + toString(as)) + "__mappings__poolAssets2PoolContract") | |
168 | 166 | ||
169 | - | func | |
167 | + | func at (au) = (("%s%s%s__" + au) + "__mappings__poolContract2LpAsset") | |
170 | 168 | ||
171 | - | let | |
172 | - | let | |
173 | - | let | |
174 | - | let | |
175 | - | | |
169 | + | let av = ac(ag, ao(B)) | |
170 | + | let aw = ac(ag, ao(C)) | |
171 | + | let au = aa(ag, aq(av, aw)) | |
172 | + | let ax = aa(ag, at(au)) | |
173 | + | ax | |
176 | 174 | } | |
177 | 175 | ||
178 | 176 | ||
179 | - | func | |
180 | - | let | |
181 | - | let | |
182 | - | let | |
183 | - | let | |
184 | - | if ($isInstanceOf( | |
185 | - | then | |
186 | - | else throw(($getType( | |
177 | + | func ay (z) = { | |
178 | + | let az = z | |
179 | + | let B = az._1 | |
180 | + | let C = az._2 | |
181 | + | let ab = invoke(ag, "checkWxEmissionPoolLabel", [B, C], nil) | |
182 | + | if ($isInstanceOf(ab, "Boolean")) | |
183 | + | then ab | |
184 | + | else throw(($getType(ab) + " couldn't be cast to Boolean")) | |
187 | 185 | } | |
188 | 186 | ||
189 | 187 | ||
190 | - | func | |
191 | - | let | |
192 | - | let | |
193 | - | invoke( | |
188 | + | func aA () = { | |
189 | + | let am = aj(ag) | |
190 | + | let aB = al(am) | |
191 | + | invoke(aB, "deposit", nil, nil) | |
194 | 192 | } | |
195 | 193 | ||
196 | 194 | ||
197 | - | let | |
195 | + | let aC = "pools" | |
198 | 196 | ||
199 | - | func | |
200 | - | let | |
201 | - | let | |
202 | - | let | |
203 | - | makeString(["votes", | |
197 | + | func aD (z) = { | |
198 | + | let aE = z | |
199 | + | let B = aE._1 | |
200 | + | let C = aE._2 | |
201 | + | makeString(["votes", B, C], a) | |
204 | 202 | } | |
205 | 203 | ||
206 | 204 | ||
207 | - | func | |
208 | - | let | |
205 | + | func aF (aG) = { | |
206 | + | let aH = if ((aG == aC)) | |
209 | 207 | then "%s%s" | |
210 | 208 | else "%s%s%s%s" | |
211 | - | makeString([ | |
209 | + | makeString([aH, aG, "head"], a) | |
212 | 210 | } | |
213 | 211 | ||
214 | 212 | ||
215 | - | func | |
216 | - | let | |
213 | + | func aI (aG) = { | |
214 | + | let aH = if ((aG == aC)) | |
217 | 215 | then "%s%s" | |
218 | 216 | else "%s%s%s%s" | |
219 | - | makeString([ | |
217 | + | makeString([aH, aG, "size"], a) | |
220 | 218 | } | |
221 | 219 | ||
222 | 220 | ||
223 | - | func | |
224 | - | let | |
221 | + | func aJ (aG,aK) = { | |
222 | + | let aH = if ((aG == aC)) | |
225 | 223 | then "%s%s%s%s" | |
226 | 224 | else "%s%s%s%s%s" | |
227 | - | makeString([ | |
225 | + | makeString([aH, aG, aK, "prev"], a) | |
228 | 226 | } | |
229 | 227 | ||
230 | 228 | ||
231 | - | func | |
232 | - | let | |
229 | + | func aL (aG,aK) = { | |
230 | + | let aH = if ((aG == aC)) | |
233 | 231 | then "%s%s%s%s" | |
234 | 232 | else "%s%s%s%s%s" | |
235 | - | makeString([ | |
233 | + | makeString([aH, aG, aK, "next"], a) | |
236 | 234 | } | |
237 | 235 | ||
238 | 236 | ||
239 | - | func | |
240 | - | let | |
241 | - | let | |
242 | - | let | |
243 | - | if (if (( | |
237 | + | func aM (aG,aK) = { | |
238 | + | let aN = getString(this, aF(aG)) | |
239 | + | let aO = getString(this, aJ(aG, aK)) | |
240 | + | let aP = getString(this, aL(aG, aK)) | |
241 | + | if (if ((aK == valueOrElse(aN, ""))) | |
244 | 242 | then true | |
245 | - | else ( | |
243 | + | else (aO != unit)) | |
246 | 244 | then true | |
247 | - | else ( | |
245 | + | else (aP != unit) | |
248 | 246 | } | |
249 | 247 | ||
250 | 248 | ||
251 | - | func | |
252 | - | let | |
253 | - | let | |
254 | - | let | |
249 | + | func aQ (aG,aK) = { | |
250 | + | let aN = getString(this, aF(aG)) | |
251 | + | let aR = valueOrElse(getInteger(this, aI(aG)), 0) | |
252 | + | let aS = if (!(aM(aG, aK))) | |
255 | 253 | then true | |
256 | - | else | |
257 | - | if (( | |
258 | - | then (([IntegerEntry( | |
259 | - | then [StringEntry( | |
260 | - | else nil)) ++ [StringEntry(aG | |
254 | + | else S("Node exists") | |
255 | + | if ((aS == aS)) | |
256 | + | then (([IntegerEntry(aI(aG), (aR + 1))] ++ (if ((aN != unit)) | |
257 | + | then [StringEntry(aL(aG, aK), value(aN)), StringEntry(aJ(aG, value(aN)), aK)] | |
258 | + | else nil)) ++ [StringEntry(aF(aG), aK)]) | |
261 | 259 | else throw("Strict value is not equal to itself.") | |
262 | 260 | } | |
263 | 261 | ||
264 | 262 | ||
265 | - | func | |
266 | - | let | |
267 | - | let | |
268 | - | let | |
269 | - | let | |
270 | - | ([IntegerEntry( | |
271 | - | then ( | |
263 | + | func aT (aG,aK) = { | |
264 | + | let aN = getString(this, aF(aG)) | |
265 | + | let aR = valueOrElse(getInteger(this, aI(aG)), 0) | |
266 | + | let aO = getString(this, aJ(aG, aK)) | |
267 | + | let aP = getString(this, aL(aG, aK)) | |
268 | + | ([IntegerEntry(aI(aG), (aR - 1))] ++ (if (if ((aO != unit)) | |
269 | + | then (aP != unit) | |
272 | 270 | else false) | |
273 | - | then [StringEntry( | |
274 | - | else if (( | |
275 | - | then [StringEntry(aG | |
276 | - | else if (( | |
277 | - | then [DeleteEntry( | |
278 | - | else if (( | |
279 | - | then [DeleteEntry(aG | |
280 | - | else | |
271 | + | then [StringEntry(aL(aG, value(aO)), value(aP)), StringEntry(aJ(aG, value(aP)), value(aO)), DeleteEntry(aJ(aG, aK)), DeleteEntry(aL(aG, aK))] | |
272 | + | else if ((aP != unit)) | |
273 | + | then [StringEntry(aF(aG), value(aP)), DeleteEntry(aL(aG, aK)), DeleteEntry(aJ(aG, value(aP)))] | |
274 | + | else if ((aO != unit)) | |
275 | + | then [DeleteEntry(aJ(aG, aK)), DeleteEntry(aL(aG, value(aO)))] | |
276 | + | else if ((aK == valueOrElse(aN, ""))) | |
277 | + | then [DeleteEntry(aF(aG))] | |
278 | + | else S(((("invalid node: " + aG) + ".") + aK)))) | |
281 | 279 | } | |
282 | 280 | ||
283 | 281 | ||
284 | - | func | |
282 | + | func aU () = "%s__managerVaultAddress" | |
285 | 283 | ||
286 | 284 | ||
287 | - | func | |
285 | + | func aV () = "%s__managerPublicKey" | |
288 | 286 | ||
289 | 287 | ||
290 | - | func | |
291 | - | let | |
292 | - | if ($isInstanceOf( | |
288 | + | func aW () = { | |
289 | + | let X = getString(aU()) | |
290 | + | if ($isInstanceOf(X, "String")) | |
293 | 291 | then { | |
294 | - | let | |
295 | - | addressFromStringValue( | |
292 | + | let aX = X | |
293 | + | addressFromStringValue(aX) | |
296 | 294 | } | |
297 | 295 | else this | |
298 | 296 | } | |
299 | 297 | ||
300 | 298 | ||
301 | - | func | |
302 | - | let | |
303 | - | let | |
304 | - | if ($isInstanceOf( | |
299 | + | func aY () = { | |
300 | + | let aZ = aW() | |
301 | + | let X = getString(aZ, aV()) | |
302 | + | if ($isInstanceOf(X, "String")) | |
305 | 303 | then { | |
306 | - | let | |
307 | - | fromBase58String( | |
304 | + | let aX = X | |
305 | + | fromBase58String(aX) | |
308 | 306 | } | |
309 | - | else if ($isInstanceOf( | |
307 | + | else if ($isInstanceOf(X, "Unit")) | |
310 | 308 | then unit | |
311 | 309 | else throw("Match error") | |
312 | 310 | } | |
313 | 311 | ||
314 | 312 | ||
315 | - | func | |
316 | - | let | |
317 | - | if ($isInstanceOf( | |
313 | + | func ba (bb) = { | |
314 | + | let X = aY() | |
315 | + | if ($isInstanceOf(X, "ByteVector")) | |
318 | 316 | then { | |
319 | - | let | |
320 | - | ( | |
317 | + | let bc = X | |
318 | + | (bb.callerPublicKey == bc) | |
321 | 319 | } | |
322 | - | else if ($isInstanceOf( | |
323 | - | then ( | |
320 | + | else if ($isInstanceOf(X, "Unit")) | |
321 | + | then (bb.caller == this) | |
324 | 322 | else throw("Match error") | |
325 | 323 | } | |
326 | 324 | ||
327 | 325 | ||
328 | - | func | |
326 | + | func bd (bb) = if (ba(bb)) | |
329 | 327 | then true | |
330 | 328 | else throw("permission denied") | |
331 | 329 | ||
332 | 330 | ||
333 | - | func | |
331 | + | func be (bb) = if ((bb.caller == this)) | |
334 | 332 | then true | |
335 | 333 | else throw("permission denied") | |
336 | 334 | ||
337 | 335 | ||
338 | - | @Callable( | |
339 | - | func getUserGwxAmountAtHeight (bg | |
340 | - | let | |
336 | + | @Callable(bb) | |
337 | + | func getUserGwxAmountAtHeight (bf,bg) = { | |
338 | + | let bh = valueOrErrorMessage(addressFromString(aa(this, n)), Q("invalid boosting contract address")) | |
341 | 339 | $Tuple2(nil, { | |
342 | - | let | |
343 | - | if ($isInstanceOf( | |
344 | - | then | |
345 | - | else throw(($getType( | |
340 | + | let ab = invoke(bh, "getUserGwxAmountAtHeightREADONLY", [bf, bg], nil) | |
341 | + | if ($isInstanceOf(ab, "Int")) | |
342 | + | then ab | |
343 | + | else throw(($getType(ab) + " couldn't be cast to Int")) | |
346 | 344 | }) | |
347 | 345 | } | |
348 | 346 | ||
349 | 347 | ||
350 | 348 | ||
351 | - | @Callable( | |
352 | - | func constructor ( | |
353 | - | let | |
349 | + | @Callable(bb) | |
350 | + | func constructor (ag,bi,bj,bk,bl) = { | |
351 | + | let bm = [bd(bb), if ((addressFromString(ag) != unit)) | |
354 | 352 | then true | |
355 | - | else "invalid factory contract address", if ((addressFromString( | |
353 | + | else "invalid factory contract address", if ((addressFromString(bi) != unit)) | |
356 | 354 | then true | |
357 | - | else "invalid voting emission candidate contract address", if ((addressFromString( | |
355 | + | else "invalid voting emission candidate contract address", if ((addressFromString(bj) != unit)) | |
358 | 356 | then true | |
359 | - | else "invalid boosting contract address", if ((addressFromString( | |
357 | + | else "invalid boosting contract address", if ((addressFromString(bk) != unit)) | |
360 | 358 | then true | |
361 | - | else "invalid staking contract address", if (( | |
359 | + | else "invalid staking contract address", if ((bl > 0)) | |
362 | 360 | then true | |
363 | - | else | |
364 | - | if (( | |
365 | - | then $Tuple2([StringEntry( | |
361 | + | else S("invalid epoch length")] | |
362 | + | if ((bm == bm)) | |
363 | + | then $Tuple2([StringEntry(m, ag), StringEntry(l, bi), StringEntry(n, bj), StringEntry(o, bk), IntegerEntry(f, bl)], unit) | |
366 | 364 | else throw("Strict value is not equal to itself.") | |
367 | 365 | } | |
368 | 366 | ||
369 | 367 | ||
370 | 368 | ||
371 | - | @Callable( | |
372 | - | func create (C | |
373 | - | let | |
369 | + | @Callable(bb) | |
370 | + | func create (B,C) = { | |
371 | + | let bm = [if ((toBase58String(bb.caller.bytes) == valueOrElse(getString(this, l), ""))) | |
374 | 372 | then true | |
375 | - | else | |
376 | - | if (( | |
373 | + | else bd(bb)] | |
374 | + | if ((bm == bm)) | |
377 | 375 | then { | |
378 | - | let | |
379 | - | let | |
380 | - | let | |
381 | - | let | |
376 | + | let z = $Tuple2(B, C) | |
377 | + | let bn = ([BooleanEntry(y(z), true)] ++ aQ(aC, ad(z))) | |
378 | + | let bo = (getInteger(this, j) == unit) | |
379 | + | let bp = if (bo) | |
382 | 380 | then { | |
383 | 381 | let i = 0 | |
384 | - | [IntegerEntry(j, i), IntegerEntry( | |
382 | + | [IntegerEntry(j, i), IntegerEntry(w(i), height), IntegerEntry(s, height), IntegerEntry(t, i), IntegerEntry(u, height)] | |
385 | 383 | } | |
386 | 384 | else nil | |
387 | - | $Tuple2(( | |
385 | + | $Tuple2((bn ++ bp), unit) | |
388 | 386 | } | |
389 | 387 | else throw("Strict value is not equal to itself.") | |
390 | 388 | } | |
391 | 389 | ||
392 | 390 | ||
393 | 391 | ||
394 | - | @Callable( | |
395 | - | func vote (C, | |
396 | - | let | |
392 | + | @Callable(bb) | |
393 | + | func vote (B,C,bq) = { | |
394 | + | let z = $Tuple2(B, C) | |
397 | 395 | let i = valueOrElse(getInteger(this, j), 0) | |
398 | - | let | |
399 | - | let | |
400 | - | let | |
401 | - | let | |
402 | - | let | |
403 | - | let | |
404 | - | let | |
405 | - | let | |
406 | - | let | |
407 | - | let | |
408 | - | if ($isInstanceOf( | |
409 | - | then | |
410 | - | else throw(($getType( | |
396 | + | let br = ac(this, w(i)) | |
397 | + | let bl = ac(this, f) | |
398 | + | let bs = (br + bl) | |
399 | + | let bt = getInteger(this, p) | |
400 | + | let bu = valueOrElse(getInteger(this, D(bb.caller, i)), 0) | |
401 | + | let bv = valueOrElse(getInteger(this, F(z, bb.caller, i)), 0) | |
402 | + | let bw = valueOrElse(getInteger(this, H(z, i)), 0) | |
403 | + | let bx = valueOrElse(getInteger(this, N(i)), 0) | |
404 | + | let by = { | |
405 | + | let ab = invoke(this, "getUserGwxAmountAtHeight", [toBase58String(bb.caller.bytes), bs], nil) | |
406 | + | if ($isInstanceOf(ab, "Int")) | |
407 | + | then ab | |
408 | + | else throw(($getType(ab) + " couldn't be cast to Int")) | |
411 | 409 | } | |
412 | - | let | |
413 | - | let | |
414 | - | let | |
415 | - | let | |
410 | + | let bz = (by - bu) | |
411 | + | let bA = (bv + bq) | |
412 | + | let bB = ay(z) | |
413 | + | let bm = [if ((getBoolean(y(z)) != unit)) | |
416 | 414 | then true | |
417 | - | else | |
415 | + | else S("invalid assets"), if ((bs > height)) | |
418 | 416 | then true | |
419 | - | else | |
417 | + | else S("invalid height"), if ((bt == unit)) | |
420 | 418 | then true | |
421 | - | else | |
419 | + | else S("finalization in progress"), if ((by > 0)) | |
422 | 420 | then true | |
423 | - | else | |
424 | - | then ( | |
421 | + | else S("you do not have gWX"), if (if ((bq > 0)) | |
422 | + | then (bz >= bq) | |
425 | 423 | else false) | |
426 | 424 | then true | |
427 | - | else | |
425 | + | else S("invalid amount"), if (bB) | |
428 | 426 | then true | |
429 | - | else | |
430 | - | if (( | |
427 | + | else S("pool hasn't WX_EMISSION label")] | |
428 | + | if ((bm == bm)) | |
431 | 429 | then { | |
432 | - | let | |
433 | - | let | |
434 | - | let | |
430 | + | let bC = aD(z) | |
431 | + | let P = toString(bb.caller) | |
432 | + | let bD = if (aM(bC, P)) | |
435 | 433 | then nil | |
436 | - | else | |
437 | - | $Tuple2(([IntegerEntry( | |
434 | + | else aQ(bC, P) | |
435 | + | $Tuple2(([IntegerEntry(D(bb.caller, i), (bu + bq)), IntegerEntry(F(z, bb.caller, i), bA), IntegerEntry(H(z, i), (bw + bq)), IntegerEntry(N(i), (bx + bq))] ++ bD), unit) | |
438 | 436 | } | |
439 | 437 | else throw("Strict value is not equal to itself.") | |
440 | 438 | } | |
441 | 439 | ||
442 | 440 | ||
443 | 441 | ||
444 | - | @Callable( | |
445 | - | func cancelVote (C | |
446 | - | let | |
442 | + | @Callable(bb) | |
443 | + | func cancelVote (B,C) = { | |
444 | + | let z = $Tuple2(B, C) | |
447 | 445 | let i = valueOrElse(getInteger(this, j), 0) | |
448 | - | let | |
449 | - | let | |
450 | - | let | |
451 | - | let | |
452 | - | let | |
453 | - | let | |
454 | - | let | |
455 | - | let | |
456 | - | let | |
446 | + | let br = ac(this, w(i)) | |
447 | + | let bl = ac(this, f) | |
448 | + | let bs = (br + bl) | |
449 | + | let bt = getInteger(this, p) | |
450 | + | let bu = valueOrElse(getInteger(this, D(bb.caller, i)), 0) | |
451 | + | let bv = valueOrElse(getInteger(this, F(z, bb.caller, i)), 0) | |
452 | + | let bw = valueOrElse(getInteger(this, H(z, i)), 0) | |
453 | + | let bx = valueOrElse(getInteger(this, N(i)), 0) | |
454 | + | let bm = [if ((getBoolean(y(z)) != unit)) | |
457 | 455 | then true | |
458 | - | else | |
456 | + | else S("invalid assets"), if ((bs > height)) | |
459 | 457 | then true | |
460 | - | else | |
458 | + | else S("invalid height"), if ((bt == unit)) | |
461 | 459 | then true | |
462 | - | else | |
460 | + | else S("finalization in progress"), if ((bv > 0)) | |
463 | 461 | then true | |
464 | - | else | |
465 | - | if (( | |
462 | + | else S("no vote")] | |
463 | + | if ((bm == bm)) | |
466 | 464 | then { | |
467 | - | let | |
468 | - | let | |
469 | - | $Tuple2(([IntegerEntry( | |
465 | + | let bC = aD(z) | |
466 | + | let P = toString(bb.caller) | |
467 | + | $Tuple2(([IntegerEntry(D(bb.caller, i), max([(bu - bv), 0])), DeleteEntry(F(z, bb.caller, i)), IntegerEntry(H(z, i), (bw - bv)), IntegerEntry(N(i), (bx - bv))] ++ aT(bC, P)), unit) | |
470 | 468 | } | |
471 | 469 | else throw("Strict value is not equal to itself.") | |
472 | 470 | } | |
473 | 471 | ||
474 | 472 | ||
475 | 473 | ||
476 | - | @Callable( | |
477 | - | func setEpochLength ( | |
478 | - | let | |
474 | + | @Callable(bb) | |
475 | + | func setEpochLength (bE) = { | |
476 | + | let bm = [bd(bb), if ((bE > 0)) | |
479 | 477 | then true | |
480 | - | else | |
481 | - | if (( | |
482 | - | then $Tuple2([IntegerEntry(g, | |
478 | + | else S("invalid epoch length")] | |
479 | + | if ((bm == bm)) | |
480 | + | then $Tuple2([IntegerEntry(g, bE)], unit) | |
483 | 481 | else throw("Strict value is not equal to itself.") | |
484 | 482 | } | |
485 | 483 | ||
486 | 484 | ||
487 | 485 | ||
488 | - | @Callable( | |
489 | - | func setMaxDepth ( | |
490 | - | let | |
486 | + | @Callable(bb) | |
487 | + | func setMaxDepth (bF) = { | |
488 | + | let bm = [bd(bb), if ((bF > 0)) | |
491 | 489 | then true | |
492 | - | else | |
493 | - | if (( | |
494 | - | then $Tuple2([IntegerEntry(k, | |
490 | + | else S("invalid max depth")] | |
491 | + | if ((bm == bm)) | |
492 | + | then $Tuple2([IntegerEntry(k, bF)], unit) | |
495 | 493 | else throw("Strict value is not equal to itself.") | |
496 | 494 | } | |
497 | 495 | ||
498 | 496 | ||
499 | 497 | ||
500 | - | @Callable( | |
501 | - | func processVoteINTERNAL ( | |
502 | - | let | |
503 | - | if (( | |
498 | + | @Callable(bb) | |
499 | + | func processVoteINTERNAL (bG,P) = { | |
500 | + | let bH = be(bb) | |
501 | + | if ((bH == bH)) | |
504 | 502 | then { | |
505 | - | let | |
506 | - | let i = | |
507 | - | let | |
508 | - | let | |
509 | - | let | |
510 | - | let | |
511 | - | let | |
512 | - | let | |
513 | - | let | |
514 | - | let | |
503 | + | let bf = valueOrErrorMessage(addressFromString(P), Q(("processVoteINTERNAL: invalid user address " + P))) | |
504 | + | let i = ac(this, j) | |
505 | + | let bI = (i - 1) | |
506 | + | let bl = ac(this, f) | |
507 | + | let br = ac(this, w(i)) | |
508 | + | let bs = (br + bl) | |
509 | + | let bJ = ac(this, w(bI)) | |
510 | + | let bK = ac(this, h(bI)) | |
511 | + | let bL = (bJ + bK) | |
512 | + | let bM = if ((bI >= 0)) | |
515 | 513 | then true | |
516 | - | else | |
517 | - | if (( | |
514 | + | else S("processVoteINTERNAL: invalid previous epoch") | |
515 | + | if ((bM == bM)) | |
518 | 516 | then { | |
519 | - | let | |
520 | - | let | |
521 | - | let | |
522 | - | let | |
523 | - | let | |
524 | - | let | |
525 | - | let | |
526 | - | if ($isInstanceOf( | |
527 | - | then | |
528 | - | else throw(($getType( | |
517 | + | let z = ae(bG) | |
518 | + | let bN = z | |
519 | + | let B = bN._1 | |
520 | + | let C = bN._2 | |
521 | + | let bB = ay(z) | |
522 | + | let by = { | |
523 | + | let ab = invoke(this, "getUserGwxAmountAtHeight", [P, bs], nil) | |
524 | + | if ($isInstanceOf(ab, "Int")) | |
525 | + | then ab | |
526 | + | else throw(($getType(ab) + " couldn't be cast to Int")) | |
529 | 527 | } | |
530 | - | let | |
531 | - | let | |
532 | - | if ($isInstanceOf( | |
533 | - | then | |
534 | - | else throw(($getType( | |
528 | + | let bO = { | |
529 | + | let ab = invoke(this, "getUserGwxAmountAtHeight", [P, bL], nil) | |
530 | + | if ($isInstanceOf(ab, "Int")) | |
531 | + | then ab | |
532 | + | else throw(($getType(ab) + " couldn't be cast to Int")) | |
535 | 533 | } | |
536 | - | let | |
537 | - | let | |
538 | - | let | |
539 | - | let | |
540 | - | let | |
541 | - | let | |
542 | - | let | |
543 | - | let | |
544 | - | let | |
534 | + | let bx = valueOrElse(getInteger(N(i)), 0) | |
535 | + | let bP = valueOrElse(getInteger(H(z, i)), 0) | |
536 | + | let bQ = valueOrErrorMessage(getInteger(F(z, bf, bI)), Q((((("processVoteINTERNAL " + bG) + " ") + P) + ": no previous vote"))) | |
537 | + | let bu = valueOrElse(getInteger(this, D(bf, i)), 0) | |
538 | + | let K = an(B, C) | |
539 | + | let bR = valueOrElse(getInteger(J(K, bI)), 0) | |
540 | + | let bk = addressFromStringValue(aa(this, o)) | |
541 | + | let bS = valueOrElse(getInteger(bk, O(K, P)), 0) | |
542 | + | let bT = if ((bS == 0)) | |
545 | 543 | then nil | |
546 | - | else [IntegerEntry(K | |
547 | - | let | |
548 | - | then fraction( | |
544 | + | else [IntegerEntry(J(K, bI), (bR + bQ))] | |
545 | + | let bA = if ((bO > 0)) | |
546 | + | then fraction(bQ, by, bO) | |
549 | 547 | else 0 | |
550 | - | let | |
551 | - | then | |
548 | + | let bU = if (if ((bA > 0)) | |
549 | + | then bB | |
552 | 550 | else false) | |
553 | - | then [IntegerEntry( | |
554 | - | else | |
555 | - | $Tuple2(( | |
551 | + | then [IntegerEntry(F(z, bf, i), bA), IntegerEntry(N(i), (bx + bA)), IntegerEntry(H(z, i), (bP + bA)), IntegerEntry(D(bf, i), (bu + bA))] | |
552 | + | else aT(aD(z), P) | |
553 | + | $Tuple2((bU ++ bT), unit) | |
556 | 554 | } | |
557 | 555 | else throw("Strict value is not equal to itself.") | |
558 | 556 | } | |
561 | 559 | ||
562 | 560 | ||
563 | 561 | ||
564 | - | @Callable( | |
565 | - | func processPoolINTERNAL ( | |
566 | - | let | |
567 | - | if (( | |
562 | + | @Callable(bb) | |
563 | + | func processPoolINTERNAL (bG,bV) = { | |
564 | + | let bH = be(bb) | |
565 | + | if ((bH == bH)) | |
568 | 566 | then { | |
569 | - | let | |
570 | - | let | |
571 | - | if ( | |
572 | - | then | |
573 | - | else ( | |
567 | + | let bW = { | |
568 | + | let bX = ac(this, j) | |
569 | + | if (bV) | |
570 | + | then bX | |
571 | + | else (bX - 1) | |
574 | 572 | } | |
575 | - | let | |
573 | + | let bM = if ((bW >= 0)) | |
576 | 574 | then true | |
577 | - | else | |
578 | - | if (( | |
575 | + | else S("processPoolINTERNAL: invalid target epoch") | |
576 | + | if ((bM == bM)) | |
579 | 577 | then { | |
580 | - | let | |
581 | - | let | |
582 | - | let | |
583 | - | let | |
584 | - | let | |
585 | - | let | |
586 | - | let | |
587 | - | let | |
588 | - | if ($isInstanceOf( | |
589 | - | then | |
590 | - | else throw(($getType( | |
578 | + | let z = ae(bG) | |
579 | + | let bY = z | |
580 | + | let B = bY._1 | |
581 | + | let C = bY._2 | |
582 | + | let bk = addressFromStringValue(aa(this, o)) | |
583 | + | let ax = an(B, C) | |
584 | + | let bZ = { | |
585 | + | let ab = invoke(bk, "usersListTraversal", [ax], nil) | |
586 | + | if ($isInstanceOf(ab, "Boolean")) | |
587 | + | then ab | |
588 | + | else throw(($getType(ab) + " couldn't be cast to Boolean")) | |
591 | 589 | } | |
592 | - | if (( | |
593 | - | then if ( | |
590 | + | if ((bZ == bZ)) | |
591 | + | then if (bZ) | |
594 | 592 | then $Tuple2(nil, true) | |
595 | 593 | else { | |
596 | - | let | |
597 | - | let | |
598 | - | let | |
599 | - | let | |
594 | + | let bB = ay(z) | |
595 | + | let bx = valueOrElse(getInteger(this, N(bW)), 0) | |
596 | + | let bP = valueOrElse(getInteger(this, H(z, bW)), 0) | |
597 | + | let ca = if (if ((bx == 0)) | |
600 | 598 | then true | |
601 | - | else !( | |
599 | + | else !(bB)) | |
602 | 600 | then 0 | |
603 | - | else fraction( | |
604 | - | let | |
605 | - | if (( | |
601 | + | else fraction(bP, b, bx) | |
602 | + | let cb = invoke(ag, "modifyWeight", [ax, ca], nil) | |
603 | + | if ((cb == cb)) | |
606 | 604 | then { | |
607 | - | let | |
605 | + | let cc = if (if (bB) | |
608 | 606 | then true | |
609 | - | else | |
607 | + | else bV) | |
610 | 608 | then nil | |
611 | - | else ([DeleteEntry(z | |
612 | - | $Tuple2(([IntegerEntry( | |
609 | + | else ([DeleteEntry(y(z))] ++ aT(aC, bG)) | |
610 | + | $Tuple2(([IntegerEntry(L(z, bW), ca)] ++ cc), false) | |
613 | 611 | } | |
614 | 612 | else throw("Strict value is not equal to itself.") | |
615 | 613 | } | |
622 | 620 | ||
623 | 621 | ||
624 | 622 | ||
625 | - | @Callable( | |
623 | + | @Callable(bb) | |
626 | 624 | func finalizeHelper () = { | |
627 | - | let | |
625 | + | let bV = valueOrElse(getBoolean(v), false) | |
628 | 626 | let i = valueOrElse(getInteger(this, j), 0) | |
629 | - | let | |
630 | - | let | |
631 | - | let | |
632 | - | let | |
633 | - | let | |
634 | - | if (if (if ((height >= | |
635 | - | then ( | |
627 | + | let cd = (i - 1) | |
628 | + | let br = ac(this, w(i)) | |
629 | + | let bl = ac(this, f) | |
630 | + | let bs = (br + bl) | |
631 | + | let bt = getInteger(this, p) | |
632 | + | if (if (if ((height >= bs)) | |
633 | + | then (bt == unit) | |
636 | 634 | else false) | |
637 | - | then !( | |
635 | + | then !(bV) | |
638 | 636 | else false) | |
639 | 637 | then { | |
640 | - | let | |
641 | - | let | |
642 | - | let | |
643 | - | let | |
644 | - | if ($isInstanceOf( | |
638 | + | let ce = (i + 1) | |
639 | + | let cf = getInteger(this, g) | |
640 | + | let cg = { | |
641 | + | let X = cf | |
642 | + | if ($isInstanceOf(X, "Int")) | |
645 | 643 | then { | |
646 | - | let | |
647 | - | [IntegerEntry(f, | |
644 | + | let bE = X | |
645 | + | [IntegerEntry(f, bE), DeleteEntry(g)] | |
648 | 646 | } | |
649 | - | else if ($isInstanceOf( | |
647 | + | else if ($isInstanceOf(X, "Unit")) | |
650 | 648 | then nil | |
651 | 649 | else throw("Match error") | |
652 | 650 | } | |
653 | - | $Tuple2(([IntegerEntry( | |
651 | + | $Tuple2(([IntegerEntry(w(ce), height), IntegerEntry(s, height), IntegerEntry(j, ce), IntegerEntry(p, d), IntegerEntry(h(i), bl)] ++ cg), true) | |
654 | 652 | } | |
655 | - | else if (if ( | |
656 | - | then ( | |
653 | + | else if (if (bV) | |
654 | + | then (bt == unit) | |
657 | 655 | else false) | |
658 | - | then $Tuple2([IntegerEntry( | |
659 | - | else if (( | |
656 | + | then $Tuple2([IntegerEntry(p, e)], true) | |
657 | + | else if ((bt == unit)) | |
660 | 658 | then $Tuple2(nil, false) | |
661 | - | else if (( | |
659 | + | else if ((bt == d)) | |
662 | 660 | then { | |
661 | + | let ch = getString(q) | |
663 | 662 | let ci = getString(r) | |
664 | - | let cj = getString(s) | |
665 | - | let Y = ci | |
666 | - | if ($isInstanceOf(Y, "Unit")) | |
663 | + | let X = ch | |
664 | + | if ($isInstanceOf(X, "Unit")) | |
667 | 665 | then { | |
668 | - | let | |
669 | - | if ($isInstanceOf( | |
670 | - | then $Tuple2([IntegerEntry( | |
671 | - | else if ($isInstanceOf( | |
666 | + | let cj = getString(aF(aC)) | |
667 | + | if ($isInstanceOf(cj, "Unit")) | |
668 | + | then $Tuple2([IntegerEntry(p, e), DeleteEntry(q), DeleteEntry(r)], true) | |
669 | + | else if ($isInstanceOf(cj, "String")) | |
672 | 670 | then { | |
673 | - | let | |
674 | - | $Tuple2([StringEntry( | |
671 | + | let ck = cj | |
672 | + | $Tuple2([StringEntry(q, ck)], true) | |
675 | 673 | } | |
676 | 674 | else throw("Match error") | |
677 | 675 | } | |
678 | - | else if ($isInstanceOf( | |
676 | + | else if ($isInstanceOf(X, "String")) | |
679 | 677 | then { | |
680 | - | let | |
681 | - | let | |
682 | - | let | |
683 | - | let | |
684 | - | if ($isInstanceOf( | |
685 | - | then getString( | |
686 | - | else if ($isInstanceOf( | |
678 | + | let bG = X | |
679 | + | let z = ae(bG) | |
680 | + | let cl = { | |
681 | + | let cj = ci | |
682 | + | if ($isInstanceOf(cj, "Unit")) | |
683 | + | then getString(aF(aD(z))) | |
684 | + | else if ($isInstanceOf(cj, "String")) | |
687 | 685 | then { | |
688 | - | let | |
689 | - | let | |
690 | - | if (( | |
686 | + | let cm = cj | |
687 | + | let cn = getString(aL(aD(z), cm)) | |
688 | + | if ((cn == cn)) | |
691 | 689 | then { | |
692 | - | let | |
693 | - | if (( | |
694 | - | then | |
690 | + | let co = invoke(this, "processVoteINTERNAL", [bG, cm], nil) | |
691 | + | if ((co == co)) | |
692 | + | then cn | |
695 | 693 | else throw("Strict value is not equal to itself.") | |
696 | 694 | } | |
697 | 695 | else throw("Strict value is not equal to itself.") | |
698 | 696 | } | |
699 | 697 | else throw("Match error") | |
700 | 698 | } | |
701 | - | let | |
702 | - | if ($isInstanceOf( | |
699 | + | let cj = cl | |
700 | + | if ($isInstanceOf(cj, "Unit")) | |
703 | 701 | then { | |
704 | - | let | |
705 | - | let | |
706 | - | if ($isInstanceOf( | |
707 | - | then $Tuple2([IntegerEntry( | |
708 | - | else if ($isInstanceOf( | |
702 | + | let cp = getString(aL(aC, bG)) | |
703 | + | let cq = cp | |
704 | + | if ($isInstanceOf(cq, "Unit")) | |
705 | + | then $Tuple2([IntegerEntry(p, e), DeleteEntry(q), DeleteEntry(r)], true) | |
706 | + | else if ($isInstanceOf(cq, "String")) | |
709 | 707 | then { | |
710 | - | let | |
711 | - | $Tuple2([StringEntry( | |
708 | + | let aX = cq | |
709 | + | $Tuple2([StringEntry(q, aX), DeleteEntry(r)], true) | |
712 | 710 | } | |
713 | 711 | else throw("Match error") | |
714 | 712 | } | |
715 | - | else if ($isInstanceOf( | |
713 | + | else if ($isInstanceOf(cj, "String")) | |
716 | 714 | then { | |
717 | - | let | |
718 | - | $Tuple2([StringEntry( | |
715 | + | let cr = cj | |
716 | + | $Tuple2([StringEntry(r, cr)], true) | |
719 | 717 | } | |
720 | 718 | else throw("Match error") | |
721 | 719 | } | |
722 | 720 | else throw("Match error") | |
723 | 721 | } | |
724 | - | else if (( | |
722 | + | else if ((bt == e)) | |
725 | 723 | then { | |
726 | - | let | |
727 | - | let | |
728 | - | if ($isInstanceOf( | |
724 | + | let ch = getString(q) | |
725 | + | let X = ch | |
726 | + | if ($isInstanceOf(X, "Unit")) | |
729 | 727 | then { | |
730 | - | let | |
731 | - | if ($isInstanceOf( | |
728 | + | let cj = getString(aF(aC)) | |
729 | + | if ($isInstanceOf(cj, "Unit")) | |
732 | 730 | then { | |
733 | - | let | |
734 | - | then [DeleteEntry( | |
735 | - | else [DeleteEntry( | |
736 | - | let | |
737 | - | if (( | |
738 | - | then $Tuple2( | |
731 | + | let bU = if (bV) | |
732 | + | then [DeleteEntry(p), DeleteEntry(v)] | |
733 | + | else [DeleteEntry(p), BooleanEntry(x(cd), true), IntegerEntry(t, i), IntegerEntry(u, br)] | |
734 | + | let cs = aA() | |
735 | + | if ((cs == cs)) | |
736 | + | then $Tuple2(bU, true) | |
739 | 737 | else throw("Strict value is not equal to itself.") | |
740 | 738 | } | |
741 | - | else if ($isInstanceOf( | |
739 | + | else if ($isInstanceOf(cj, "String")) | |
742 | 740 | then { | |
743 | - | let | |
744 | - | $Tuple2([StringEntry( | |
741 | + | let ct = cj | |
742 | + | $Tuple2([StringEntry(q, ct)], true) | |
745 | 743 | } | |
746 | 744 | else throw("Match error") | |
747 | 745 | } | |
748 | - | else if ($isInstanceOf( | |
746 | + | else if ($isInstanceOf(X, "String")) | |
749 | 747 | then { | |
750 | - | let | |
751 | - | let | |
752 | - | if (( | |
748 | + | let bG = X | |
749 | + | let cp = getString(aL(aC, bG)) | |
750 | + | if ((cp == cp)) | |
753 | 751 | then { | |
754 | - | let | |
755 | - | let | |
756 | - | if ($isInstanceOf( | |
757 | - | then | |
758 | - | else throw(($getType( | |
752 | + | let bZ = { | |
753 | + | let ab = invoke(this, "processPoolINTERNAL", [bG, bV], nil) | |
754 | + | if ($isInstanceOf(ab, "Boolean")) | |
755 | + | then ab | |
756 | + | else throw(($getType(ab) + " couldn't be cast to Boolean")) | |
759 | 757 | } | |
760 | - | if (( | |
761 | - | then if ( | |
758 | + | if ((bZ == bZ)) | |
759 | + | then if (bZ) | |
762 | 760 | then $Tuple2(nil, true) | |
763 | 761 | else { | |
764 | - | let | |
765 | - | if ($isInstanceOf( | |
762 | + | let cj = cp | |
763 | + | if ($isInstanceOf(cj, "Unit")) | |
766 | 764 | then { | |
767 | - | let | |
768 | - | then [DeleteEntry( | |
769 | - | else [DeleteEntry( | |
770 | - | let | |
771 | - | if (( | |
772 | - | then $Tuple2( | |
765 | + | let bU = if (bV) | |
766 | + | then [DeleteEntry(p), DeleteEntry(v), DeleteEntry(q)] | |
767 | + | else [DeleteEntry(p), BooleanEntry(x(cd), true), IntegerEntry(t, i), IntegerEntry(u, br), DeleteEntry(q)] | |
768 | + | let cs = aA() | |
769 | + | if ((cs == cs)) | |
770 | + | then $Tuple2(bU, true) | |
773 | 771 | else throw("Strict value is not equal to itself.") | |
774 | 772 | } | |
775 | - | else if ($isInstanceOf( | |
773 | + | else if ($isInstanceOf(cj, "String")) | |
776 | 774 | then { | |
777 | - | let | |
778 | - | $Tuple2([StringEntry( | |
775 | + | let ct = cj | |
776 | + | $Tuple2([StringEntry(q, ct)], true) | |
779 | 777 | } | |
780 | 778 | else throw("Match error") | |
781 | 779 | } | |
785 | 783 | } | |
786 | 784 | else throw("Match error") | |
787 | 785 | } | |
788 | - | else | |
786 | + | else S("finalization is broken") | |
789 | 787 | } | |
790 | 788 | ||
791 | 789 | ||
792 | 790 | ||
793 | - | @Callable(bc) | |
794 | - | func finalizeWrapper (cv) = { | |
795 | - | let cw = addressFromStringValue(getStringValue(this, m)) | |
796 | - | let cx = { | |
797 | - | let ac = invoke(this, "finalizeHelper", nil, nil) | |
798 | - | if ($isInstanceOf(ac, "Boolean")) | |
799 | - | then ac | |
800 | - | else throw(($getType(ac) + " couldn't be cast to Boolean")) | |
791 | + | @Callable(bb) | |
792 | + | func finalizeWrapper (cu) = { | |
793 | + | let cv = { | |
794 | + | let ab = invoke(this, "finalizeHelper", nil, nil) | |
795 | + | if ($isInstanceOf(ab, "Boolean")) | |
796 | + | then ab | |
797 | + | else throw(($getType(ab) + " couldn't be cast to Boolean")) | |
801 | 798 | } | |
802 | - | if ((cx == cx)) | |
803 | - | then if (!(cx)) | |
804 | - | then if ((cv == 0)) | |
805 | - | then T("Current voting is not over yet") | |
806 | - | else { | |
807 | - | let cy = invoke(cw, "finalize", nil, nil) | |
808 | - | if ((cy == cy)) | |
809 | - | then $Tuple2(nil, unit) | |
810 | - | else throw("Strict value is not equal to itself.") | |
811 | - | } | |
799 | + | if ((cv == cv)) | |
800 | + | then if (!(cv)) | |
801 | + | then if ((cu == 0)) | |
802 | + | then S("Current voting is not over yet") | |
803 | + | else $Tuple2(nil, unit) | |
812 | 804 | else { | |
813 | - | let | |
814 | - | if (( | |
805 | + | let cw = valueOrElse(getInteger(this, k), c) | |
806 | + | if ((cw > cu)) | |
815 | 807 | then { | |
816 | - | let | |
817 | - | if (( | |
808 | + | let cx = invoke(this, "finalizeWrapper", [(cu + 1)], nil) | |
809 | + | if ((cx == cx)) | |
818 | 810 | then $Tuple2(nil, unit) | |
819 | 811 | else throw("Strict value is not equal to itself.") | |
820 | 812 | } | |
825 | 817 | ||
826 | 818 | ||
827 | 819 | ||
828 | - | @Callable( | |
820 | + | @Callable(bb) | |
829 | 821 | func finalize () = { | |
830 | - | let | |
831 | - | if (( | |
822 | + | let cx = invoke(this, "finalizeWrapper", [0], nil) | |
823 | + | if ((cx == cx)) | |
832 | 824 | then $Tuple2(nil, unit) | |
833 | 825 | else throw("Strict value is not equal to itself.") | |
834 | 826 | } | |
835 | 827 | ||
836 | 828 | ||
837 | 829 | ||
838 | - | @Callable( | |
839 | - | func containsNodeREADONLY ( | |
830 | + | @Callable(bb) | |
831 | + | func containsNodeREADONLY (aG,aK) = $Tuple2(nil, aM(aG, aK)) | |
840 | 832 | ||
841 | 833 | ||
842 | 834 | ||
843 | - | @Callable( | |
844 | - | func insertNode ( | |
845 | - | let | |
846 | - | if (( | |
847 | - | then $Tuple2( | |
835 | + | @Callable(bb) | |
836 | + | func insertNode (aG,aK) = { | |
837 | + | let bH = bd(bb) | |
838 | + | if ((bH == bH)) | |
839 | + | then $Tuple2(aQ(aG, aK), unit) | |
848 | 840 | else throw("Strict value is not equal to itself.") | |
849 | 841 | } | |
850 | 842 | ||
851 | 843 | ||
852 | 844 | ||
853 | - | @Callable( | |
854 | - | func deleteNode ( | |
855 | - | let | |
856 | - | if (( | |
857 | - | then $Tuple2( | |
845 | + | @Callable(bb) | |
846 | + | func deleteNode (aG,aK) = { | |
847 | + | let bH = bd(bb) | |
848 | + | if ((bH == bH)) | |
849 | + | then $Tuple2(aT(aG, aK), unit) | |
858 | 850 | else throw("Strict value is not equal to itself.") | |
859 | 851 | } | |
860 | 852 | ||
861 | 853 | ||
862 | - | ||
863 | - | @Callable(bc) | |
864 | - | func isFinalizationInProgress () = { | |
865 | - | let bu = getInteger(this, q) | |
866 | - | let cA = (bu != unit) | |
867 | - | $Tuple2(nil, cA) | |
868 | - | } | |
869 | - | ||
870 | - | ||
871 | - | @Verifier(cB) | |
872 | - | func cC () = { | |
873 | - | let cD = { | |
874 | - | let Y = aZ() | |
875 | - | if ($isInstanceOf(Y, "ByteVector")) | |
854 | + | @Verifier(cy) | |
855 | + | func cz () = { | |
856 | + | let cA = { | |
857 | + | let X = aY() | |
858 | + | if ($isInstanceOf(X, "ByteVector")) | |
876 | 859 | then { | |
877 | - | let | |
878 | - | | |
860 | + | let bc = X | |
861 | + | bc | |
879 | 862 | } | |
880 | - | else if ($isInstanceOf( | |
881 | - | then | |
863 | + | else if ($isInstanceOf(X, "Unit")) | |
864 | + | then cy.senderPublicKey | |
882 | 865 | else throw("Match error") | |
883 | 866 | } | |
884 | - | sigVerify( | |
867 | + | sigVerify(cy.bodyBytes, cy.proofs[0], cA) | |
885 | 868 | } | |
886 | 869 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let a = "__" | |
5 | 5 | ||
6 | 6 | let b = 100000000 | |
7 | 7 | ||
8 | 8 | let c = 10 | |
9 | 9 | ||
10 | 10 | let d = 0 | |
11 | 11 | ||
12 | 12 | let e = 1 | |
13 | 13 | ||
14 | 14 | let f = makeString(["%s", "epochLength"], a) | |
15 | 15 | ||
16 | 16 | let g = makeString(["%s%s", "epochLength__new"], a) | |
17 | 17 | ||
18 | 18 | func h (i) = makeString(["%s%d", "epochLength", toString(i)], a) | |
19 | 19 | ||
20 | 20 | ||
21 | 21 | let j = makeString(["%s", "currentEpoch"], a) | |
22 | 22 | ||
23 | 23 | let k = makeString(["%s", "maxDepth"], a) | |
24 | 24 | ||
25 | 25 | let l = makeString(["%s", "votingEmissionCandidateContract"], a) | |
26 | 26 | ||
27 | - | let m = makeString(["%s", " | |
27 | + | let m = makeString(["%s", "factoryContract"], a) | |
28 | 28 | ||
29 | - | let n = makeString(["%s", " | |
29 | + | let n = makeString(["%s", "boostingContract"], a) | |
30 | 30 | ||
31 | - | let o = makeString(["%s", " | |
31 | + | let o = makeString(["%s", "stakingContract"], a) | |
32 | 32 | ||
33 | - | let p = makeString(["%s", " | |
33 | + | let p = makeString(["%s", "finalizationStage"], a) | |
34 | 34 | ||
35 | - | let q = makeString(["%s", " | |
35 | + | let q = makeString(["%s", "nextPool"], a) | |
36 | 36 | ||
37 | - | let r = makeString(["%s", " | |
37 | + | let r = makeString(["%s", "nextUser"], a) | |
38 | 38 | ||
39 | - | let s = makeString(["%s", " | |
39 | + | let s = makeString(["%s", "startHeight"], a) | |
40 | 40 | ||
41 | - | let t = makeString(["%s", " | |
41 | + | let t = makeString(["%s", "currentEpochUi"], a) | |
42 | 42 | ||
43 | - | let u = makeString(["%s", " | |
43 | + | let u = makeString(["%s", "startHeightUi"], a) | |
44 | 44 | ||
45 | - | let v = makeString(["%s", " | |
45 | + | let v = makeString(["%s", "force"], a) | |
46 | 46 | ||
47 | - | let w = makeString(["%s", "force"], a) | |
48 | - | ||
49 | - | func x (i) = makeString(["%s%d", "startHeight", toString(i)], a) | |
47 | + | func w (i) = makeString(["%s%d", "startHeight", toString(i)], a) | |
50 | 48 | ||
51 | 49 | ||
52 | - | func | |
50 | + | func x (i) = makeString(["%s%d", "finalized", toString(i)], a) | |
53 | 51 | ||
54 | 52 | ||
55 | - | func | |
56 | - | let | |
57 | - | let | |
58 | - | let | |
59 | - | makeString(["%s%s%s", "inList", | |
53 | + | func y (z) = { | |
54 | + | let A = z | |
55 | + | let B = A._1 | |
56 | + | let C = A._2 | |
57 | + | makeString(["%s%s%s", "inList", B, C], a) | |
60 | 58 | } | |
61 | 59 | ||
62 | 60 | ||
63 | - | func | |
61 | + | func D (E,i) = makeString(["%s%s%d", "used", toString(E), toString(i)], a) | |
64 | 62 | ||
65 | 63 | ||
66 | - | func | |
67 | - | let | |
68 | - | let | |
69 | - | let | |
70 | - | makeString(["%s%s%s%s%d", "vote", | |
64 | + | func F (z,E,i) = { | |
65 | + | let G = z | |
66 | + | let B = G._1 | |
67 | + | let C = G._2 | |
68 | + | makeString(["%s%s%s%s%d", "vote", B, C, toString(E), toString(i)], a) | |
71 | 69 | } | |
72 | 70 | ||
73 | 71 | ||
74 | - | func | |
75 | - | let | |
76 | - | let | |
77 | - | let | |
78 | - | makeString(["%s%s%s%d", "votingResult", | |
72 | + | func H (z,i) = { | |
73 | + | let I = z | |
74 | + | let B = I._1 | |
75 | + | let C = I._2 | |
76 | + | makeString(["%s%s%s%d", "votingResult", B, C, toString(i)], a) | |
79 | 77 | } | |
80 | 78 | ||
81 | 79 | ||
82 | - | func | |
80 | + | func J (K,i) = makeString(["%s%s%d", "votingResultStaked", K, toString(i)], a) | |
83 | 81 | ||
84 | 82 | ||
85 | - | func | |
86 | - | let | |
87 | - | let | |
88 | - | let | |
89 | - | makeString(["%s%s%s%d", "poolShare", | |
83 | + | func L (z,i) = { | |
84 | + | let M = z | |
85 | + | let B = M._1 | |
86 | + | let C = M._2 | |
87 | + | makeString(["%s%s%s%d", "poolShare", B, C, toString(i)], a) | |
90 | 88 | } | |
91 | 89 | ||
92 | 90 | ||
93 | - | func | |
91 | + | func N (i) = makeString(["%s%d", "totalVotes", toString(i)], a) | |
94 | 92 | ||
95 | 93 | ||
96 | - | func | |
94 | + | func O (K,P) = makeString(["%s%s%s", "staked", P, K], a) | |
97 | 95 | ||
98 | 96 | ||
99 | - | func | |
97 | + | func Q (R) = makeString(["voting_emission.ride:", R], " ") | |
100 | 98 | ||
101 | 99 | ||
102 | - | func | |
100 | + | func S (R) = throw(Q(R)) | |
103 | 101 | ||
104 | 102 | ||
105 | - | func | |
106 | - | let | |
103 | + | func T (E,U,V) = { | |
104 | + | let W = Q(makeString(["mandatory ", toString(E), ".", U, " is not defined"], "")) | |
107 | 105 | valueOrErrorMessage({ | |
108 | - | let | |
109 | - | if ($isInstanceOf( | |
106 | + | let X = V | |
107 | + | if ($isInstanceOf(X, "String")) | |
110 | 108 | then { | |
111 | - | let | |
112 | - | getString( | |
109 | + | let Y = X | |
110 | + | getString(E, U) | |
113 | 111 | } | |
114 | - | else if ($isInstanceOf( | |
112 | + | else if ($isInstanceOf(X, "Int")) | |
115 | 113 | then { | |
116 | - | let | |
117 | - | getInteger( | |
114 | + | let Z = X | |
115 | + | getInteger(E, U) | |
118 | 116 | } | |
119 | - | else | |
120 | - | }, | |
117 | + | else S("invalid entry type") | |
118 | + | }, W) | |
121 | 119 | } | |
122 | 120 | ||
123 | 121 | ||
124 | - | func | |
125 | - | let | |
126 | - | if ($isInstanceOf( | |
127 | - | then | |
128 | - | else throw(($getType( | |
122 | + | func aa (E,U) = { | |
123 | + | let ab = T(E, U, "") | |
124 | + | if ($isInstanceOf(ab, "String")) | |
125 | + | then ab | |
126 | + | else throw(($getType(ab) + " couldn't be cast to String")) | |
129 | 127 | } | |
130 | 128 | ||
131 | 129 | ||
132 | - | func | |
133 | - | let | |
134 | - | if ($isInstanceOf( | |
135 | - | then | |
136 | - | else throw(($getType( | |
130 | + | func ac (E,U) = { | |
131 | + | let ab = T(E, U, 0) | |
132 | + | if ($isInstanceOf(ab, "Int")) | |
133 | + | then ab | |
134 | + | else throw(($getType(ab) + " couldn't be cast to Int")) | |
137 | 135 | } | |
138 | 136 | ||
139 | 137 | ||
140 | - | func | |
138 | + | func ad (z) = ((z._1 + a) + z._2) | |
141 | 139 | ||
142 | 140 | ||
143 | - | func | |
144 | - | let | |
145 | - | if ((size( | |
146 | - | then $Tuple2( | |
147 | - | else | |
141 | + | func ae (Y) = { | |
142 | + | let af = split(Y, a) | |
143 | + | if ((size(af) == 2)) | |
144 | + | then $Tuple2(af[0], af[1]) | |
145 | + | else S("invalid pool string") | |
148 | 146 | } | |
149 | 147 | ||
150 | 148 | ||
151 | - | let | |
149 | + | let ag = addressFromStringValue(aa(this, m)) | |
152 | 150 | ||
153 | - | let | |
151 | + | let ah = 10 | |
154 | 152 | ||
155 | - | func | |
153 | + | func ai () = "%s__factoryConfig" | |
156 | 154 | ||
157 | 155 | ||
158 | - | func | |
156 | + | func aj (ak) = split(aa(ak, ai()), a) | |
159 | 157 | ||
160 | 158 | ||
161 | - | func | |
159 | + | func al (am) = addressFromStringValue(am[ah]) | |
162 | 160 | ||
163 | 161 | ||
164 | - | func | |
165 | - | func | |
162 | + | func an (B,C) = { | |
163 | + | func ao (ap) = ("%s%s%s__mappings__baseAsset2internalId__" + ap) | |
166 | 164 | ||
167 | - | func | |
165 | + | func aq (ar,as) = (((("%d%d%s%s__" + toString(ar)) + "__") + toString(as)) + "__mappings__poolAssets2PoolContract") | |
168 | 166 | ||
169 | - | func | |
167 | + | func at (au) = (("%s%s%s__" + au) + "__mappings__poolContract2LpAsset") | |
170 | 168 | ||
171 | - | let | |
172 | - | let | |
173 | - | let | |
174 | - | let | |
175 | - | | |
169 | + | let av = ac(ag, ao(B)) | |
170 | + | let aw = ac(ag, ao(C)) | |
171 | + | let au = aa(ag, aq(av, aw)) | |
172 | + | let ax = aa(ag, at(au)) | |
173 | + | ax | |
176 | 174 | } | |
177 | 175 | ||
178 | 176 | ||
179 | - | func | |
180 | - | let | |
181 | - | let | |
182 | - | let | |
183 | - | let | |
184 | - | if ($isInstanceOf( | |
185 | - | then | |
186 | - | else throw(($getType( | |
177 | + | func ay (z) = { | |
178 | + | let az = z | |
179 | + | let B = az._1 | |
180 | + | let C = az._2 | |
181 | + | let ab = invoke(ag, "checkWxEmissionPoolLabel", [B, C], nil) | |
182 | + | if ($isInstanceOf(ab, "Boolean")) | |
183 | + | then ab | |
184 | + | else throw(($getType(ab) + " couldn't be cast to Boolean")) | |
187 | 185 | } | |
188 | 186 | ||
189 | 187 | ||
190 | - | func | |
191 | - | let | |
192 | - | let | |
193 | - | invoke( | |
188 | + | func aA () = { | |
189 | + | let am = aj(ag) | |
190 | + | let aB = al(am) | |
191 | + | invoke(aB, "deposit", nil, nil) | |
194 | 192 | } | |
195 | 193 | ||
196 | 194 | ||
197 | - | let | |
195 | + | let aC = "pools" | |
198 | 196 | ||
199 | - | func | |
200 | - | let | |
201 | - | let | |
202 | - | let | |
203 | - | makeString(["votes", | |
197 | + | func aD (z) = { | |
198 | + | let aE = z | |
199 | + | let B = aE._1 | |
200 | + | let C = aE._2 | |
201 | + | makeString(["votes", B, C], a) | |
204 | 202 | } | |
205 | 203 | ||
206 | 204 | ||
207 | - | func | |
208 | - | let | |
205 | + | func aF (aG) = { | |
206 | + | let aH = if ((aG == aC)) | |
209 | 207 | then "%s%s" | |
210 | 208 | else "%s%s%s%s" | |
211 | - | makeString([ | |
209 | + | makeString([aH, aG, "head"], a) | |
212 | 210 | } | |
213 | 211 | ||
214 | 212 | ||
215 | - | func | |
216 | - | let | |
213 | + | func aI (aG) = { | |
214 | + | let aH = if ((aG == aC)) | |
217 | 215 | then "%s%s" | |
218 | 216 | else "%s%s%s%s" | |
219 | - | makeString([ | |
217 | + | makeString([aH, aG, "size"], a) | |
220 | 218 | } | |
221 | 219 | ||
222 | 220 | ||
223 | - | func | |
224 | - | let | |
221 | + | func aJ (aG,aK) = { | |
222 | + | let aH = if ((aG == aC)) | |
225 | 223 | then "%s%s%s%s" | |
226 | 224 | else "%s%s%s%s%s" | |
227 | - | makeString([ | |
225 | + | makeString([aH, aG, aK, "prev"], a) | |
228 | 226 | } | |
229 | 227 | ||
230 | 228 | ||
231 | - | func | |
232 | - | let | |
229 | + | func aL (aG,aK) = { | |
230 | + | let aH = if ((aG == aC)) | |
233 | 231 | then "%s%s%s%s" | |
234 | 232 | else "%s%s%s%s%s" | |
235 | - | makeString([ | |
233 | + | makeString([aH, aG, aK, "next"], a) | |
236 | 234 | } | |
237 | 235 | ||
238 | 236 | ||
239 | - | func | |
240 | - | let | |
241 | - | let | |
242 | - | let | |
243 | - | if (if (( | |
237 | + | func aM (aG,aK) = { | |
238 | + | let aN = getString(this, aF(aG)) | |
239 | + | let aO = getString(this, aJ(aG, aK)) | |
240 | + | let aP = getString(this, aL(aG, aK)) | |
241 | + | if (if ((aK == valueOrElse(aN, ""))) | |
244 | 242 | then true | |
245 | - | else ( | |
243 | + | else (aO != unit)) | |
246 | 244 | then true | |
247 | - | else ( | |
245 | + | else (aP != unit) | |
248 | 246 | } | |
249 | 247 | ||
250 | 248 | ||
251 | - | func | |
252 | - | let | |
253 | - | let | |
254 | - | let | |
249 | + | func aQ (aG,aK) = { | |
250 | + | let aN = getString(this, aF(aG)) | |
251 | + | let aR = valueOrElse(getInteger(this, aI(aG)), 0) | |
252 | + | let aS = if (!(aM(aG, aK))) | |
255 | 253 | then true | |
256 | - | else | |
257 | - | if (( | |
258 | - | then (([IntegerEntry( | |
259 | - | then [StringEntry( | |
260 | - | else nil)) ++ [StringEntry(aG | |
254 | + | else S("Node exists") | |
255 | + | if ((aS == aS)) | |
256 | + | then (([IntegerEntry(aI(aG), (aR + 1))] ++ (if ((aN != unit)) | |
257 | + | then [StringEntry(aL(aG, aK), value(aN)), StringEntry(aJ(aG, value(aN)), aK)] | |
258 | + | else nil)) ++ [StringEntry(aF(aG), aK)]) | |
261 | 259 | else throw("Strict value is not equal to itself.") | |
262 | 260 | } | |
263 | 261 | ||
264 | 262 | ||
265 | - | func | |
266 | - | let | |
267 | - | let | |
268 | - | let | |
269 | - | let | |
270 | - | ([IntegerEntry( | |
271 | - | then ( | |
263 | + | func aT (aG,aK) = { | |
264 | + | let aN = getString(this, aF(aG)) | |
265 | + | let aR = valueOrElse(getInteger(this, aI(aG)), 0) | |
266 | + | let aO = getString(this, aJ(aG, aK)) | |
267 | + | let aP = getString(this, aL(aG, aK)) | |
268 | + | ([IntegerEntry(aI(aG), (aR - 1))] ++ (if (if ((aO != unit)) | |
269 | + | then (aP != unit) | |
272 | 270 | else false) | |
273 | - | then [StringEntry( | |
274 | - | else if (( | |
275 | - | then [StringEntry(aG | |
276 | - | else if (( | |
277 | - | then [DeleteEntry( | |
278 | - | else if (( | |
279 | - | then [DeleteEntry(aG | |
280 | - | else | |
271 | + | then [StringEntry(aL(aG, value(aO)), value(aP)), StringEntry(aJ(aG, value(aP)), value(aO)), DeleteEntry(aJ(aG, aK)), DeleteEntry(aL(aG, aK))] | |
272 | + | else if ((aP != unit)) | |
273 | + | then [StringEntry(aF(aG), value(aP)), DeleteEntry(aL(aG, aK)), DeleteEntry(aJ(aG, value(aP)))] | |
274 | + | else if ((aO != unit)) | |
275 | + | then [DeleteEntry(aJ(aG, aK)), DeleteEntry(aL(aG, value(aO)))] | |
276 | + | else if ((aK == valueOrElse(aN, ""))) | |
277 | + | then [DeleteEntry(aF(aG))] | |
278 | + | else S(((("invalid node: " + aG) + ".") + aK)))) | |
281 | 279 | } | |
282 | 280 | ||
283 | 281 | ||
284 | - | func | |
282 | + | func aU () = "%s__managerVaultAddress" | |
285 | 283 | ||
286 | 284 | ||
287 | - | func | |
285 | + | func aV () = "%s__managerPublicKey" | |
288 | 286 | ||
289 | 287 | ||
290 | - | func | |
291 | - | let | |
292 | - | if ($isInstanceOf( | |
288 | + | func aW () = { | |
289 | + | let X = getString(aU()) | |
290 | + | if ($isInstanceOf(X, "String")) | |
293 | 291 | then { | |
294 | - | let | |
295 | - | addressFromStringValue( | |
292 | + | let aX = X | |
293 | + | addressFromStringValue(aX) | |
296 | 294 | } | |
297 | 295 | else this | |
298 | 296 | } | |
299 | 297 | ||
300 | 298 | ||
301 | - | func | |
302 | - | let | |
303 | - | let | |
304 | - | if ($isInstanceOf( | |
299 | + | func aY () = { | |
300 | + | let aZ = aW() | |
301 | + | let X = getString(aZ, aV()) | |
302 | + | if ($isInstanceOf(X, "String")) | |
305 | 303 | then { | |
306 | - | let | |
307 | - | fromBase58String( | |
304 | + | let aX = X | |
305 | + | fromBase58String(aX) | |
308 | 306 | } | |
309 | - | else if ($isInstanceOf( | |
307 | + | else if ($isInstanceOf(X, "Unit")) | |
310 | 308 | then unit | |
311 | 309 | else throw("Match error") | |
312 | 310 | } | |
313 | 311 | ||
314 | 312 | ||
315 | - | func | |
316 | - | let | |
317 | - | if ($isInstanceOf( | |
313 | + | func ba (bb) = { | |
314 | + | let X = aY() | |
315 | + | if ($isInstanceOf(X, "ByteVector")) | |
318 | 316 | then { | |
319 | - | let | |
320 | - | ( | |
317 | + | let bc = X | |
318 | + | (bb.callerPublicKey == bc) | |
321 | 319 | } | |
322 | - | else if ($isInstanceOf( | |
323 | - | then ( | |
320 | + | else if ($isInstanceOf(X, "Unit")) | |
321 | + | then (bb.caller == this) | |
324 | 322 | else throw("Match error") | |
325 | 323 | } | |
326 | 324 | ||
327 | 325 | ||
328 | - | func | |
326 | + | func bd (bb) = if (ba(bb)) | |
329 | 327 | then true | |
330 | 328 | else throw("permission denied") | |
331 | 329 | ||
332 | 330 | ||
333 | - | func | |
331 | + | func be (bb) = if ((bb.caller == this)) | |
334 | 332 | then true | |
335 | 333 | else throw("permission denied") | |
336 | 334 | ||
337 | 335 | ||
338 | - | @Callable( | |
339 | - | func getUserGwxAmountAtHeight (bg | |
340 | - | let | |
336 | + | @Callable(bb) | |
337 | + | func getUserGwxAmountAtHeight (bf,bg) = { | |
338 | + | let bh = valueOrErrorMessage(addressFromString(aa(this, n)), Q("invalid boosting contract address")) | |
341 | 339 | $Tuple2(nil, { | |
342 | - | let | |
343 | - | if ($isInstanceOf( | |
344 | - | then | |
345 | - | else throw(($getType( | |
340 | + | let ab = invoke(bh, "getUserGwxAmountAtHeightREADONLY", [bf, bg], nil) | |
341 | + | if ($isInstanceOf(ab, "Int")) | |
342 | + | then ab | |
343 | + | else throw(($getType(ab) + " couldn't be cast to Int")) | |
346 | 344 | }) | |
347 | 345 | } | |
348 | 346 | ||
349 | 347 | ||
350 | 348 | ||
351 | - | @Callable( | |
352 | - | func constructor ( | |
353 | - | let | |
349 | + | @Callable(bb) | |
350 | + | func constructor (ag,bi,bj,bk,bl) = { | |
351 | + | let bm = [bd(bb), if ((addressFromString(ag) != unit)) | |
354 | 352 | then true | |
355 | - | else "invalid factory contract address", if ((addressFromString( | |
353 | + | else "invalid factory contract address", if ((addressFromString(bi) != unit)) | |
356 | 354 | then true | |
357 | - | else "invalid voting emission candidate contract address", if ((addressFromString( | |
355 | + | else "invalid voting emission candidate contract address", if ((addressFromString(bj) != unit)) | |
358 | 356 | then true | |
359 | - | else "invalid boosting contract address", if ((addressFromString( | |
357 | + | else "invalid boosting contract address", if ((addressFromString(bk) != unit)) | |
360 | 358 | then true | |
361 | - | else "invalid staking contract address", if (( | |
359 | + | else "invalid staking contract address", if ((bl > 0)) | |
362 | 360 | then true | |
363 | - | else | |
364 | - | if (( | |
365 | - | then $Tuple2([StringEntry( | |
361 | + | else S("invalid epoch length")] | |
362 | + | if ((bm == bm)) | |
363 | + | then $Tuple2([StringEntry(m, ag), StringEntry(l, bi), StringEntry(n, bj), StringEntry(o, bk), IntegerEntry(f, bl)], unit) | |
366 | 364 | else throw("Strict value is not equal to itself.") | |
367 | 365 | } | |
368 | 366 | ||
369 | 367 | ||
370 | 368 | ||
371 | - | @Callable( | |
372 | - | func create (C | |
373 | - | let | |
369 | + | @Callable(bb) | |
370 | + | func create (B,C) = { | |
371 | + | let bm = [if ((toBase58String(bb.caller.bytes) == valueOrElse(getString(this, l), ""))) | |
374 | 372 | then true | |
375 | - | else | |
376 | - | if (( | |
373 | + | else bd(bb)] | |
374 | + | if ((bm == bm)) | |
377 | 375 | then { | |
378 | - | let | |
379 | - | let | |
380 | - | let | |
381 | - | let | |
376 | + | let z = $Tuple2(B, C) | |
377 | + | let bn = ([BooleanEntry(y(z), true)] ++ aQ(aC, ad(z))) | |
378 | + | let bo = (getInteger(this, j) == unit) | |
379 | + | let bp = if (bo) | |
382 | 380 | then { | |
383 | 381 | let i = 0 | |
384 | - | [IntegerEntry(j, i), IntegerEntry( | |
382 | + | [IntegerEntry(j, i), IntegerEntry(w(i), height), IntegerEntry(s, height), IntegerEntry(t, i), IntegerEntry(u, height)] | |
385 | 383 | } | |
386 | 384 | else nil | |
387 | - | $Tuple2(( | |
385 | + | $Tuple2((bn ++ bp), unit) | |
388 | 386 | } | |
389 | 387 | else throw("Strict value is not equal to itself.") | |
390 | 388 | } | |
391 | 389 | ||
392 | 390 | ||
393 | 391 | ||
394 | - | @Callable( | |
395 | - | func vote (C, | |
396 | - | let | |
392 | + | @Callable(bb) | |
393 | + | func vote (B,C,bq) = { | |
394 | + | let z = $Tuple2(B, C) | |
397 | 395 | let i = valueOrElse(getInteger(this, j), 0) | |
398 | - | let | |
399 | - | let | |
400 | - | let | |
401 | - | let | |
402 | - | let | |
403 | - | let | |
404 | - | let | |
405 | - | let | |
406 | - | let | |
407 | - | let | |
408 | - | if ($isInstanceOf( | |
409 | - | then | |
410 | - | else throw(($getType( | |
396 | + | let br = ac(this, w(i)) | |
397 | + | let bl = ac(this, f) | |
398 | + | let bs = (br + bl) | |
399 | + | let bt = getInteger(this, p) | |
400 | + | let bu = valueOrElse(getInteger(this, D(bb.caller, i)), 0) | |
401 | + | let bv = valueOrElse(getInteger(this, F(z, bb.caller, i)), 0) | |
402 | + | let bw = valueOrElse(getInteger(this, H(z, i)), 0) | |
403 | + | let bx = valueOrElse(getInteger(this, N(i)), 0) | |
404 | + | let by = { | |
405 | + | let ab = invoke(this, "getUserGwxAmountAtHeight", [toBase58String(bb.caller.bytes), bs], nil) | |
406 | + | if ($isInstanceOf(ab, "Int")) | |
407 | + | then ab | |
408 | + | else throw(($getType(ab) + " couldn't be cast to Int")) | |
411 | 409 | } | |
412 | - | let | |
413 | - | let | |
414 | - | let | |
415 | - | let | |
410 | + | let bz = (by - bu) | |
411 | + | let bA = (bv + bq) | |
412 | + | let bB = ay(z) | |
413 | + | let bm = [if ((getBoolean(y(z)) != unit)) | |
416 | 414 | then true | |
417 | - | else | |
415 | + | else S("invalid assets"), if ((bs > height)) | |
418 | 416 | then true | |
419 | - | else | |
417 | + | else S("invalid height"), if ((bt == unit)) | |
420 | 418 | then true | |
421 | - | else | |
419 | + | else S("finalization in progress"), if ((by > 0)) | |
422 | 420 | then true | |
423 | - | else | |
424 | - | then ( | |
421 | + | else S("you do not have gWX"), if (if ((bq > 0)) | |
422 | + | then (bz >= bq) | |
425 | 423 | else false) | |
426 | 424 | then true | |
427 | - | else | |
425 | + | else S("invalid amount"), if (bB) | |
428 | 426 | then true | |
429 | - | else | |
430 | - | if (( | |
427 | + | else S("pool hasn't WX_EMISSION label")] | |
428 | + | if ((bm == bm)) | |
431 | 429 | then { | |
432 | - | let | |
433 | - | let | |
434 | - | let | |
430 | + | let bC = aD(z) | |
431 | + | let P = toString(bb.caller) | |
432 | + | let bD = if (aM(bC, P)) | |
435 | 433 | then nil | |
436 | - | else | |
437 | - | $Tuple2(([IntegerEntry( | |
434 | + | else aQ(bC, P) | |
435 | + | $Tuple2(([IntegerEntry(D(bb.caller, i), (bu + bq)), IntegerEntry(F(z, bb.caller, i), bA), IntegerEntry(H(z, i), (bw + bq)), IntegerEntry(N(i), (bx + bq))] ++ bD), unit) | |
438 | 436 | } | |
439 | 437 | else throw("Strict value is not equal to itself.") | |
440 | 438 | } | |
441 | 439 | ||
442 | 440 | ||
443 | 441 | ||
444 | - | @Callable( | |
445 | - | func cancelVote (C | |
446 | - | let | |
442 | + | @Callable(bb) | |
443 | + | func cancelVote (B,C) = { | |
444 | + | let z = $Tuple2(B, C) | |
447 | 445 | let i = valueOrElse(getInteger(this, j), 0) | |
448 | - | let | |
449 | - | let | |
450 | - | let | |
451 | - | let | |
452 | - | let | |
453 | - | let | |
454 | - | let | |
455 | - | let | |
456 | - | let | |
446 | + | let br = ac(this, w(i)) | |
447 | + | let bl = ac(this, f) | |
448 | + | let bs = (br + bl) | |
449 | + | let bt = getInteger(this, p) | |
450 | + | let bu = valueOrElse(getInteger(this, D(bb.caller, i)), 0) | |
451 | + | let bv = valueOrElse(getInteger(this, F(z, bb.caller, i)), 0) | |
452 | + | let bw = valueOrElse(getInteger(this, H(z, i)), 0) | |
453 | + | let bx = valueOrElse(getInteger(this, N(i)), 0) | |
454 | + | let bm = [if ((getBoolean(y(z)) != unit)) | |
457 | 455 | then true | |
458 | - | else | |
456 | + | else S("invalid assets"), if ((bs > height)) | |
459 | 457 | then true | |
460 | - | else | |
458 | + | else S("invalid height"), if ((bt == unit)) | |
461 | 459 | then true | |
462 | - | else | |
460 | + | else S("finalization in progress"), if ((bv > 0)) | |
463 | 461 | then true | |
464 | - | else | |
465 | - | if (( | |
462 | + | else S("no vote")] | |
463 | + | if ((bm == bm)) | |
466 | 464 | then { | |
467 | - | let | |
468 | - | let | |
469 | - | $Tuple2(([IntegerEntry( | |
465 | + | let bC = aD(z) | |
466 | + | let P = toString(bb.caller) | |
467 | + | $Tuple2(([IntegerEntry(D(bb.caller, i), max([(bu - bv), 0])), DeleteEntry(F(z, bb.caller, i)), IntegerEntry(H(z, i), (bw - bv)), IntegerEntry(N(i), (bx - bv))] ++ aT(bC, P)), unit) | |
470 | 468 | } | |
471 | 469 | else throw("Strict value is not equal to itself.") | |
472 | 470 | } | |
473 | 471 | ||
474 | 472 | ||
475 | 473 | ||
476 | - | @Callable( | |
477 | - | func setEpochLength ( | |
478 | - | let | |
474 | + | @Callable(bb) | |
475 | + | func setEpochLength (bE) = { | |
476 | + | let bm = [bd(bb), if ((bE > 0)) | |
479 | 477 | then true | |
480 | - | else | |
481 | - | if (( | |
482 | - | then $Tuple2([IntegerEntry(g, | |
478 | + | else S("invalid epoch length")] | |
479 | + | if ((bm == bm)) | |
480 | + | then $Tuple2([IntegerEntry(g, bE)], unit) | |
483 | 481 | else throw("Strict value is not equal to itself.") | |
484 | 482 | } | |
485 | 483 | ||
486 | 484 | ||
487 | 485 | ||
488 | - | @Callable( | |
489 | - | func setMaxDepth ( | |
490 | - | let | |
486 | + | @Callable(bb) | |
487 | + | func setMaxDepth (bF) = { | |
488 | + | let bm = [bd(bb), if ((bF > 0)) | |
491 | 489 | then true | |
492 | - | else | |
493 | - | if (( | |
494 | - | then $Tuple2([IntegerEntry(k, | |
490 | + | else S("invalid max depth")] | |
491 | + | if ((bm == bm)) | |
492 | + | then $Tuple2([IntegerEntry(k, bF)], unit) | |
495 | 493 | else throw("Strict value is not equal to itself.") | |
496 | 494 | } | |
497 | 495 | ||
498 | 496 | ||
499 | 497 | ||
500 | - | @Callable( | |
501 | - | func processVoteINTERNAL ( | |
502 | - | let | |
503 | - | if (( | |
498 | + | @Callable(bb) | |
499 | + | func processVoteINTERNAL (bG,P) = { | |
500 | + | let bH = be(bb) | |
501 | + | if ((bH == bH)) | |
504 | 502 | then { | |
505 | - | let | |
506 | - | let i = | |
507 | - | let | |
508 | - | let | |
509 | - | let | |
510 | - | let | |
511 | - | let | |
512 | - | let | |
513 | - | let | |
514 | - | let | |
503 | + | let bf = valueOrErrorMessage(addressFromString(P), Q(("processVoteINTERNAL: invalid user address " + P))) | |
504 | + | let i = ac(this, j) | |
505 | + | let bI = (i - 1) | |
506 | + | let bl = ac(this, f) | |
507 | + | let br = ac(this, w(i)) | |
508 | + | let bs = (br + bl) | |
509 | + | let bJ = ac(this, w(bI)) | |
510 | + | let bK = ac(this, h(bI)) | |
511 | + | let bL = (bJ + bK) | |
512 | + | let bM = if ((bI >= 0)) | |
515 | 513 | then true | |
516 | - | else | |
517 | - | if (( | |
514 | + | else S("processVoteINTERNAL: invalid previous epoch") | |
515 | + | if ((bM == bM)) | |
518 | 516 | then { | |
519 | - | let | |
520 | - | let | |
521 | - | let | |
522 | - | let | |
523 | - | let | |
524 | - | let | |
525 | - | let | |
526 | - | if ($isInstanceOf( | |
527 | - | then | |
528 | - | else throw(($getType( | |
517 | + | let z = ae(bG) | |
518 | + | let bN = z | |
519 | + | let B = bN._1 | |
520 | + | let C = bN._2 | |
521 | + | let bB = ay(z) | |
522 | + | let by = { | |
523 | + | let ab = invoke(this, "getUserGwxAmountAtHeight", [P, bs], nil) | |
524 | + | if ($isInstanceOf(ab, "Int")) | |
525 | + | then ab | |
526 | + | else throw(($getType(ab) + " couldn't be cast to Int")) | |
529 | 527 | } | |
530 | - | let | |
531 | - | let | |
532 | - | if ($isInstanceOf( | |
533 | - | then | |
534 | - | else throw(($getType( | |
528 | + | let bO = { | |
529 | + | let ab = invoke(this, "getUserGwxAmountAtHeight", [P, bL], nil) | |
530 | + | if ($isInstanceOf(ab, "Int")) | |
531 | + | then ab | |
532 | + | else throw(($getType(ab) + " couldn't be cast to Int")) | |
535 | 533 | } | |
536 | - | let | |
537 | - | let | |
538 | - | let | |
539 | - | let | |
540 | - | let | |
541 | - | let | |
542 | - | let | |
543 | - | let | |
544 | - | let | |
534 | + | let bx = valueOrElse(getInteger(N(i)), 0) | |
535 | + | let bP = valueOrElse(getInteger(H(z, i)), 0) | |
536 | + | let bQ = valueOrErrorMessage(getInteger(F(z, bf, bI)), Q((((("processVoteINTERNAL " + bG) + " ") + P) + ": no previous vote"))) | |
537 | + | let bu = valueOrElse(getInteger(this, D(bf, i)), 0) | |
538 | + | let K = an(B, C) | |
539 | + | let bR = valueOrElse(getInteger(J(K, bI)), 0) | |
540 | + | let bk = addressFromStringValue(aa(this, o)) | |
541 | + | let bS = valueOrElse(getInteger(bk, O(K, P)), 0) | |
542 | + | let bT = if ((bS == 0)) | |
545 | 543 | then nil | |
546 | - | else [IntegerEntry(K | |
547 | - | let | |
548 | - | then fraction( | |
544 | + | else [IntegerEntry(J(K, bI), (bR + bQ))] | |
545 | + | let bA = if ((bO > 0)) | |
546 | + | then fraction(bQ, by, bO) | |
549 | 547 | else 0 | |
550 | - | let | |
551 | - | then | |
548 | + | let bU = if (if ((bA > 0)) | |
549 | + | then bB | |
552 | 550 | else false) | |
553 | - | then [IntegerEntry( | |
554 | - | else | |
555 | - | $Tuple2(( | |
551 | + | then [IntegerEntry(F(z, bf, i), bA), IntegerEntry(N(i), (bx + bA)), IntegerEntry(H(z, i), (bP + bA)), IntegerEntry(D(bf, i), (bu + bA))] | |
552 | + | else aT(aD(z), P) | |
553 | + | $Tuple2((bU ++ bT), unit) | |
556 | 554 | } | |
557 | 555 | else throw("Strict value is not equal to itself.") | |
558 | 556 | } | |
559 | 557 | else throw("Strict value is not equal to itself.") | |
560 | 558 | } | |
561 | 559 | ||
562 | 560 | ||
563 | 561 | ||
564 | - | @Callable( | |
565 | - | func processPoolINTERNAL ( | |
566 | - | let | |
567 | - | if (( | |
562 | + | @Callable(bb) | |
563 | + | func processPoolINTERNAL (bG,bV) = { | |
564 | + | let bH = be(bb) | |
565 | + | if ((bH == bH)) | |
568 | 566 | then { | |
569 | - | let | |
570 | - | let | |
571 | - | if ( | |
572 | - | then | |
573 | - | else ( | |
567 | + | let bW = { | |
568 | + | let bX = ac(this, j) | |
569 | + | if (bV) | |
570 | + | then bX | |
571 | + | else (bX - 1) | |
574 | 572 | } | |
575 | - | let | |
573 | + | let bM = if ((bW >= 0)) | |
576 | 574 | then true | |
577 | - | else | |
578 | - | if (( | |
575 | + | else S("processPoolINTERNAL: invalid target epoch") | |
576 | + | if ((bM == bM)) | |
579 | 577 | then { | |
580 | - | let | |
581 | - | let | |
582 | - | let | |
583 | - | let | |
584 | - | let | |
585 | - | let | |
586 | - | let | |
587 | - | let | |
588 | - | if ($isInstanceOf( | |
589 | - | then | |
590 | - | else throw(($getType( | |
578 | + | let z = ae(bG) | |
579 | + | let bY = z | |
580 | + | let B = bY._1 | |
581 | + | let C = bY._2 | |
582 | + | let bk = addressFromStringValue(aa(this, o)) | |
583 | + | let ax = an(B, C) | |
584 | + | let bZ = { | |
585 | + | let ab = invoke(bk, "usersListTraversal", [ax], nil) | |
586 | + | if ($isInstanceOf(ab, "Boolean")) | |
587 | + | then ab | |
588 | + | else throw(($getType(ab) + " couldn't be cast to Boolean")) | |
591 | 589 | } | |
592 | - | if (( | |
593 | - | then if ( | |
590 | + | if ((bZ == bZ)) | |
591 | + | then if (bZ) | |
594 | 592 | then $Tuple2(nil, true) | |
595 | 593 | else { | |
596 | - | let | |
597 | - | let | |
598 | - | let | |
599 | - | let | |
594 | + | let bB = ay(z) | |
595 | + | let bx = valueOrElse(getInteger(this, N(bW)), 0) | |
596 | + | let bP = valueOrElse(getInteger(this, H(z, bW)), 0) | |
597 | + | let ca = if (if ((bx == 0)) | |
600 | 598 | then true | |
601 | - | else !( | |
599 | + | else !(bB)) | |
602 | 600 | then 0 | |
603 | - | else fraction( | |
604 | - | let | |
605 | - | if (( | |
601 | + | else fraction(bP, b, bx) | |
602 | + | let cb = invoke(ag, "modifyWeight", [ax, ca], nil) | |
603 | + | if ((cb == cb)) | |
606 | 604 | then { | |
607 | - | let | |
605 | + | let cc = if (if (bB) | |
608 | 606 | then true | |
609 | - | else | |
607 | + | else bV) | |
610 | 608 | then nil | |
611 | - | else ([DeleteEntry(z | |
612 | - | $Tuple2(([IntegerEntry( | |
609 | + | else ([DeleteEntry(y(z))] ++ aT(aC, bG)) | |
610 | + | $Tuple2(([IntegerEntry(L(z, bW), ca)] ++ cc), false) | |
613 | 611 | } | |
614 | 612 | else throw("Strict value is not equal to itself.") | |
615 | 613 | } | |
616 | 614 | else throw("Strict value is not equal to itself.") | |
617 | 615 | } | |
618 | 616 | else throw("Strict value is not equal to itself.") | |
619 | 617 | } | |
620 | 618 | else throw("Strict value is not equal to itself.") | |
621 | 619 | } | |
622 | 620 | ||
623 | 621 | ||
624 | 622 | ||
625 | - | @Callable( | |
623 | + | @Callable(bb) | |
626 | 624 | func finalizeHelper () = { | |
627 | - | let | |
625 | + | let bV = valueOrElse(getBoolean(v), false) | |
628 | 626 | let i = valueOrElse(getInteger(this, j), 0) | |
629 | - | let | |
630 | - | let | |
631 | - | let | |
632 | - | let | |
633 | - | let | |
634 | - | if (if (if ((height >= | |
635 | - | then ( | |
627 | + | let cd = (i - 1) | |
628 | + | let br = ac(this, w(i)) | |
629 | + | let bl = ac(this, f) | |
630 | + | let bs = (br + bl) | |
631 | + | let bt = getInteger(this, p) | |
632 | + | if (if (if ((height >= bs)) | |
633 | + | then (bt == unit) | |
636 | 634 | else false) | |
637 | - | then !( | |
635 | + | then !(bV) | |
638 | 636 | else false) | |
639 | 637 | then { | |
640 | - | let | |
641 | - | let | |
642 | - | let | |
643 | - | let | |
644 | - | if ($isInstanceOf( | |
638 | + | let ce = (i + 1) | |
639 | + | let cf = getInteger(this, g) | |
640 | + | let cg = { | |
641 | + | let X = cf | |
642 | + | if ($isInstanceOf(X, "Int")) | |
645 | 643 | then { | |
646 | - | let | |
647 | - | [IntegerEntry(f, | |
644 | + | let bE = X | |
645 | + | [IntegerEntry(f, bE), DeleteEntry(g)] | |
648 | 646 | } | |
649 | - | else if ($isInstanceOf( | |
647 | + | else if ($isInstanceOf(X, "Unit")) | |
650 | 648 | then nil | |
651 | 649 | else throw("Match error") | |
652 | 650 | } | |
653 | - | $Tuple2(([IntegerEntry( | |
651 | + | $Tuple2(([IntegerEntry(w(ce), height), IntegerEntry(s, height), IntegerEntry(j, ce), IntegerEntry(p, d), IntegerEntry(h(i), bl)] ++ cg), true) | |
654 | 652 | } | |
655 | - | else if (if ( | |
656 | - | then ( | |
653 | + | else if (if (bV) | |
654 | + | then (bt == unit) | |
657 | 655 | else false) | |
658 | - | then $Tuple2([IntegerEntry( | |
659 | - | else if (( | |
656 | + | then $Tuple2([IntegerEntry(p, e)], true) | |
657 | + | else if ((bt == unit)) | |
660 | 658 | then $Tuple2(nil, false) | |
661 | - | else if (( | |
659 | + | else if ((bt == d)) | |
662 | 660 | then { | |
661 | + | let ch = getString(q) | |
663 | 662 | let ci = getString(r) | |
664 | - | let cj = getString(s) | |
665 | - | let Y = ci | |
666 | - | if ($isInstanceOf(Y, "Unit")) | |
663 | + | let X = ch | |
664 | + | if ($isInstanceOf(X, "Unit")) | |
667 | 665 | then { | |
668 | - | let | |
669 | - | if ($isInstanceOf( | |
670 | - | then $Tuple2([IntegerEntry( | |
671 | - | else if ($isInstanceOf( | |
666 | + | let cj = getString(aF(aC)) | |
667 | + | if ($isInstanceOf(cj, "Unit")) | |
668 | + | then $Tuple2([IntegerEntry(p, e), DeleteEntry(q), DeleteEntry(r)], true) | |
669 | + | else if ($isInstanceOf(cj, "String")) | |
672 | 670 | then { | |
673 | - | let | |
674 | - | $Tuple2([StringEntry( | |
671 | + | let ck = cj | |
672 | + | $Tuple2([StringEntry(q, ck)], true) | |
675 | 673 | } | |
676 | 674 | else throw("Match error") | |
677 | 675 | } | |
678 | - | else if ($isInstanceOf( | |
676 | + | else if ($isInstanceOf(X, "String")) | |
679 | 677 | then { | |
680 | - | let | |
681 | - | let | |
682 | - | let | |
683 | - | let | |
684 | - | if ($isInstanceOf( | |
685 | - | then getString( | |
686 | - | else if ($isInstanceOf( | |
678 | + | let bG = X | |
679 | + | let z = ae(bG) | |
680 | + | let cl = { | |
681 | + | let cj = ci | |
682 | + | if ($isInstanceOf(cj, "Unit")) | |
683 | + | then getString(aF(aD(z))) | |
684 | + | else if ($isInstanceOf(cj, "String")) | |
687 | 685 | then { | |
688 | - | let | |
689 | - | let | |
690 | - | if (( | |
686 | + | let cm = cj | |
687 | + | let cn = getString(aL(aD(z), cm)) | |
688 | + | if ((cn == cn)) | |
691 | 689 | then { | |
692 | - | let | |
693 | - | if (( | |
694 | - | then | |
690 | + | let co = invoke(this, "processVoteINTERNAL", [bG, cm], nil) | |
691 | + | if ((co == co)) | |
692 | + | then cn | |
695 | 693 | else throw("Strict value is not equal to itself.") | |
696 | 694 | } | |
697 | 695 | else throw("Strict value is not equal to itself.") | |
698 | 696 | } | |
699 | 697 | else throw("Match error") | |
700 | 698 | } | |
701 | - | let | |
702 | - | if ($isInstanceOf( | |
699 | + | let cj = cl | |
700 | + | if ($isInstanceOf(cj, "Unit")) | |
703 | 701 | then { | |
704 | - | let | |
705 | - | let | |
706 | - | if ($isInstanceOf( | |
707 | - | then $Tuple2([IntegerEntry( | |
708 | - | else if ($isInstanceOf( | |
702 | + | let cp = getString(aL(aC, bG)) | |
703 | + | let cq = cp | |
704 | + | if ($isInstanceOf(cq, "Unit")) | |
705 | + | then $Tuple2([IntegerEntry(p, e), DeleteEntry(q), DeleteEntry(r)], true) | |
706 | + | else if ($isInstanceOf(cq, "String")) | |
709 | 707 | then { | |
710 | - | let | |
711 | - | $Tuple2([StringEntry( | |
708 | + | let aX = cq | |
709 | + | $Tuple2([StringEntry(q, aX), DeleteEntry(r)], true) | |
712 | 710 | } | |
713 | 711 | else throw("Match error") | |
714 | 712 | } | |
715 | - | else if ($isInstanceOf( | |
713 | + | else if ($isInstanceOf(cj, "String")) | |
716 | 714 | then { | |
717 | - | let | |
718 | - | $Tuple2([StringEntry( | |
715 | + | let cr = cj | |
716 | + | $Tuple2([StringEntry(r, cr)], true) | |
719 | 717 | } | |
720 | 718 | else throw("Match error") | |
721 | 719 | } | |
722 | 720 | else throw("Match error") | |
723 | 721 | } | |
724 | - | else if (( | |
722 | + | else if ((bt == e)) | |
725 | 723 | then { | |
726 | - | let | |
727 | - | let | |
728 | - | if ($isInstanceOf( | |
724 | + | let ch = getString(q) | |
725 | + | let X = ch | |
726 | + | if ($isInstanceOf(X, "Unit")) | |
729 | 727 | then { | |
730 | - | let | |
731 | - | if ($isInstanceOf( | |
728 | + | let cj = getString(aF(aC)) | |
729 | + | if ($isInstanceOf(cj, "Unit")) | |
732 | 730 | then { | |
733 | - | let | |
734 | - | then [DeleteEntry( | |
735 | - | else [DeleteEntry( | |
736 | - | let | |
737 | - | if (( | |
738 | - | then $Tuple2( | |
731 | + | let bU = if (bV) | |
732 | + | then [DeleteEntry(p), DeleteEntry(v)] | |
733 | + | else [DeleteEntry(p), BooleanEntry(x(cd), true), IntegerEntry(t, i), IntegerEntry(u, br)] | |
734 | + | let cs = aA() | |
735 | + | if ((cs == cs)) | |
736 | + | then $Tuple2(bU, true) | |
739 | 737 | else throw("Strict value is not equal to itself.") | |
740 | 738 | } | |
741 | - | else if ($isInstanceOf( | |
739 | + | else if ($isInstanceOf(cj, "String")) | |
742 | 740 | then { | |
743 | - | let | |
744 | - | $Tuple2([StringEntry( | |
741 | + | let ct = cj | |
742 | + | $Tuple2([StringEntry(q, ct)], true) | |
745 | 743 | } | |
746 | 744 | else throw("Match error") | |
747 | 745 | } | |
748 | - | else if ($isInstanceOf( | |
746 | + | else if ($isInstanceOf(X, "String")) | |
749 | 747 | then { | |
750 | - | let | |
751 | - | let | |
752 | - | if (( | |
748 | + | let bG = X | |
749 | + | let cp = getString(aL(aC, bG)) | |
750 | + | if ((cp == cp)) | |
753 | 751 | then { | |
754 | - | let | |
755 | - | let | |
756 | - | if ($isInstanceOf( | |
757 | - | then | |
758 | - | else throw(($getType( | |
752 | + | let bZ = { | |
753 | + | let ab = invoke(this, "processPoolINTERNAL", [bG, bV], nil) | |
754 | + | if ($isInstanceOf(ab, "Boolean")) | |
755 | + | then ab | |
756 | + | else throw(($getType(ab) + " couldn't be cast to Boolean")) | |
759 | 757 | } | |
760 | - | if (( | |
761 | - | then if ( | |
758 | + | if ((bZ == bZ)) | |
759 | + | then if (bZ) | |
762 | 760 | then $Tuple2(nil, true) | |
763 | 761 | else { | |
764 | - | let | |
765 | - | if ($isInstanceOf( | |
762 | + | let cj = cp | |
763 | + | if ($isInstanceOf(cj, "Unit")) | |
766 | 764 | then { | |
767 | - | let | |
768 | - | then [DeleteEntry( | |
769 | - | else [DeleteEntry( | |
770 | - | let | |
771 | - | if (( | |
772 | - | then $Tuple2( | |
765 | + | let bU = if (bV) | |
766 | + | then [DeleteEntry(p), DeleteEntry(v), DeleteEntry(q)] | |
767 | + | else [DeleteEntry(p), BooleanEntry(x(cd), true), IntegerEntry(t, i), IntegerEntry(u, br), DeleteEntry(q)] | |
768 | + | let cs = aA() | |
769 | + | if ((cs == cs)) | |
770 | + | then $Tuple2(bU, true) | |
773 | 771 | else throw("Strict value is not equal to itself.") | |
774 | 772 | } | |
775 | - | else if ($isInstanceOf( | |
773 | + | else if ($isInstanceOf(cj, "String")) | |
776 | 774 | then { | |
777 | - | let | |
778 | - | $Tuple2([StringEntry( | |
775 | + | let ct = cj | |
776 | + | $Tuple2([StringEntry(q, ct)], true) | |
779 | 777 | } | |
780 | 778 | else throw("Match error") | |
781 | 779 | } | |
782 | 780 | else throw("Strict value is not equal to itself.") | |
783 | 781 | } | |
784 | 782 | else throw("Strict value is not equal to itself.") | |
785 | 783 | } | |
786 | 784 | else throw("Match error") | |
787 | 785 | } | |
788 | - | else | |
786 | + | else S("finalization is broken") | |
789 | 787 | } | |
790 | 788 | ||
791 | 789 | ||
792 | 790 | ||
793 | - | @Callable(bc) | |
794 | - | func finalizeWrapper (cv) = { | |
795 | - | let cw = addressFromStringValue(getStringValue(this, m)) | |
796 | - | let cx = { | |
797 | - | let ac = invoke(this, "finalizeHelper", nil, nil) | |
798 | - | if ($isInstanceOf(ac, "Boolean")) | |
799 | - | then ac | |
800 | - | else throw(($getType(ac) + " couldn't be cast to Boolean")) | |
791 | + | @Callable(bb) | |
792 | + | func finalizeWrapper (cu) = { | |
793 | + | let cv = { | |
794 | + | let ab = invoke(this, "finalizeHelper", nil, nil) | |
795 | + | if ($isInstanceOf(ab, "Boolean")) | |
796 | + | then ab | |
797 | + | else throw(($getType(ab) + " couldn't be cast to Boolean")) | |
801 | 798 | } | |
802 | - | if ((cx == cx)) | |
803 | - | then if (!(cx)) | |
804 | - | then if ((cv == 0)) | |
805 | - | then T("Current voting is not over yet") | |
806 | - | else { | |
807 | - | let cy = invoke(cw, "finalize", nil, nil) | |
808 | - | if ((cy == cy)) | |
809 | - | then $Tuple2(nil, unit) | |
810 | - | else throw("Strict value is not equal to itself.") | |
811 | - | } | |
799 | + | if ((cv == cv)) | |
800 | + | then if (!(cv)) | |
801 | + | then if ((cu == 0)) | |
802 | + | then S("Current voting is not over yet") | |
803 | + | else $Tuple2(nil, unit) | |
812 | 804 | else { | |
813 | - | let | |
814 | - | if (( | |
805 | + | let cw = valueOrElse(getInteger(this, k), c) | |
806 | + | if ((cw > cu)) | |
815 | 807 | then { | |
816 | - | let | |
817 | - | if (( | |
808 | + | let cx = invoke(this, "finalizeWrapper", [(cu + 1)], nil) | |
809 | + | if ((cx == cx)) | |
818 | 810 | then $Tuple2(nil, unit) | |
819 | 811 | else throw("Strict value is not equal to itself.") | |
820 | 812 | } | |
821 | 813 | else $Tuple2(nil, unit) | |
822 | 814 | } | |
823 | 815 | else throw("Strict value is not equal to itself.") | |
824 | 816 | } | |
825 | 817 | ||
826 | 818 | ||
827 | 819 | ||
828 | - | @Callable( | |
820 | + | @Callable(bb) | |
829 | 821 | func finalize () = { | |
830 | - | let | |
831 | - | if (( | |
822 | + | let cx = invoke(this, "finalizeWrapper", [0], nil) | |
823 | + | if ((cx == cx)) | |
832 | 824 | then $Tuple2(nil, unit) | |
833 | 825 | else throw("Strict value is not equal to itself.") | |
834 | 826 | } | |
835 | 827 | ||
836 | 828 | ||
837 | 829 | ||
838 | - | @Callable( | |
839 | - | func containsNodeREADONLY ( | |
830 | + | @Callable(bb) | |
831 | + | func containsNodeREADONLY (aG,aK) = $Tuple2(nil, aM(aG, aK)) | |
840 | 832 | ||
841 | 833 | ||
842 | 834 | ||
843 | - | @Callable( | |
844 | - | func insertNode ( | |
845 | - | let | |
846 | - | if (( | |
847 | - | then $Tuple2( | |
835 | + | @Callable(bb) | |
836 | + | func insertNode (aG,aK) = { | |
837 | + | let bH = bd(bb) | |
838 | + | if ((bH == bH)) | |
839 | + | then $Tuple2(aQ(aG, aK), unit) | |
848 | 840 | else throw("Strict value is not equal to itself.") | |
849 | 841 | } | |
850 | 842 | ||
851 | 843 | ||
852 | 844 | ||
853 | - | @Callable( | |
854 | - | func deleteNode ( | |
855 | - | let | |
856 | - | if (( | |
857 | - | then $Tuple2( | |
845 | + | @Callable(bb) | |
846 | + | func deleteNode (aG,aK) = { | |
847 | + | let bH = bd(bb) | |
848 | + | if ((bH == bH)) | |
849 | + | then $Tuple2(aT(aG, aK), unit) | |
858 | 850 | else throw("Strict value is not equal to itself.") | |
859 | 851 | } | |
860 | 852 | ||
861 | 853 | ||
862 | - | ||
863 | - | @Callable(bc) | |
864 | - | func isFinalizationInProgress () = { | |
865 | - | let bu = getInteger(this, q) | |
866 | - | let cA = (bu != unit) | |
867 | - | $Tuple2(nil, cA) | |
868 | - | } | |
869 | - | ||
870 | - | ||
871 | - | @Verifier(cB) | |
872 | - | func cC () = { | |
873 | - | let cD = { | |
874 | - | let Y = aZ() | |
875 | - | if ($isInstanceOf(Y, "ByteVector")) | |
854 | + | @Verifier(cy) | |
855 | + | func cz () = { | |
856 | + | let cA = { | |
857 | + | let X = aY() | |
858 | + | if ($isInstanceOf(X, "ByteVector")) | |
876 | 859 | then { | |
877 | - | let | |
878 | - | | |
860 | + | let bc = X | |
861 | + | bc | |
879 | 862 | } | |
880 | - | else if ($isInstanceOf( | |
881 | - | then | |
863 | + | else if ($isInstanceOf(X, "Unit")) | |
864 | + | then cy.senderPublicKey | |
882 | 865 | else throw("Match error") | |
883 | 866 | } | |
884 | - | sigVerify( | |
867 | + | sigVerify(cy.bodyBytes, cy.proofs[0], cA) | |
885 | 868 | } | |
886 | 869 |
github/deemru/w8io/169f3d6 321.04 ms ◑![]()