tx · 5HmkgC4yPdmKxBECrSjaNrXpyJUdUC5mTa1Xgq85b2ru 3N9Zi6AcWcGbM23jQJ4fnzFsoHoTsxYDznr: -0.02800000 Waves 2024.04.19 09:47 [3069306] smart account 3N9Zi6AcWcGbM23jQJ4fnzFsoHoTsxYDznr > SELF 0.00000000 Waves
{ "type": 13, "id": "5HmkgC4yPdmKxBECrSjaNrXpyJUdUC5mTa1Xgq85b2ru", "fee": 2800000, "feeAssetId": null, "timestamp": 1713509277468, "version": 2, "chainId": 84, "sender": "3N9Zi6AcWcGbM23jQJ4fnzFsoHoTsxYDznr", "senderPublicKey": "GFbasS3jufhZkK4xR7tdTjjnP8K33KvJFEDHRtxXDkaJ", "proofs": [ "3Hsx2wmkpNU6YuxUDGLkgZXgX6y9mWEYqPQFRjSR8zjfgWgQ7stHURBqDbrAG8H4ifQDm1xScTyELQ7PoB4Z2btj" ], "script": "base64:BgKGHQgCEgQKAggBEgcKBQgICAgBEgQKAggIEgUKAwgIARIECgIICBIDCgEBEgMKAQESAwoBCBIECgIICBIECgIIBBIAEgMKAQESABIECgIICBIECgIICBIECgIICBIAEgQKAggIEgUKAwgIASIJc2VwYXJhdG9yIg5wb29sV2VpZ2h0TXVsdCIPbWF4RGVwdGhEZWZhdWx0IhlmaW5hbGl6YXRpb25TdGFnZUJhbGFuY2VzIhZmaW5hbGl6YXRpb25TdGFnZVRvdGFsIhdmaW5hbGl6YXRpb25TdGFnZVNoYXJlcyILd2F2ZXNTdHJpbmciEHBvb2xTdGF0dXNBY3RpdmUiFXBvb2xTdGF0dXNQdXREaXNhYmxlZCIZcG9vbFN0YXR1c01hdGNoZXJEaXNhYmxlZCIScG9vbFN0YXR1c1NodXRkb3duIg5rZXlFcG9jaExlbmd0aCIRa2V5RXBvY2hMZW5ndGhOZXciFWtleUVwb2NoTGVuZ3RoQnlFcG9jaCIFZXBvY2giD2tleUN1cnJlbnRFcG9jaCILa2V5TWF4RGVwdGgiEGtleVJlc3VtcHRpb25GZWUiImtleVZvdGluZ0VtaXNzaW9uQ2FuZGlkYXRlQ29udHJhY3QiHWtleVZvdGluZ0VtaXNzaW9uUmF0ZUNvbnRyYWN0IhJrZXlGYWN0b3J5Q29udHJhY3QiE2tleUJvb3N0aW5nQ29udHJhY3QiEmtleVN0YWtpbmdDb250cmFjdCIWa2V5QXNzZXRzU3RvcmVDb250cmFjdCIUa2V5RmluYWxpemF0aW9uU3RhZ2UiC2tleU5leHRQb29sIgtrZXlOZXh0VXNlciIOa2V5U3RhcnRIZWlnaHQiEWtleUN1cnJlbnRFcG9jaFVpIhBrZXlTdGFydEhlaWdodFVpIh1rZXlGaW5hbGl6YXRpb25TaG91bGRCZUZvcmNlZCIWa2V5QWxsb3dlZExwU2NyaXB0SGFzaCIca2V5QWxsb3dlZExwU3RhYmxlU2NyaXB0SGFzaCIVa2V5U3RhcnRIZWlnaHRCeUVwb2NoIgxrZXlGaW5hbGl6ZWQiCWtleUluTGlzdCIEcG9vbCILJHQwMjI0NDIyODQiDWFtb3VudEFzc2V0SWQiDHByaWNlQXNzZXRJZCIHa2V5VXNlZCIHYWRkcmVzcyIHa2V5Vm90ZSILJHQwMjU1ODI1OTgiD2tleVZvdGluZ1Jlc3VsdCILJHQwMjc4MDI4MjAiFWtleVZvdGluZ1Jlc3VsdFN0YWtlZCIMbHBBc3NldElkU3RyIgxrZXlQb29sU2hhcmUiCyR0MDMxNDEzMTgxIg1rZXlUb3RhbFZvdGVzIg9rZXlTdGFrZWRCeVVzZXIiDnVzZXJBZGRyZXNzU3RyIgd3cmFwRXJyIgNtc2ciCHRocm93RXJyIg5nZXRWYWx1ZU9yRmFpbCIDa2V5IgR0eXBlIgVlcnJvciIHJG1hdGNoMCIDc3RyIgNpbnQiDGdldFN0ck9yRmFpbCIBQCIMZ2V0SW50T3JGYWlsIgxwb29sVG9TdHJpbmciDHN0cmluZ1RvUG9vbCIFcGFydHMiD2ZhY3RvcnlDb250cmFjdCIaSWR4RmFjdG9yeUNmZ0d3eFJld2FyZERhcHAiDWtleUZhY3RvcnlDZmciFHJlYWRGYWN0b3J5Q2ZnT3JGYWlsIgdmYWN0b3J5IhlnZXRHd3hSZXdhcmRBZGRyZXNzT3JGYWlsIgpmYWN0b3J5Q2ZnIgxwYXJzZUFzc2V0SWQiBWlucHV0Ig9hc3NldElkVG9TdHJpbmciC2dldFBvb2xJbmZvIg5wb29sSW5mb09wdGlvbiIWZ2V0THBBc3NldEJ5UG9vbEFzc2V0cyIfa2V5TWFwcGluZ3NCYXNlQXNzZXQyaW50ZXJuYWxJZCIMYmFzZUFzc2V0U3RyIilrZXlNYXBwaW5nUG9vbEFzc2V0c1RvUG9vbENvbnRyYWN0QWRkcmVzcyIYaW50ZXJuYWxBbW91bnRBc3NldElkU3RyIhdpbnRlcm5hbFByaWNlQXNzZXRJZFN0ciIfa2V5TWFwcGluZ1Bvb2xDb250cmFjdFRvTFBBc3NldCITcG9vbENvbnRyYWN0QWRkcmVzcyIVYW1vdW50QXNzZXRJbnRlcm5hbElkIhRwcmljZUFzc2V0SW50ZXJuYWxJZCIJbHBBc3NldElkIhhjaGVja1d4RW1pc3Npb25Qb29sTGFiZWwiCyR0MDY1NDE2NTgxIhBnd3hSZXdhcmREZXBvc2l0IhJnd3hSZXdhcmRzQ29udHJhY3QiDXBvb2xzTGlzdE5hbWUiEGdldFZvdGVzTGlzdE5hbWUiCyR0MDY5OTg3MDM4IgtrZXlMaXN0SGVhZCIIbGlzdE5hbWUiBG1ldGEiC2tleUxpc3RTaXplIgtrZXlMaXN0UHJldiICaWQiC2tleUxpc3ROZXh0Igxjb250YWluc05vZGUiCmhlYWRPclVuaXQiCnByZXZPclVuaXQiCm5leHRPclVuaXQiEWluc2VydE5vZGVBY3Rpb25zIghsaXN0U2l6ZSIJY2hlY2tOb2RlIhFkZWxldGVOb2RlQWN0aW9ucyIWa2V5TWFuYWdlclZhdWx0QWRkcmVzcyITa2V5TWFuYWdlclB1YmxpY0tleSIcZ2V0TWFuYWdlclZhdWx0QWRkcmVzc09yVGhpcyIBcyIWbWFuYWdlclB1YmxpY0tleU9yVW5pdCITbWFuYWdlclZhdWx0QWRkcmVzcyIJaXNNYW5hZ2VyIgFpIgJwayILbXVzdE1hbmFnZXIiCG11c3RUaGlzIgt1c2VyQWRkcmVzcyIMdGFyZ2V0SGVpZ2h0Ihdib29zdGluZ0NvbnRyYWN0QWRkcmVzcyIfdm90aW5nRW1pc3Npb25DYW5kaWRhdGVDb250cmFjdCIQYm9vc3RpbmdDb250cmFjdCIPc3Rha2luZ0NvbnRyYWN0IgtlcG9jaExlbmd0aCIGY2hlY2tzIg1pbkxpc3RBY3Rpb25zIhhjdXJyZW50RXBvY2hJc05vdERlZmluZWQiEnN0YXJ0SGVpZ2h0QWN0aW9ucyIGYW1vdW50IgtzdGFydEhlaWdodCIJZW5kSGVpZ2h0IhdmaW5hbGl6YXRpb25TdGFnZU9yVW5pdCIEdXNlZCIEdm90ZSIKcG9vbFJlc3VsdCIKdG90YWxWb3RlcyITZ3d4QW1vdW50QXRFbmRUb3RhbCIJYXZhaWxhYmxlIgduZXdWb3RlIgp3eEVtaXNzaW9uIg12b3Rlc0xpc3ROYW1lIhB2b3Rlc0xpc3RBY3Rpb25zIg5uZXdFcG9jaExlbmd0aCILbmV3TWF4RGVwdGgiB3Bvb2xTdHIiC2NoZWNrQ2FsbGVyIg1lcG9jaFByZXZpb3VzIg0kdDAxNzI2MjE3MzAyIgtiYWxhbmNlSXNPayIHYWN0aW9ucyITZGVsZXRlV3hFbWlzc2lvbkludiIPbW9kaWZ5V2VpZ2h0SW52Igtwb29sQWRkcmVzcyIQc2V0UG9vbFN0YXR1c0ludiILbGlzdEFjdGlvbnMiE3N0YXJ0SGVpZ2h0UHJldmlvdXMiE2Vwb2NoTGVuZ3RoUHJldmlvdXMiEWVuZEhlaWdodFByZXZpb3VzIhBjaGVja1RhcmdldEVwb2NoIg0kdDAxOTM0ODE5Mzg4Ihtnd3hBbW91bnRBdEVuZFRvdGFsUHJldmlvdXMiDHZvdGluZ1Jlc3VsdCISdm90ZVByZXZpb3VzT3B0aW9uIgx2b3RlUHJldmlvdXMiGnZvdGluZ1Jlc3VsdFN0YWtlZFByZXZpb3VzIgxzdGFrZWRCeVVzZXIiGXZvdGluZ1Jlc3VsdFN0YWtlZEFjdGlvbnMiBWZvcmNlIgt0YXJnZXRFcG9jaCIMY3VycmVudEVwb2NoIg0kdDAyMTg1ODIxODk4IgFyIhNhc3NldHNTdG9yZUNvbnRyYWN0IgVzaGFyZSINcHJldmlvdXNFcG9jaCIIbmV3RXBvY2giFG5ld0Vwb2NoTGVuZ3RoT3B0aW9uIhVuZXdFcG9jaExlbmd0aEFjdGlvbnMiCnBvb2xPclVuaXQiByRtYXRjaDEiC25leHRQb29sU3RyIg5uZXh0UG9vbE9yVW5pdCIKdXNlck9yVW5pdCIMcG9vbHNIZWFkU3RyIg5uZXh0VXNlck9yVW5pdCIEdXNlciIEbmV4dCIOcHJvY2Vzc1ZvdGVJbnYiByRtYXRjaDIiCG5leHRVc2VyIhNnd3hSZXdhcmREZXBvc2l0SW52Igdjb3VudGVyIhp2b3RpbmdFbWlzc2lvblJhdGVDb250cmFjdCIGcmVzdWx0IgNpbnYiCG1heERlcHRoIhZmaW5hbGl6YXRpb25JblByb2dyZXNzIh9zbGlwcGFnZVRvbGVyYW5jZU9yTWluT3V0QW1vdW50Ig0kdDAzMjg1MDMyOTgwIgpmZWVQYXltZW50Ig9rQm9vc3RpbmdDb25maWciDWlkeENmZ0Fzc2V0SWQiCXd4QXNzZXRJZCITYW1vdW50QXNzZXRWZXJpZmllZCIScHJpY2VBc3NldFZlcmlmaWVkIg1yZXN1bXB0aW9uRmVlIhRscEFzc2V0QmFsYW5jZUJlZm9yZSIJYXV0b1N0YWtlIgNwdXQiDnBvb2xTY3JpcHRIYXNoIhFhbGxvd2VkU2NyaXB0SGFzaCIIaXNTdGFibGUiDGZ1bmN0aW9uTmFtZSITbHBBc3NldEJhbGFuY2VBZnRlciISbHBBc3NldEJhbGFuY2VEaWZmIhZscEFzc2V0VHJhbnNmZXJBY3Rpb25zIhBzZXRXeEVtaXNzaW9uSW52Igpwb29sU3RhdHVzIgJ0eCIGdmVyaWZ5Ig90YXJnZXRQdWJsaWNLZXlMAAFhAgJfXwABYgCAwtcvAAFjAAoAAWQAAAABZQABAAFmAAIAAWcCBVdBVkVTAAFoAAEAAWkAAgABagADAAFrAAQAAWwJALkJAgkAzAgCAgIlcwkAzAgCAgtlcG9jaExlbmd0aAUDbmlsBQFhAAFtCQC5CQIJAMwIAgIEJXMlcwkAzAgCAhBlcG9jaExlbmd0aF9fbmV3BQNuaWwFAWEBAW4BAW8JALkJAgkAzAgCAgQlcyVkCQDMCAICC2Vwb2NoTGVuZ3RoCQDMCAIJAKQDAQUBbwUDbmlsBQFhAAFwCQC5CQIJAMwIAgICJXMJAMwIAgIMY3VycmVudEVwb2NoBQNuaWwFAWEAAXEJALkJAgkAzAgCAgIlcwkAzAgCAghtYXhEZXB0aAUDbmlsBQFhAAFyCQC5CQIJAMwIAgICJXMJAMwIAgINcmVzdW1wdGlvbkZlZQUDbmlsBQFhAAFzCQC5CQIJAMwIAgICJXMJAMwIAgIfdm90aW5nRW1pc3Npb25DYW5kaWRhdGVDb250cmFjdAUDbmlsBQFhAAF0CQC5CQIJAMwIAgICJXMJAMwIAgIadm90aW5nRW1pc3Npb25SYXRlQ29udHJhY3QFA25pbAUBYQABdQkAuQkCCQDMCAICAiVzCQDMCAICD2ZhY3RvcnlDb250cmFjdAUDbmlsBQFhAAF2CQC5CQIJAMwIAgICJXMJAMwIAgIQYm9vc3RpbmdDb250cmFjdAUDbmlsBQFhAAF3CQC5CQIJAMwIAgICJXMJAMwIAgIPc3Rha2luZ0NvbnRyYWN0BQNuaWwFAWEAAXgJALkJAgkAzAgCAgIlcwkAzAgCAhNhc3NldHNTdG9yZUNvbnRyYWN0BQNuaWwFAWEAAXkJALkJAgkAzAgCAgIlcwkAzAgCAhFmaW5hbGl6YXRpb25TdGFnZQUDbmlsBQFhAAF6CQC5CQIJAMwIAgICJXMJAMwIAgIIbmV4dFBvb2wFA25pbAUBYQABQQkAuQkCCQDMCAICAiVzCQDMCAICCG5leHRVc2VyBQNuaWwFAWEAAUIJALkJAgkAzAgCAgIlcwkAzAgCAgtzdGFydEhlaWdodAUDbmlsBQFhAAFDCQC5CQIJAMwIAgICJXMJAMwIAgIOY3VycmVudEVwb2NoVWkFA25pbAUBYQABRAkAuQkCCQDMCAICAiVzCQDMCAICDXN0YXJ0SGVpZ2h0VWkFA25pbAUBYQABRQkAuQkCCQDMCAICAiVzCQDMCAICBWZvcmNlBQNuaWwFAWEBAUYAAhclc19fYWxsb3dlZExwU2NyaXB0SGFzaAEBRwACHSVzX19hbGxvd2VkTHBTdGFibGVTY3JpcHRIYXNoAQFIAQFvCQC5CQIJAMwIAgIEJXMlZAkAzAgCAgtzdGFydEhlaWdodAkAzAgCCQCkAwEFAW8FA25pbAUBYQEBSQEBbwkAuQkCCQDMCAICBCVzJWQJAMwIAgIJZmluYWxpemVkCQDMCAIJAKQDAQUBbwUDbmlsBQFhAQFKAQFLBAFMBQFLBAFNCAUBTAJfMQQBTggFAUwCXzIJALkJAgkAzAgCAgYlcyVzJXMJAMwIAgIGaW5MaXN0CQDMCAIFAU0JAMwIAgUBTgUDbmlsBQFhAQFPAgFQAW8JALkJAgkAzAgCAgYlcyVzJWQJAMwIAgIEdXNlZAkAzAgCCQClCAEFAVAJAMwIAgkApAMBBQFvBQNuaWwFAWEBAVEDAUsBUAFvBAFSBQFLBAFNCAUBUgJfMQQBTggFAVICXzIJALkJAgkAzAgCAgolcyVzJXMlcyVkCQDMCAICBHZvdGUJAMwIAgUBTQkAzAgCBQFOCQDMCAIJAKUIAQUBUAkAzAgCCQCkAwEFAW8FA25pbAUBYQEBUwIBSwFvBAFUBQFLBAFNCAUBVAJfMQQBTggFAVQCXzIJALkJAgkAzAgCAgglcyVzJXMlZAkAzAgCAgx2b3RpbmdSZXN1bHQJAMwIAgUBTQkAzAgCBQFOCQDMCAIJAKQDAQUBbwUDbmlsBQFhAQFVAgFWAW8JALkJAgkAzAgCAgYlcyVzJWQJAMwIAgISdm90aW5nUmVzdWx0U3Rha2VkCQDMCAIFAVYJAMwIAgkApAMBBQFvBQNuaWwFAWEBAVcCAUsBbwQBWAUBSwQBTQgFAVgCXzEEAU4IBQFYAl8yCQC5CQIJAMwIAgIIJXMlcyVzJWQJAMwIAgIJcG9vbFNoYXJlCQDMCAIFAU0JAMwIAgUBTgkAzAgCCQCkAwEFAW8FA25pbAUBYQEBWQEBbwkAuQkCCQDMCAICBCVzJWQJAMwIAgIKdG90YWxWb3RlcwkAzAgCCQCkAwEFAW8FA25pbAUBYQEBWgIBVgJhYQkAuQkCCQDMCAICBiVzJXMlcwkAzAgCAgZzdGFrZWQJAMwIAgUCYWEJAMwIAgUBVgUDbmlsBQFhAQJhYgECYWMJALkJAgkAzAgCAhV2b3RpbmdfZW1pc3Npb24ucmlkZToJAMwIAgUCYWMFA25pbAIBIAECYWQBAmFjCQACAQkBAmFiAQUCYWMBAmFlAwFQAmFmAmFnBAJhaAkBAmFiAQkAuQkCCQDMCAICCm1hbmRhdG9yeSAJAMwIAgkApQgBBQFQCQDMCAICAS4JAMwIAgUCYWYJAMwIAgIPIGlzIG5vdCBkZWZpbmVkBQNuaWwCAAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCBAJhaQUCYWcDCQABAgUCYWkCBlN0cmluZwQCYWoFAmFpCQCdCAIFAVAFAmFmAwkAAQIFAmFpAgNJbnQEAmFrBQJhaQkAmggCBQFQBQJhZgkBAmFkAQISaW52YWxpZCBlbnRyeSB0eXBlBQJhaAECYWwCAVACYWYKAAJhbQkBAmFlAwUBUAUCYWYCAAMJAAECBQJhbQIGU3RyaW5nBQJhbQkAAgEJAKwCAgkAAwEFAmFtAhsgY291bGRuJ3QgYmUgY2FzdCB0byBTdHJpbmcBAmFuAgFQAmFmCgACYW0JAQJhZQMFAVAFAmFmAAADCQABAgUCYW0CA0ludAUCYW0JAAIBCQCsAgIJAAMBBQJhbQIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50AQJhbwEBSwkArAICCQCsAgIIBQFLAl8xBQFhCAUBSwJfMgECYXABAmFqBAJhcQkAtQkCBQJhagUBYQMJAAACCQCQAwEFAmFxAAIJAJQKAgkAkQMCBQJhcQAACQCRAwIFAmFxAAEJAQJhZAECE2ludmFsaWQgcG9vbCBzdHJpbmcAAmFyCQERQGV4dHJOYXRpdmUoMTA2MikBCQECYWwCBQR0aGlzBQF1AAJhcwAKAQJhdAACESVzX19mYWN0b3J5Q29uZmlnAQJhdQECYXYJALUJAgkBAmFsAgUCYXYJAQJhdAAFAWEBAmF3AQJheAkBEUBleHRyTmF0aXZlKDEwNjIpAQkAkQMCBQJheAUCYXMBAmF5AQJhegMJAAACBQJhegUBZwUEdW5pdAkA2QQBBQJhegECYUEBAmF6AwkAAAIFAmF6BQR1bml0BQFnCQDYBAEJAQV2YWx1ZQEFAmF6AQJhQgIBTQFOBAJhQwoAAmFtCQD8BwQFAmFyAhBwb29sSW5mb1JFQURPTkxZCQDMCAIFAU0JAMwIAgUBTgUDbmlsBQNuaWwDCQABAgUCYW0CFShBZGRyZXNzLCBCeXRlVmVjdG9yKQUCYW0FBHVuaXQFAmFDAQJhRAIBTQFOCgECYUUBAmFGCQCsAgICKCVzJXMlc19fbWFwcGluZ3NfX2Jhc2VBc3NldDJpbnRlcm5hbElkX18FAmFGCgECYUcCAmFIAmFJCQCsAgIJAKwCAgkArAICCQCsAgICCiVkJWQlcyVzX18JAKQDAQUCYUgCAl9fCQCkAwEFAmFJAiNfX21hcHBpbmdzX19wb29sQXNzZXRzMlBvb2xDb250cmFjdAoBAmFKAQJhSwkArAICCQCsAgICCCVzJXMlc19fBQJhSwIgX19tYXBwaW5nc19fcG9vbENvbnRyYWN0MkxwQXNzZXQEAmFMCQECYW4CBQJhcgkBAmFFAQUBTQQCYU0JAQJhbgIFAmFyCQECYUUBBQFOBAJhSwkBAmFsAgUCYXIJAQJhRwIFAmFMBQJhTQQCYU4JAQJhbAIFAmFyCQECYUoBBQJhSwUCYU4BAmFPAQFLBAJhUAUBSwQBTQgFAmFQAl8xBAFOCAUCYVACXzIKAAJhbQkA/AcEBQJhcgIYY2hlY2tXeEVtaXNzaW9uUG9vbExhYmVsCQDMCAIFAU0JAMwIAgUBTgUDbmlsBQNuaWwDCQABAgUCYW0CB0Jvb2xlYW4FAmFtCQACAQkArAICCQADAQUCYW0CHCBjb3VsZG4ndCBiZSBjYXN0IHRvIEJvb2xlYW4BAmFRAAQCYXgJAQJhdQEFAmFyBAJhUgkBAmF3AQUCYXgJAPwHBAUCYVICB2RlcG9zaXQFA25pbAUDbmlsAAJhUwIFcG9vbHMBAmFUAQFLBAJhVQUBSwQBTQgFAmFVAl8xBAFOCAUCYVUCXzIJALkJAgkAzAgCAgV2b3RlcwkAzAgCBQFNCQDMCAIFAU4FA25pbAUBYQECYVYBAmFXBAJhWAMJAAACBQJhVwUCYVMCBCVzJXMCCCVzJXMlcyVzCQC5CQIJAMwIAgUCYVgJAMwIAgUCYVcJAMwIAgIEaGVhZAUDbmlsBQFhAQJhWQECYVcEAmFYAwkAAAIFAmFXBQJhUwIEJXMlcwIIJXMlcyVzJXMJALkJAgkAzAgCBQJhWAkAzAgCBQJhVwkAzAgCAgRzaXplBQNuaWwFAWEBAmFaAgJhVwJiYQQCYVgDCQAAAgUCYVcFAmFTAgglcyVzJXMlcwIKJXMlcyVzJXMlcwkAuQkCCQDMCAIFAmFYCQDMCAIFAmFXCQDMCAIFAmJhCQDMCAICBHByZXYFA25pbAUBYQECYmICAmFXAmJhBAJhWAMJAAACBQJhVwUCYVMCCCVzJXMlcyVzAgolcyVzJXMlcyVzCQC5CQIJAMwIAgUCYVgJAMwIAgUCYVcJAMwIAgUCYmEJAMwIAgIEbmV4dAUDbmlsBQFhAQJiYwICYVcCYmEEAmJkCQCdCAIFBHRoaXMJAQJhVgEFAmFXBAJiZQkAnQgCBQR0aGlzCQECYVoCBQJhVwUCYmEEAmJmCQCdCAIFBHRoaXMJAQJiYgIFAmFXBQJiYQMDCQAAAgUCYmEJAQt2YWx1ZU9yRWxzZQIFAmJkAgAGCQECIT0CBQJiZQUEdW5pdAYJAQIhPQIFAmJmBQR1bml0AQJiZwICYVcCYmEEAmJkCQCdCAIFBHRoaXMJAQJhVgEFAmFXBAJiaAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQECYVkBBQJhVwAABAJiaQMJAQEhAQkBAmJjAgUCYVcFAmJhBgkBAmFkAQILTm9kZSBleGlzdHMDCQAAAgUCYmkFAmJpCQDOCAIJAM4IAgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAmFZAQUCYVcJAGQCBQJiaAABBQNuaWwDCQECIT0CBQJiZAUEdW5pdAkAzAgCCQELU3RyaW5nRW50cnkCCQECYmICBQJhVwUCYmEJAQV2YWx1ZQEFAmJkCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhWgIFAmFXCQEFdmFsdWUBBQJiZAUCYmEFA25pbAUDbmlsCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhVgEFAmFXBQJiYQUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJiagICYVcCYmEEAmJkCQCdCAIFBHRoaXMJAQJhVgEFAmFXBAJiaAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQECYVkBBQJhVwAABAJiZQkAnQgCBQR0aGlzCQECYVoCBQJhVwUCYmEEAmJmCQCdCAIFBHRoaXMJAQJiYgIFAmFXBQJiYQkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYVkBBQJhVwkAZQIFAmJoAAEFA25pbAMDCQECIT0CBQJiZQUEdW5pdAkBAiE9AgUCYmYFBHVuaXQHCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJiYgIFAmFXCQEFdmFsdWUBBQJiZQkBBXZhbHVlAQUCYmYJAMwIAgkBC1N0cmluZ0VudHJ5AgkBAmFaAgUCYVcJAQV2YWx1ZQEFAmJmCQEFdmFsdWUBBQJiZQkAzAgCCQELRGVsZXRlRW50cnkBCQECYVoCBQJhVwUCYmEJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAmJiAgUCYVcFAmJhBQNuaWwDCQECIT0CBQJiZgUEdW5pdAkAzAgCCQELU3RyaW5nRW50cnkCCQECYVYBBQJhVwkBBXZhbHVlAQUCYmYJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAmJiAgUCYVcFAmJhCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhWgIFAmFXCQEFdmFsdWUBBQJiZgUDbmlsAwkBAiE9AgUCYmUFBHVuaXQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAmFaAgUCYVcFAmJhCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJiYgIFAmFXCQEFdmFsdWUBBQJiZQUDbmlsAwkAAAIFAmJhCQELdmFsdWVPckVsc2UCBQJiZAIACQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhVgEFAmFXBQNuaWwJAQJhZAEJAKwCAgkArAICCQCsAgICDmludmFsaWQgbm9kZTogBQJhVwIBLgUCYmEBAmJrAAIXJXNfX21hbmFnZXJWYXVsdEFkZHJlc3MBAmJsAAIUJXNfX21hbmFnZXJQdWJsaWNLZXkBAmJtAAQCYWkJAKIIAQkBAmJrAAMJAAECBQJhaQIGU3RyaW5nBAJibgUCYWkJARFAZXh0ck5hdGl2ZSgxMDYyKQEFAmJuBQR0aGlzAQJibwAEAmJwCQECYm0ABAJhaQkAnQgCBQJicAkBAmJsAAMJAAECBQJhaQIGU3RyaW5nBAJibgUCYWkJANkEAQUCYm4DCQABAgUCYWkCBFVuaXQFBHVuaXQJAAIBAgtNYXRjaCBlcnJvcgECYnEBAmJyBAJhaQkBAmJvAAMJAAECBQJhaQIKQnl0ZVZlY3RvcgQCYnMFAmFpCQAAAggFAmJyD2NhbGxlclB1YmxpY0tleQUCYnMDCQABAgUCYWkCBFVuaXQJAAACCAUCYnIGY2FsbGVyBQR0aGlzCQACAQILTWF0Y2ggZXJyb3IBAmJ0AQJicgMJAQJicQEFAmJyBgkAAgECEXBlcm1pc3Npb24gZGVuaWVkAQJidQECYnIDCQAAAggFAmJyBmNhbGxlcgUEdGhpcwYJAAIBAhFwZXJtaXNzaW9uIGRlbmllZBMCYnIBGGdldFVzZXJHd3hBbW91bnRBdEhlaWdodAICYnYCYncEAmJ4CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBAmFsAgUEdGhpcwUBdgkBAmFiAQIhaW52YWxpZCBib29zdGluZyBjb250cmFjdCBhZGRyZXNzCQCUCgIFA25pbAoAAmFtCQD8BwQFAmJ4AiBnZXRVc2VyR3d4QW1vdW50QXRIZWlnaHRSRUFET05MWQkAzAgCBQJidgkAzAgCBQJidwUDbmlsBQNuaWwDCQABAgUCYW0CA0ludAUCYW0JAAIBCQCsAgIJAAMBBQJhbQIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50AmJyAQtjb25zdHJ1Y3RvcgUCYXICYnkCYnoCYkECYkIEAmJDCQDMCAIJAQJidAEFAmJyCQDMCAIDCQECIT0CCQCmCAEFAmFyBQR1bml0BgIgaW52YWxpZCBmYWN0b3J5IGNvbnRyYWN0IGFkZHJlc3MJAMwIAgMJAQIhPQIJAKYIAQUCYnkFBHVuaXQGAjJpbnZhbGlkIHZvdGluZyBlbWlzc2lvbiBjYW5kaWRhdGUgY29udHJhY3QgYWRkcmVzcwkAzAgCAwkBAiE9AgkApggBBQJiegUEdW5pdAYCIWludmFsaWQgYm9vc3RpbmcgY29udHJhY3QgYWRkcmVzcwkAzAgCAwkBAiE9AgkApggBBQJiQQUEdW5pdAYCIGludmFsaWQgc3Rha2luZyBjb250cmFjdCBhZGRyZXNzCQDMCAIDCQBmAgUCYkIAAAYJAQJhZAECFGludmFsaWQgZXBvY2ggbGVuZ3RoBQNuaWwDCQAAAgUCYkMFAmJDCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgUBdQUCYXIJAMwIAgkBC1N0cmluZ0VudHJ5AgUBcwUCYnkJAMwIAgkBC1N0cmluZ0VudHJ5AgUBdgUCYnoJAMwIAgkBC1N0cmluZ0VudHJ5AgUBdwUCYkEJAMwIAgkBDEludGVnZXJFbnRyeQIFAWwFAmJCBQNuaWwFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYnIBBmNyZWF0ZQIBTQFOBAJiQwkAzAgCAwkAAAIJANgEAQgIBQJicgZjYWxsZXIFYnl0ZXMJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwUBcwIABgkBAmJ0AQUCYnIFA25pbAMJAAACBQJiQwUCYkMEAUsJAJQKAgUBTQUBTgQCYkQJAM4IAgkAzAgCCQEMQm9vbGVhbkVudHJ5AgkBAUoBBQFLBgUDbmlsCQECYmcCBQJhUwkBAmFvAQUBSwQCYkUJAAACCQCaCAIFBHRoaXMFAXAFBHVuaXQEAmJGAwUCYkUEAW8AAAkAzAgCCQEMSW50ZWdlckVudHJ5AgUBcAUBbwkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAUgBBQFvBQZoZWlnaHQJAMwIAgkBDEludGVnZXJFbnRyeQIFAUIFBmhlaWdodAkAzAgCCQEMSW50ZWdlckVudHJ5AgUBQwUBbwkAzAgCCQEMSW50ZWdlckVudHJ5AgUBRAUGaGVpZ2h0BQNuaWwFA25pbAkAlAoCCQDOCAIFAmJEBQJiRgUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJicgEEdm90ZQMBTQFOAmJHBAFLCQCUCgIFAU0FAU4EAW8JAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUBcAAABAJiSAkBAmFuAgUEdGhpcwkBAUgBBQFvBAJiQgkBAmFuAgUEdGhpcwUBbAQCYkkJAGQCBQJiSAUCYkIEAmJKCQCaCAIFBHRoaXMFAXkEAmJLCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQFPAggFAmJyBmNhbGxlcgUBbwAABAJiTAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEBUQMFAUsIBQJicgZjYWxsZXIFAW8AAAQCYk0JAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBAVMCBQFLBQFvAAAEAmJOCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQFZAQUBbwAABAJiTwoAAmFtCQD8BwQFBHRoaXMCGGdldFVzZXJHd3hBbW91bnRBdEhlaWdodAkAzAgCCQDYBAEICAUCYnIGY2FsbGVyBWJ5dGVzCQDMCAIFAmJJBQNuaWwFA25pbAMJAAECBQJhbQIDSW50BQJhbQkAAgEJAKwCAgkAAwEFAmFtAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQEAmJQCQBlAgUCYk8FAmJLBAJiUQkAZAIFAmJMBQJiRwQCYlIJAQJhTwEFAUsEAmJDCQDMCAIDCQECIT0CCQCgCAEJAQFKAQUBSwUEdW5pdAYJAQJhZAECDmludmFsaWQgYXNzZXRzCQDMCAIDCQBmAgUCYkkFBmhlaWdodAYJAQJhZAECDmludmFsaWQgaGVpZ2h0CQDMCAIDCQAAAgUCYkoFBHVuaXQGCQECYWQBAhhmaW5hbGl6YXRpb24gaW4gcHJvZ3Jlc3MJAMwIAgMJAGYCBQJiTwAABgkBAmFkAQITeW91IGRvIG5vdCBoYXZlIGdXWAkAzAgCAwMJAGYCBQJiRwAACQBnAgUCYlAFAmJHBwYJAQJhZAECDmludmFsaWQgYW1vdW50CQDMCAIDBQJiUgYJAQJhZAECHXBvb2wgaGFzbid0IFdYX0VNSVNTSU9OIGxhYmVsBQNuaWwDCQAAAgUCYkMFAmJDBAJiUwkBAmFUAQUBSwQCYWEJAKUIAQgFAmJyBmNhbGxlcgQCYlQDCQECYmMCBQJiUwUCYWEFA25pbAkBAmJnAgUCYlMFAmFhCQCUCgIJAM4IAgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAU8CCAUCYnIGY2FsbGVyBQFvCQBkAgUCYksFAmJHCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBUQMFAUsIBQJicgZjYWxsZXIFAW8FAmJRCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBUwIFAUsFAW8JAGQCBQJiTQUCYkcJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFZAQUBbwkAZAIFAmJOBQJiRwUDbmlsBQJiVAUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJicgEKY2FuY2VsVm90ZQIBTQFOBAFLCQCUCgIFAU0FAU4EAW8JAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUBcAAABAJiSAkBAmFuAgUEdGhpcwkBAUgBBQFvBAJiQgkBAmFuAgUEdGhpcwUBbAQCYkkJAGQCBQJiSAUCYkIEAmJKCQCaCAIFBHRoaXMFAXkEAmJLCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQFPAggFAmJyBmNhbGxlcgUBbwAABAJiTAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEBUQMFAUsIBQJicgZjYWxsZXIFAW8AAAQCYk0JAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBAVMCBQFLBQFvAAAEAmJOCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQFZAQUBbwAABAJiQwkAzAgCAwkBAiE9AgkAoAgBCQEBSgEFAUsFBHVuaXQGCQECYWQBAg5pbnZhbGlkIGFzc2V0cwkAzAgCAwkAZgIFAmJJBQZoZWlnaHQGCQECYWQBAg5pbnZhbGlkIGhlaWdodAkAzAgCAwkAAAIFAmJKBQR1bml0BgkBAmFkAQIYZmluYWxpemF0aW9uIGluIHByb2dyZXNzCQDMCAIDCQBmAgUCYkwAAAYJAQJhZAECB25vIHZvdGUFA25pbAMJAAACBQJiQwUCYkMEAmJTCQECYVQBBQFLBAJhYQkApQgBCAUCYnIGY2FsbGVyCQCUCgIJAM4IAgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAU8CCAUCYnIGY2FsbGVyBQFvCQCWAwEJAMwIAgkAZQIFAmJLBQJiTAkAzAgCAAAFA25pbAkAzAgCCQELRGVsZXRlRW50cnkBCQEBUQMFAUsIBQJicgZjYWxsZXIFAW8JAMwIAgkBDEludGVnZXJFbnRyeQIJAQFTAgUBSwUBbwkAZQIFAmJNBQJiTAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAVkBBQFvCQBlAgUCYk4FAmJMBQNuaWwJAQJiagIFAmJTBQJhYQUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJicgEOc2V0RXBvY2hMZW5ndGgBAmJVBAJiQwkAzAgCCQECYnQBBQJicgkAzAgCAwkAZgIFAmJVAAAGCQECYWQBAhRpbnZhbGlkIGVwb2NoIGxlbmd0aAUDbmlsAwkAAAIFAmJDBQJiQwkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQFtBQJiVQUDbmlsBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJyAQtzZXRNYXhEZXB0aAECYlYEAmJDCQDMCAIJAQJidAEFAmJyCQDMCAIDCQBmAgUCYlYAAAYJAQJhZAECEWludmFsaWQgbWF4IGRlcHRoBQNuaWwDCQAAAgUCYkMFAmJDCQCUCgIJAMwIAgkBDEludGVnZXJFbnRyeQIFAXEFAmJWBQNuaWwFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYnIBGnByb2Nlc3NQb29sQmFsYW5jZUlOVEVSTkFMAQJiVwQCYlgJAQJidQEFAmJyAwkAAAIFAmJYBQJiWAQBbwkBAmFuAgUEdGhpcwUBcAQCYlkJAGUCBQFvAAEEAUsJAQJhcAEFAmJXBAJiWgUBSwQBTQgFAmJaAl8xBAFOCAUCYloCXzIEAmFOCQECYUQCBQFNBQFOBAJjYQoAAmFtCQD8BwQFAmFyAgxjaGVja0JhbGFuY2UJAMwIAgUCYU4FA25pbAUDbmlsAwkAAQIFAmFtAgdCb29sZWFuBQJhbQkAAgEJAKwCAgkAAwEFAmFtAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuBAJjYgMJAQEhAQUCY2EEAmNjCQD8BwQFAmFyAhlkZWxldGVXeEVtaXNzaW9uUG9vbExhYmVsCQDMCAIFAU0JAMwIAgUBTgUDbmlsBQNuaWwDCQAAAgUCY2MFAmNjBAJjZAkA/AcEBQJhcgIMbW9kaWZ5V2VpZ2h0CQDMCAIFAmFOCQDMCAIAAAUDbmlsBQNuaWwDCQAAAgUCY2QFAmNkBAJjZQgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkBAmFCAgUBTQUBTgkBAmFiAQIOaW52YWxpZCBhc3NldHMCXzEEAmNmCQD8BwQFAmFyAgptYW5hZ2VQb29sCQDMCAIJAKUIAQUCY2UJAMwIAgUBagUDbmlsBQNuaWwDCQAAAgUCY2YFAmNmBAJjZwkAzggCCQDMCAIJAQtEZWxldGVFbnRyeQEJAQFKAQUBSwUDbmlsCQECYmoCBQJhUwkBAmFvAQUBSwkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBVwIFAUsFAmJZAAAFA25pbAUCY2cJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4FA25pbAkAlAoCBQJjYgUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJicgETcHJvY2Vzc1ZvdGVJTlRFUk5BTAICYlcCYWEEAmJYCQECYnUBBQJicgMJAAACBQJiWAUCYlgEAmJ2CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQUCYWEJAQJhYgEJAKwCAgIqcHJvY2Vzc1ZvdGVJTlRFUk5BTDogaW52YWxpZCB1c2VyIGFkZHJlc3MgBQJhYQQBbwkBAmFuAgUEdGhpcwUBcAQCYlkJAGUCBQFvAAEEAmJCCQECYW4CBQR0aGlzBQFsBAJiSAkBAmFuAgUEdGhpcwkBAUgBBQFvBAJiSQkAZAIFAmJIBQJiQgQCY2gJAQJhbgIFBHRoaXMJAQFIAQUCYlkEAmNpCQECYW4CBQR0aGlzCQEBbgEFAmJZBAJjagkAZAIFAmNoBQJjaQQCY2sDCQBnAgUCYlkAAAYJAQJhZAECK3Byb2Nlc3NWb3RlSU5URVJOQUw6IGludmFsaWQgcHJldmlvdXMgZXBvY2gDCQAAAgUCY2sFAmNrBAFLCQECYXABBQJiVwQCY2wFAUsEAU0IBQJjbAJfMQQBTggFAmNsAl8yBAJiTwoAAmFtCQD8BwQFBHRoaXMCGGdldFVzZXJHd3hBbW91bnRBdEhlaWdodAkAzAgCBQJhYQkAzAgCBQJiSQUDbmlsBQNuaWwDCQABAgUCYW0CA0ludAUCYW0JAAIBCQCsAgIJAAMBBQJhbQIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50BAJjbQoAAmFtCQD8BwQFBHRoaXMCGGdldFVzZXJHd3hBbW91bnRBdEhlaWdodAkAzAgCBQJhYQkAzAgCBQJjagUDbmlsBQNuaWwDCQABAgUCYW0CA0ludAUCYW0JAAIBCQCsAgIJAAMBBQJhbQIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50BAJiTgkBC3ZhbHVlT3JFbHNlAgkAnwgBCQEBWQEFAW8AAAQCY24JAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBAVMCBQFLBQFvAAAEAmNvCQCfCAEJAQFRAwUBSwUCYnYFAmJZBAJjcAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCBQJjbwkBAmFiAQkArAICCQCsAgIJAKwCAgkArAICAhRwcm9jZXNzVm90ZUlOVEVSTkFMIAUCYlcCASAFAmFhAhI6IG5vIHByZXZpb3VzIHZvdGUEAmJLCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQFPAgUCYnYFAW8AAAQBVgkBAmFEAgUBTQUBTgQCY3EJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBAVUCBQFWBQJiWQAABAJiQQkBEUBleHRyTmF0aXZlKDEwNjIpAQkBAmFsAgUEdGhpcwUBdwQCY3IJAQt2YWx1ZU9yRWxzZQIJAJoIAgUCYkEJAQFaAgUBVgUCYWEAAAQCY3MDAwkAAAIFAmNyAAAGCQAAAgUCY28FBHVuaXQFA25pbAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAVUCBQFWBQJiWQkAZAIFAmNxBQJjcAUDbmlsBAJhTgkBAmFEAgUBTQUBTgQCYlEDCQBmAgUCY20AAAkAawMFAmNwBQJiTwUCY20AAAQCY2IDAwkAAAIFAmNvBQR1bml0BgkAZwIAAAUCYlEJAQJiagIJAQJhVAEFAUsFAmFhCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBUQMFAUsFAmJ2BQFvBQJiUQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAVkBBQFvCQBkAgUCYk4FAmJRCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBUwIFAUsFAW8JAGQCBQJjbgUCYlEJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFPAgUCYnYFAW8JAGQCBQJiSwUCYlEFA25pbAkAlAoCCQDOCAIFAmNiBQJjcwUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJicgETcHJvY2Vzc1Bvb2xJTlRFUk5BTAICYlcCY3QEAmJYCQECYnUBBQJicgMJAAACBQJiWAUCYlgEAmN1BAJjdgkBAmFuAgUEdGhpcwUBcAMFAmN0BQJjdgkAZQIFAmN2AAEEAmNrAwkAZwIFAmN1AAAGCQECYWQBAilwcm9jZXNzUG9vbElOVEVSTkFMOiBpbnZhbGlkIHRhcmdldCBlcG9jaAMJAAACBQJjawUCY2sEAUsJAQJhcAEFAmJXBAJjdwUBSwQBTQgFAmN3Al8xBAFOCAUCY3cCXzIEAmJBCQERQGV4dHJOYXRpdmUoMTA2MikBCQECYWwCBQR0aGlzBQF3BAJhTgkBAmFEAgUBTQUBTgQCY3gKAAJhbQkA/AcEBQJiQQISdXNlcnNMaXN0VHJhdmVyc2FsCQDMCAIFAmFOBQNuaWwFA25pbAMJAAECBQJhbQIHQm9vbGVhbgUCYW0JAAIBCQCsAgIJAAMBBQJhbQIcIGNvdWxkbid0IGJlIGNhc3QgdG8gQm9vbGVhbgMJAAACBQJjeAUCY3gDBQJjeAkAlAoCBQNuaWwGBAJjeQkBEUBleHRyTmF0aXZlKDEwNjIpAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFAmFyBQF4Ah1pbnZhbGlkIGFzc2V0cyBzdG9yZSBjb250cmFjdAQCYk4JAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBAVkBBQJjdQAABAJjbgkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEBUwIFAUsFAmN1AAAEAmN6AwkAAAIFAmJOAAAAAAkAawMFAmNuBQFiBQJiTgQCY2QJAPwHBAUCYXICDG1vZGlmeVdlaWdodAkAzAgCBQJhTgkAzAgCBQJjegUDbmlsBQNuaWwDCQAAAgUCY2QFAmNkCQCUCgIJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFXAgUBSwUCY3UFAmN6BQNuaWwHCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJyAQ5maW5hbGl6ZUhlbHBlcgAEAmN0CQELdmFsdWVPckVsc2UCCQCgCAEFAUUHBAFvCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFAXAAAAQCY0EJAGUCBQFvAAEEAmJICQECYW4CBQR0aGlzCQEBSAEFAW8EAmJCCQECYW4CBQR0aGlzBQFsBAJiSQkAZAIFAmJIBQJiQgQCYkoJAJoIAgUEdGhpcwUBeQMDAwkAZwIFBmhlaWdodAUCYkkJAAACBQJiSgUEdW5pdAcJAQEhAQUCY3QHBAJjQgkAZAIFAW8AAQQCY0MJAJoIAgUEdGhpcwUBbQQCY0QEAmFpBQJjQwMJAAECBQJhaQIDSW50BAJiVQUCYWkJAMwIAgkBDEludGVnZXJFbnRyeQIFAWwFAmJVCQDMCAIJAQtEZWxldGVFbnRyeQEFAW0FA25pbAMJAAECBQJhaQIEVW5pdAUDbmlsCQACAQILTWF0Y2ggZXJyb3IJAJQKAgkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBSAEFAmNCBQZoZWlnaHQJAMwIAgkBDEludGVnZXJFbnRyeQIFAUIFBmhlaWdodAkAzAgCCQEMSW50ZWdlckVudHJ5AgUBcAUCY0IJAMwIAgkBDEludGVnZXJFbnRyeQIFAXkFAWQJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFuAQUBbwUCYkIFA25pbAUCY0QGAwMFAmN0CQAAAgUCYkoFBHVuaXQHCQCUCgIJAMwIAgkBDEludGVnZXJFbnRyeQIFAXkFAWYFA25pbAYDCQAAAgUCYkoFBHVuaXQJAJQKAgUDbmlsBwMJAAACBQJiSgUBZAQCY0UJAKIIAQUBegQCYWkFAmNFAwkAAQIFAmFpAgRVbml0BAJjRgkAoggBCQECYVYBBQJhUwMJAAECBQJjRgIEVW5pdAkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQF5BQFlCQDMCAIJAQtEZWxldGVFbnRyeQEFAXoFA25pbAYDCQABAgUCY0YCBlN0cmluZwQCY0cFAmNGCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgUBegUCY0cFA25pbAYJAAIBAgtNYXRjaCBlcnJvcgMJAAECBQJhaQIGU3RyaW5nBAJiVwUCYWkEAmNICQCiCAEJAQJiYgIFAmFTBQJiVwMJAAACBQJjSAUCY0gEAmN4CQD8BwQFBHRoaXMCGnByb2Nlc3NQb29sQmFsYW5jZUlOVEVSTkFMCQDMCAIFAmJXBQNuaWwFA25pbAMJAAACBQJjeAUCY3gEAmNGBQJjSAMJAAECBQJjRgIEVW5pdAkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQF5BQFlCQDMCAIJAQtEZWxldGVFbnRyeQEFAXoFA25pbAYDCQABAgUCY0YCBlN0cmluZwQCY0cFAmNGCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgUBegUCY0cFA25pbAYJAAIBAgtNYXRjaCBlcnJvcgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECC01hdGNoIGVycm9yAwkAAAIFAmJKBQFlBAJjRQkAoggBBQF6BAJjSQkAoggBBQFBBAJhaQUCY0UDCQABAgUCYWkCBFVuaXQEAmNGCQCiCAEJAQJhVgEFAmFTAwkAAQIFAmNGAgRVbml0CQCUCgIJAMwIAgkBDEludGVnZXJFbnRyeQIFAXkFAWYJAMwIAgkBC0RlbGV0ZUVudHJ5AQUBegkAzAgCCQELRGVsZXRlRW50cnkBBQFBBQNuaWwGAwkAAQIFAmNGAgZTdHJpbmcEAmNKBQJjRgkAlAoCCQDMCAIJAQtTdHJpbmdFbnRyeQIFAXoFAmNKBQNuaWwGCQACAQILTWF0Y2ggZXJyb3IDCQABAgUCYWkCBlN0cmluZwQCYlcFAmFpBAFLCQECYXABBQJiVwQCY0sEAmNGBQJjSQMJAAECBQJjRgIEVW5pdAkAoggBCQECYVYBCQECYVQBBQFLAwkAAQIFAmNGAgZTdHJpbmcEAmNMBQJjRgQCY00JAKIIAQkBAmJiAgkBAmFUAQUBSwUCY0wDCQAAAgUCY00FAmNNBAJjTgkA/AcEBQR0aGlzAhNwcm9jZXNzVm90ZUlOVEVSTkFMCQDMCAIFAmJXCQDMCAIFAmNMBQNuaWwFA25pbAMJAAACBQJjTgUCY04FAmNNCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQILTWF0Y2ggZXJyb3IEAmNGBQJjSwMJAAECBQJjRgIEVW5pdAQCY0gJAKIIAQkBAmJiAgUCYVMFAmJXBAJjTwUCY0gDCQABAgUCY08CBFVuaXQJAJQKAgkAzAgCCQEMSW50ZWdlckVudHJ5AgUBeQUBZgkAzAgCCQELRGVsZXRlRW50cnkBBQF6CQDMCAIJAQtEZWxldGVFbnRyeQEFAUEFA25pbAYDCQABAgUCY08CBlN0cmluZwQCYm4FAmNPCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgUBegUCYm4JAMwIAgkBC0RlbGV0ZUVudHJ5AQUBQQUDbmlsBgkAAgECC01hdGNoIGVycm9yAwkAAQIFAmNGAgZTdHJpbmcEAmNQBQJjRgkAlAoCCQDMCAIJAQtTdHJpbmdFbnRyeQIFAUEFAmNQBQNuaWwGCQACAQILTWF0Y2ggZXJyb3IJAAIBAgtNYXRjaCBlcnJvcgMJAAACBQJiSgUBZgQCY0UJAKIIAQUBegQCYWkFAmNFAwkAAQIFAmFpAgRVbml0BAJjRgkAoggBCQECYVYBBQJhUwMJAAECBQJjRgIEVW5pdAQCY2IDBQJjdAkAzAgCCQELRGVsZXRlRW50cnkBBQF5CQDMCAIJAQtEZWxldGVFbnRyeQEFAUUFA25pbAkAzAgCCQELRGVsZXRlRW50cnkBBQF5CQDMCAIJAQxCb29sZWFuRW50cnkCCQEBSQEFAmNBBgkAzAgCCQEMSW50ZWdlckVudHJ5AgUBQwUBbwkAzAgCCQEMSW50ZWdlckVudHJ5AgUBRAUCYkgFA25pbAQCY1EJAQJhUQADCQAAAgUCY1EFAmNRCQCUCgIFAmNiBgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgMJAAECBQJjRgIGU3RyaW5nBAJjRwUCY0YJAJQKAgkAzAgCCQELU3RyaW5nRW50cnkCBQF6BQJjRwUDbmlsBgkAAgECC01hdGNoIGVycm9yAwkAAQIFAmFpAgZTdHJpbmcEAmJXBQJhaQQCY0gJAKIIAQkBAmJiAgUCYVMFAmJXAwkAAAIFAmNIBQJjSAQCY3gKAAJhbQkA/AcEBQR0aGlzAhNwcm9jZXNzUG9vbElOVEVSTkFMCQDMCAIFAmJXCQDMCAIFAmN0BQNuaWwFA25pbAMJAAECBQJhbQIHQm9vbGVhbgUCYW0JAAIBCQCsAgIJAAMBBQJhbQIcIGNvdWxkbid0IGJlIGNhc3QgdG8gQm9vbGVhbgMJAAACBQJjeAUCY3gDBQJjeAkAlAoCBQNuaWwGBAJjRgUCY0gDCQABAgUCY0YCBFVuaXQEAmNiAwUCY3QJAMwIAgkBC0RlbGV0ZUVudHJ5AQUBeQkAzAgCCQELRGVsZXRlRW50cnkBBQFFCQDMCAIJAQtEZWxldGVFbnRyeQEFAXoFA25pbAkAzAgCCQELRGVsZXRlRW50cnkBBQF5CQDMCAIJAQxCb29sZWFuRW50cnkCCQEBSQEFAmNBBgkAzAgCCQEMSW50ZWdlckVudHJ5AgUBQwUBbwkAzAgCCQEMSW50ZWdlckVudHJ5AgUBRAUCYkgJAMwIAgkBC0RlbGV0ZUVudHJ5AQUBegUDbmlsBAJjUQkBAmFRAAMJAAACBQJjUQUCY1EJAJQKAgUCY2IGCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAwkAAQIFAmNGAgZTdHJpbmcEAmNHBQJjRgkAlAoCCQDMCAIJAQtTdHJpbmdFbnRyeQIFAXoFAmNHBQNuaWwGCQACAQILTWF0Y2ggZXJyb3IJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAgtNYXRjaCBlcnJvcgkBAmFkAQIWZmluYWxpemF0aW9uIGlzIGJyb2tlbgJicgEPZmluYWxpemVXcmFwcGVyAQJjUgQCY1MJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMFAXQEAmNUCgACYW0JAPwHBAUEdGhpcwIOZmluYWxpemVIZWxwZXIFA25pbAUDbmlsAwkAAQIFAmFtAgdCb29sZWFuBQJhbQkAAgEJAKwCAgkAAwEFAmFtAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuAwkAAAIFAmNUBQJjVAMJAQEhAQUCY1QDCQAAAgUCY1IAAAkBAmFkAQIeQ3VycmVudCB2b3RpbmcgaXMgbm90IG92ZXIgeWV0BAJjVQkA/AcEBQJjUwIIZmluYWxpemUFA25pbAUDbmlsAwkAAAIFAmNVBQJjVQkAlAoCBQNuaWwFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4EAmNWCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFAXEFAWMDCQBmAgUCY1YFAmNSBAJjVQkA/AcEBQR0aGlzAg9maW5hbGl6ZVdyYXBwZXIJAMwIAgkAZAIFAmNSAAEFA25pbAUDbmlsAwkAAAIFAmNVBQJjVQkAlAoCBQNuaWwFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAJQKAgUDbmlsBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJyAQhmaW5hbGl6ZQAEAmNVCQD8BwQFBHRoaXMCD2ZpbmFsaXplV3JhcHBlcgkAzAgCAAAFA25pbAUDbmlsAwkAAAIFAmNVBQJjVQkAlAoCBQNuaWwFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYnIBFGNvbnRhaW5zTm9kZVJFQURPTkxZAgJhVwJiYQkAlAoCBQNuaWwJAQJiYwIFAmFXBQJiYQJicgEKaW5zZXJ0Tm9kZQICYVcCYmEEAmJYCQECYnQBBQJicgMJAAACBQJiWAUCYlgJAJQKAgkBAmJnAgUCYVcFAmJhBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJyAQpkZWxldGVOb2RlAgJhVwJiYQQCYlgJAQJidAEFAmJyAwkAAAIFAmJYBQJiWAkAlAoCCQECYmoCBQJhVwUCYmEFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYnIBGGlzRmluYWxpemF0aW9uSW5Qcm9ncmVzcwAEAmJKCQCaCAIFBHRoaXMFAXkEAmNXCQECIT0CBQJiSgUEdW5pdAkAlAoCBQNuaWwFAmNXAmJyAQpkZWxldGVQb29sAgFNAU4EAmJYAwMJAAACCAUCYnIGY2FsbGVyBQJhcgYJAQJidAEFAmJyBgkBAmFkAQIRUGVybWlzc2lvbiBkZW5pZWQDCQAAAgUCYlgFAmJYBAJhVwIFcG9vbHMEAUsJAJQKAgUBTQUBTgQCYmEJALkJAgkAzAgCBQFNCQDMCAIFAU4FA25pbAUBYQQCY2IDCQECYmMCBQJhVwUCYmEJAQJiagIFAmFXBQJiYQUDbmlsCQDOCAIJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAUoBBQFLBQNuaWwFAmNiCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJyAQZyZXN1bWUDAU0BTgJjWAQCYkoJAJoIAgUEdGhpcwUBeQQCY1kJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkBAmFCAgUBTQUBTgkBAmFiAQIOaW52YWxpZCBhc3NldHMEAmNlCAUCY1kCXzEEAmFOCAUCY1kCXzIEAmNaCQCRAwIIBQJicghwYXltZW50cwAABAJjeQkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwUBeAQCZGECCiVzX19jb25maWcEAmRiAAEEAmJ6CQERQGV4dHJOYXRpdmUoMTA2MikBCQECYWwCBQR0aGlzBQF2BAJkYwkA2QQBCQCRAwIJALUJAgkBEUBleHRyTmF0aXZlKDEwNTMpAgUCYnoFAmRhBQFhBQJkYgQCZGQKAAJhbQkA/AcEBQJjeQISaXNWZXJpZmllZFJFQURPTkxZCQDMCAIFAU0FA25pbAUDbmlsAwkAAQIFAmFtAgdCb29sZWFuBQJhbQkAAgEJAKwCAgkAAwEFAmFtAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuBAJkZQoAAmFtCQD8BwQFAmN5AhJpc1ZlcmlmaWVkUkVBRE9OTFkJAMwIAgUBTgUDbmlsBQNuaWwDCQABAgUCYW0CB0Jvb2xlYW4FAmFtCQACAQkArAICCQADAQUCYW0CHCBjb3VsZG4ndCBiZSBjYXN0IHRvIEJvb2xlYW4EAmRmCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUEdGhpcwUBcgIWaW52YWxpZCByZXN1bXB0aW9uIGZlZQQCYkMJAMwIAgMJAAACBQJiSgUEdW5pdAYJAQJhZAECG2ZpbmFsaXphdGlvbiBpcyBpbiBwcm9ncmVzcwkAzAgCAwkAAAIIBQJjWgdhc3NldElkBQJkYwYJAQJhZAECHGludmFsaWQgZmVlIHBheW1lbnQgYXNzZXQgaWQJAMwIAgMJAAACCAUCY1oGYW1vdW50BQJkZgYJAQJhZAECGmludmFsaWQgZmVlIHBheW1lbnQgYW1vdW50CQDMCAIDAwUCZGQFAmRlBwYJAQJhZAECHmJvdGggYXNzZXRzIHNob3VsZCBiZSB2ZXJpZmllZAUDbmlsAwkAAAIFAmJDBQJiQwQCZGcJAPAHAgUEdGhpcwUCYU4DCQAAAgUCZGcFAmRnBAJkaAcEAmRpAwkAAAIJAJADAQgFAmJyCHBheW1lbnRzAAEEAmNhCgACYW0JAPwHBAUCYXICDGNoZWNrQmFsYW5jZQkAzAgCCQECYUEBBQJhTgUDbmlsBQNuaWwDCQABAgUCYW0CB0Jvb2xlYW4FAmFtCQACAQkArAICCQADAQUCYW0CHCBjb3VsZG4ndCBiZSBjYXN0IHRvIEJvb2xlYW4DBQJjYQYJAQJhZAECGWFzc2V0cyBzaG91bGQgYmUgYXR0YWNoZWQDCQAAAgkAkAMBCAUCYnIIcGF5bWVudHMAAgQCZGoJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA8QcBBQJjZQkBAmFiAQIccG9vbCBhZGRyZXNzIGlzIG5vdCBzY3JpcHRlZAQCZGsJANsEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFAmFyCQEBRwAJAQJhYgECKGFsbG93ZWQgbHAgc3RhYmxlIHNjcmlwdCBoYXNoIGlzIG5vdCBzZXQEAmRsCQAAAgUCZGoFAmRrBAJkbQMFAmRsAgtwdXRPbmVUa25WMgIJcHV0T25lVGtuCQD8BwQFAmNlBQJkbQkAzAgCBQJjWAkAzAgCBQJkaAUDbmlsCQDMCAIJAJEDAggFAmJyCHBheW1lbnRzAAEFA25pbAMJAAACCQCQAwEIBQJicghwYXltZW50cwADCQD8BwQFAmNlAgNwdXQJAMwIAgUCY1gJAMwIAgUCZGgFA25pbAkAzAgCCQCRAwIIBQJicghwYXltZW50cwABCQDMCAIJAJEDAggFAmJyCHBheW1lbnRzAAIFA25pbAkBAmFkAQIVaW52YWxpZCBwYXltZW50cyBzaXplAwkAAAIFAmRpBQJkaQQCZG4JAPAHAgUEdGhpcwUCYU4DCQAAAgUCZG4FAmRuBAJkbwkAZQIFAmRuBQJkZwQCZHADCQBmAgUCZG8AAAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUCYnIGY2FsbGVyBQJkbwUCYU4FA25pbAUDbmlsBAJkcQkA/AcEBQJhcgIWc2V0V3hFbWlzc2lvblBvb2xMYWJlbAkAzAgCBQFNCQDMCAIFAU4FA25pbAUDbmlsAwkAAAIFAmRxBQJkcQQCZHIKAAJhbQkA/AcEBQJhcgIVZ2V0UG9vbFN0YXR1c1JFQURPTkxZCQDMCAIJAKUIAQUCY2UFA25pbAUDbmlsAwkAAQIFAmFtAgNJbnQFAmFtCQACAQkArAICCQADAQUCYW0CGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAQCY2YDCQAAAgUCZHIFAWoJAPwHBAUCYXICCm1hbmFnZVBvb2wJAMwIAgkApQgBBQJjZQkAzAgCBQFoBQNuaWwFA25pbAUEdW5pdAMJAAACBQJjZgUCY2YEAUsJAJQKAgUBTQUBTgQCYkQJAM4IAgkAzAgCCQEMQm9vbGVhbkVudHJ5AgkBAUoBBQFLBgUDbmlsCQECYmcCBQJhUwkBAmFvAQUBSwkAlAoCCQDOCAIFAmJEBQJkcAUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgECZHMBAmR0AAQCZHUEAmFpCQECYm8AAwkAAQIFAmFpAgpCeXRlVmVjdG9yBAJicwUCYWkFAmJzAwkAAQIFAmFpAgRVbml0CAUCZHMPc2VuZGVyUHVibGljS2V5CQACAQILTWF0Y2ggZXJyb3IJAPQDAwgFAmRzCWJvZHlCeXRlcwkAkQMCCAUCZHMGcHJvb2ZzAAAFAmR1qE0mxg==", "height": 3069306, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: BL3oJzDQxq8t8jLPudSUKH8mn4h5SHVfixt7y6njYRmi Next: 5Lrz9ARrmWLs4a4SSf12xH6ApDgh6XHk2Mm5bsL1RaAo Diff:
Old | New | Differences | |
---|---|---|---|
15 | 15 | ||
16 | 16 | let g = "WAVES" | |
17 | 17 | ||
18 | - | let h = | |
18 | + | let h = 1 | |
19 | 19 | ||
20 | - | let i = | |
20 | + | let i = 2 | |
21 | 21 | ||
22 | - | func j (k) = makeString(["%s%d", "epochLength", toString(k)], a) | |
22 | + | let j = 3 | |
23 | + | ||
24 | + | let k = 4 | |
25 | + | ||
26 | + | let l = makeString(["%s", "epochLength"], a) | |
27 | + | ||
28 | + | let m = makeString(["%s%s", "epochLength__new"], a) | |
29 | + | ||
30 | + | func n (o) = makeString(["%s%d", "epochLength", toString(o)], a) | |
23 | 31 | ||
24 | 32 | ||
25 | - | let | |
33 | + | let p = makeString(["%s", "currentEpoch"], a) | |
26 | 34 | ||
27 | - | let | |
35 | + | let q = makeString(["%s", "maxDepth"], a) | |
28 | 36 | ||
29 | - | let | |
37 | + | let r = makeString(["%s", "resumptionFee"], a) | |
30 | 38 | ||
31 | - | let | |
39 | + | let s = makeString(["%s", "votingEmissionCandidateContract"], a) | |
32 | 40 | ||
33 | - | let | |
41 | + | let t = makeString(["%s", "votingEmissionRateContract"], a) | |
34 | 42 | ||
35 | - | let | |
43 | + | let u = makeString(["%s", "factoryContract"], a) | |
36 | 44 | ||
37 | - | let | |
45 | + | let v = makeString(["%s", "boostingContract"], a) | |
38 | 46 | ||
39 | - | let | |
47 | + | let w = makeString(["%s", "stakingContract"], a) | |
40 | 48 | ||
41 | - | let | |
49 | + | let x = makeString(["%s", "assetsStoreContract"], a) | |
42 | 50 | ||
43 | - | let | |
51 | + | let y = makeString(["%s", "finalizationStage"], a) | |
44 | 52 | ||
45 | - | let | |
53 | + | let z = makeString(["%s", "nextPool"], a) | |
46 | 54 | ||
47 | - | let | |
55 | + | let A = makeString(["%s", "nextUser"], a) | |
48 | 56 | ||
49 | - | let | |
57 | + | let B = makeString(["%s", "startHeight"], a) | |
50 | 58 | ||
51 | - | let | |
59 | + | let C = makeString(["%s", "currentEpochUi"], a) | |
52 | 60 | ||
53 | - | let | |
61 | + | let D = makeString(["%s", "startHeightUi"], a) | |
54 | 62 | ||
55 | - | let | |
63 | + | let E = makeString(["%s", "force"], a) | |
56 | 64 | ||
57 | - | func | |
65 | + | func F () = "%s__allowedLpScriptHash" | |
58 | 66 | ||
59 | 67 | ||
60 | - | func | |
68 | + | func G () = "%s__allowedLpStableScriptHash" | |
61 | 69 | ||
62 | 70 | ||
63 | - | func | |
71 | + | func H (o) = makeString(["%s%d", "startHeight", toString(o)], a) | |
64 | 72 | ||
65 | 73 | ||
66 | - | func | |
74 | + | func I (o) = makeString(["%s%d", "finalized", toString(o)], a) | |
67 | 75 | ||
68 | 76 | ||
69 | - | func | |
70 | - | let | |
71 | - | let | |
72 | - | let | |
73 | - | makeString(["%s%s%s", "inList", | |
77 | + | func J (K) = { | |
78 | + | let L = K | |
79 | + | let M = L._1 | |
80 | + | let N = L._2 | |
81 | + | makeString(["%s%s%s", "inList", M, N], a) | |
74 | 82 | } | |
75 | 83 | ||
76 | 84 | ||
77 | - | func K (G,k) = { | |
78 | - | let L = G | |
79 | - | let I = L._1 | |
80 | - | let J = L._2 | |
81 | - | makeString(["%s%s%s%d", "insufficientBalances", I, J, toString(k)], a) | |
85 | + | func O (P,o) = makeString(["%s%s%d", "used", toString(P), toString(o)], a) | |
86 | + | ||
87 | + | ||
88 | + | func Q (K,P,o) = { | |
89 | + | let R = K | |
90 | + | let M = R._1 | |
91 | + | let N = R._2 | |
92 | + | makeString(["%s%s%s%s%d", "vote", M, N, toString(P), toString(o)], a) | |
82 | 93 | } | |
83 | 94 | ||
84 | 95 | ||
85 | - | func M (N,k) = makeString(["%s%s%d", "used", toString(N), toString(k)], a) | |
86 | - | ||
87 | - | ||
88 | - | func O (G,N,k) = { | |
89 | - | let P = G | |
90 | - | let I = P._1 | |
91 | - | let J = P._2 | |
92 | - | makeString(["%s%s%s%s%d", "vote", I, J, toString(N), toString(k)], a) | |
96 | + | func S (K,o) = { | |
97 | + | let T = K | |
98 | + | let M = T._1 | |
99 | + | let N = T._2 | |
100 | + | makeString(["%s%s%s%d", "votingResult", M, N, toString(o)], a) | |
93 | 101 | } | |
94 | 102 | ||
95 | 103 | ||
96 | - | func Q (G,k) = { | |
97 | - | let R = G | |
98 | - | let I = R._1 | |
99 | - | let J = R._2 | |
100 | - | makeString(["%s%s%s%d", "votingResult", I, J, toString(k)], a) | |
104 | + | func U (V,o) = makeString(["%s%s%d", "votingResultStaked", V, toString(o)], a) | |
105 | + | ||
106 | + | ||
107 | + | func W (K,o) = { | |
108 | + | let X = K | |
109 | + | let M = X._1 | |
110 | + | let N = X._2 | |
111 | + | makeString(["%s%s%s%d", "poolShare", M, N, toString(o)], a) | |
101 | 112 | } | |
102 | 113 | ||
103 | 114 | ||
104 | - | func | |
115 | + | func Y (o) = makeString(["%s%d", "totalVotes", toString(o)], a) | |
105 | 116 | ||
106 | 117 | ||
107 | - | func U (G,k) = { | |
108 | - | let V = G | |
109 | - | let I = V._1 | |
110 | - | let J = V._2 | |
111 | - | makeString(["%s%s%s%d", "poolShare", I, J, toString(k)], a) | |
118 | + | func Z (V,aa) = makeString(["%s%s%s", "staked", aa, V], a) | |
119 | + | ||
120 | + | ||
121 | + | func ab (ac) = makeString(["voting_emission.ride:", ac], " ") | |
122 | + | ||
123 | + | ||
124 | + | func ad (ac) = throw(ab(ac)) | |
125 | + | ||
126 | + | ||
127 | + | func ae (P,af,ag) = { | |
128 | + | let ah = ab(makeString(["mandatory ", toString(P), ".", af, " is not defined"], "")) | |
129 | + | valueOrErrorMessage({ | |
130 | + | let ai = ag | |
131 | + | if ($isInstanceOf(ai, "String")) | |
132 | + | then { | |
133 | + | let aj = ai | |
134 | + | getString(P, af) | |
135 | + | } | |
136 | + | else if ($isInstanceOf(ai, "Int")) | |
137 | + | then { | |
138 | + | let ak = ai | |
139 | + | getInteger(P, af) | |
140 | + | } | |
141 | + | else ad("invalid entry type") | |
142 | + | }, ah) | |
112 | 143 | } | |
113 | 144 | ||
114 | 145 | ||
115 | - | func W (k) = makeString(["%s%d", "totalVotes", toString(k)], a) | |
116 | - | ||
117 | - | ||
118 | - | func X (T,Y) = makeString(["%s%s%s", "staked", Y, T], a) | |
119 | - | ||
120 | - | ||
121 | - | func Z (aa) = makeString(["voting_emission.ride:", aa], " ") | |
122 | - | ||
123 | - | ||
124 | - | func ab (aa) = throw(Z(aa)) | |
125 | - | ||
126 | - | ||
127 | - | func ac (N,ad,ae) = { | |
128 | - | let af = Z(makeString(["mandatory ", toString(N), ".", ad, " is not defined"], "")) | |
129 | - | valueOrErrorMessage({ | |
130 | - | let ag = ae | |
131 | - | if ($isInstanceOf(ag, "String")) | |
132 | - | then { | |
133 | - | let ah = ag | |
134 | - | getString(N, ad) | |
135 | - | } | |
136 | - | else if ($isInstanceOf(ag, "Int")) | |
137 | - | then { | |
138 | - | let ai = ag | |
139 | - | getInteger(N, ad) | |
140 | - | } | |
141 | - | else ab("invalid entry type") | |
142 | - | }, af) | |
146 | + | func al (P,af) = { | |
147 | + | let am = ae(P, af, "") | |
148 | + | if ($isInstanceOf(am, "String")) | |
149 | + | then am | |
150 | + | else throw(($getType(am) + " couldn't be cast to String")) | |
143 | 151 | } | |
144 | 152 | ||
145 | 153 | ||
146 | - | func | |
147 | - | let | |
148 | - | if ($isInstanceOf( | |
149 | - | then | |
150 | - | else throw(($getType( | |
154 | + | func an (P,af) = { | |
155 | + | let am = ae(P, af, 0) | |
156 | + | if ($isInstanceOf(am, "Int")) | |
157 | + | then am | |
158 | + | else throw(($getType(am) + " couldn't be cast to Int")) | |
151 | 159 | } | |
152 | 160 | ||
153 | 161 | ||
154 | - | func al (N,ad) = { | |
155 | - | let ak = ac(N, ad, 0) | |
156 | - | if ($isInstanceOf(ak, "Int")) | |
157 | - | then ak | |
158 | - | else throw(($getType(ak) + " couldn't be cast to Int")) | |
162 | + | func ao (K) = ((K._1 + a) + K._2) | |
163 | + | ||
164 | + | ||
165 | + | func ap (aj) = { | |
166 | + | let aq = split(aj, a) | |
167 | + | if ((size(aq) == 2)) | |
168 | + | then $Tuple2(aq[0], aq[1]) | |
169 | + | else ad("invalid pool string") | |
159 | 170 | } | |
160 | 171 | ||
161 | 172 | ||
162 | - | func am (G) = ((G._1 + a) + G._2) | |
173 | + | let ar = addressFromStringValue(al(this, u)) | |
174 | + | ||
175 | + | let as = 10 | |
176 | + | ||
177 | + | func at () = "%s__factoryConfig" | |
163 | 178 | ||
164 | 179 | ||
165 | - | func an (ah) = { | |
166 | - | let ao = split(ah, a) | |
167 | - | if ((size(ao) == 2)) | |
168 | - | then $Tuple2(ao[0], ao[1]) | |
169 | - | else ab("invalid pool string") | |
180 | + | func au (av) = split(al(av, at()), a) | |
181 | + | ||
182 | + | ||
183 | + | func aw (ax) = addressFromStringValue(ax[as]) | |
184 | + | ||
185 | + | ||
186 | + | func ay (az) = if ((az == g)) | |
187 | + | then unit | |
188 | + | else fromBase58String(az) | |
189 | + | ||
190 | + | ||
191 | + | func aA (az) = if ((az == unit)) | |
192 | + | then g | |
193 | + | else toBase58String(value(az)) | |
194 | + | ||
195 | + | ||
196 | + | func aB (M,N) = { | |
197 | + | let aC = { | |
198 | + | let am = invoke(ar, "poolInfoREADONLY", [M, N], nil) | |
199 | + | if ($isInstanceOf(am, "(Address, ByteVector)")) | |
200 | + | then am | |
201 | + | else unit | |
202 | + | } | |
203 | + | aC | |
170 | 204 | } | |
171 | 205 | ||
172 | 206 | ||
173 | - | let ap = addressFromStringValue(aj(this, q)) | |
207 | + | func aD (M,N) = { | |
208 | + | func aE (aF) = ("%s%s%s__mappings__baseAsset2internalId__" + aF) | |
174 | 209 | ||
175 | - | ||
210 | + | func aG (aH,aI) = (((("%d%d%s%s__" + toString(aH)) + "__") + toString(aI)) + "__mappings__poolAssets2PoolContract") | |
176 | 211 | ||
177 | - | func | |
212 | + | func aJ (aK) = (("%s%s%s__" + aK) + "__mappings__poolContract2LpAsset") | |
178 | 213 | ||
179 | - | ||
180 | - | func as (at) = split(aj(at, ar()), a) | |
181 | - | ||
182 | - | ||
183 | - | func au (av) = addressFromStringValue(av[aq]) | |
184 | - | ||
185 | - | ||
186 | - | func aw (ax) = if ((ax == g)) | |
187 | - | then unit | |
188 | - | else fromBase58String(ax) | |
189 | - | ||
190 | - | ||
191 | - | func ay (ax) = if ((ax == unit)) | |
192 | - | then g | |
193 | - | else toBase58String(value(ax)) | |
194 | - | ||
195 | - | ||
196 | - | func az (I,J) = { | |
197 | - | let aA = { | |
198 | - | let ak = invoke(ap, "poolInfoREADONLY", [I, J], nil) | |
199 | - | if ($isInstanceOf(ak, "(Address, ByteVector)")) | |
200 | - | then ak | |
201 | - | else unit | |
202 | - | } | |
203 | - | aA | |
214 | + | let aL = an(ar, aE(M)) | |
215 | + | let aM = an(ar, aE(N)) | |
216 | + | let aK = al(ar, aG(aL, aM)) | |
217 | + | let aN = al(ar, aJ(aK)) | |
218 | + | aN | |
204 | 219 | } | |
205 | 220 | ||
206 | 221 | ||
207 | - | func aB (I,J) = { | |
208 | - | func aC (aD) = ("%s%s%s__mappings__baseAsset2internalId__" + aD) | |
209 | - | ||
210 | - | func aE (aF,aG) = (((("%d%d%s%s__" + toString(aF)) + "__") + toString(aG)) + "__mappings__poolAssets2PoolContract") | |
211 | - | ||
212 | - | func aH (aI) = (("%s%s%s__" + aI) + "__mappings__poolContract2LpAsset") | |
213 | - | ||
214 | - | let aJ = al(ap, aC(I)) | |
215 | - | let aK = al(ap, aC(J)) | |
216 | - | let aI = aj(ap, aE(aJ, aK)) | |
217 | - | let aL = aj(ap, aH(aI)) | |
218 | - | aL | |
222 | + | func aO (K) = { | |
223 | + | let aP = K | |
224 | + | let M = aP._1 | |
225 | + | let N = aP._2 | |
226 | + | let am = invoke(ar, "checkWxEmissionPoolLabel", [M, N], nil) | |
227 | + | if ($isInstanceOf(am, "Boolean")) | |
228 | + | then am | |
229 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
219 | 230 | } | |
220 | 231 | ||
221 | 232 | ||
222 | - | func aM (G) = { | |
223 | - | let aN = G | |
224 | - | let I = aN._1 | |
225 | - | let J = aN._2 | |
226 | - | let ak = invoke(ap, "checkWxEmissionPoolLabel", [I, J], nil) | |
227 | - | if ($isInstanceOf(ak, "Boolean")) | |
228 | - | then ak | |
229 | - | else throw(($getType(ak) + " couldn't be cast to Boolean")) | |
233 | + | func aQ () = { | |
234 | + | let ax = au(ar) | |
235 | + | let aR = aw(ax) | |
236 | + | invoke(aR, "deposit", nil, nil) | |
230 | 237 | } | |
231 | 238 | ||
232 | 239 | ||
233 | - | func aO () = { | |
234 | - | let av = as(ap) | |
235 | - | let aP = au(av) | |
236 | - | invoke(aP, "deposit", nil, nil) | |
240 | + | let aS = "pools" | |
241 | + | ||
242 | + | func aT (K) = { | |
243 | + | let aU = K | |
244 | + | let M = aU._1 | |
245 | + | let N = aU._2 | |
246 | + | makeString(["votes", M, N], a) | |
237 | 247 | } | |
238 | 248 | ||
239 | 249 | ||
240 | - | let aQ = "pools" | |
241 | - | ||
242 | - | func aR (G) = { | |
243 | - | let aS = G | |
244 | - | let I = aS._1 | |
245 | - | let J = aS._2 | |
246 | - | makeString(["votes", I, J], a) | |
250 | + | func aV (aW) = { | |
251 | + | let aX = if ((aW == aS)) | |
252 | + | then "%s%s" | |
253 | + | else "%s%s%s%s" | |
254 | + | makeString([aX, aW, "head"], a) | |
247 | 255 | } | |
248 | 256 | ||
249 | 257 | ||
250 | - | func | |
251 | - | let | |
258 | + | func aY (aW) = { | |
259 | + | let aX = if ((aW == aS)) | |
252 | 260 | then "%s%s" | |
253 | 261 | else "%s%s%s%s" | |
254 | - | makeString([ | |
262 | + | makeString([aX, aW, "size"], a) | |
255 | 263 | } | |
256 | 264 | ||
257 | 265 | ||
258 | - | func | |
259 | - | let | |
260 | - | then "%s%s" | |
261 | - | else "%s%s%s%s" | |
262 | - | makeString([ | |
266 | + | func aZ (aW,ba) = { | |
267 | + | let aX = if ((aW == aS)) | |
268 | + | then "%s%s%s%s" | |
269 | + | else "%s%s%s%s%s" | |
270 | + | makeString([aX, aW, ba, "prev"], a) | |
263 | 271 | } | |
264 | 272 | ||
265 | 273 | ||
266 | - | func | |
267 | - | let | |
274 | + | func bb (aW,ba) = { | |
275 | + | let aX = if ((aW == aS)) | |
268 | 276 | then "%s%s%s%s" | |
269 | 277 | else "%s%s%s%s%s" | |
270 | - | makeString([ | |
278 | + | makeString([aX, aW, ba, "next"], a) | |
271 | 279 | } | |
272 | 280 | ||
273 | 281 | ||
274 | - | func aZ (aU,aY) = { | |
275 | - | let aV = if ((aU == aQ)) | |
276 | - | then "%s%s%s%s" | |
277 | - | else "%s%s%s%s%s" | |
278 | - | makeString([aV, aU, aY, "next"], a) | |
282 | + | func bc (aW,ba) = { | |
283 | + | let bd = getString(this, aV(aW)) | |
284 | + | let be = getString(this, aZ(aW, ba)) | |
285 | + | let bf = getString(this, bb(aW, ba)) | |
286 | + | if (if ((ba == valueOrElse(bd, ""))) | |
287 | + | then true | |
288 | + | else (be != unit)) | |
289 | + | then true | |
290 | + | else (bf != unit) | |
279 | 291 | } | |
280 | 292 | ||
281 | 293 | ||
282 | - | func ba (aU,aY) = { | |
283 | - | let bb = getString(this, aT(aU)) | |
284 | - | let bc = getString(this, aX(aU, aY)) | |
285 | - | let bd = getString(this, aZ(aU, aY)) | |
286 | - | if (if ((aY == valueOrElse(bb, ""))) | |
294 | + | func bg (aW,ba) = { | |
295 | + | let bd = getString(this, aV(aW)) | |
296 | + | let bh = valueOrElse(getInteger(this, aY(aW)), 0) | |
297 | + | let bi = if (!(bc(aW, ba))) | |
287 | 298 | then true | |
288 | - | else (bc != unit)) | |
289 | - | then true | |
290 | - | else (bd != unit) | |
291 | - | } | |
292 | - | ||
293 | - | ||
294 | - | func be (aU,aY) = { | |
295 | - | let bb = getString(this, aT(aU)) | |
296 | - | let bf = valueOrElse(getInteger(this, aW(aU)), 0) | |
297 | - | let bg = if (!(ba(aU, aY))) | |
298 | - | then true | |
299 | - | else ab("Node exists") | |
300 | - | if ((bg == bg)) | |
301 | - | then (([IntegerEntry(aW(aU), (bf + 1))] ++ (if ((bb != unit)) | |
302 | - | then [StringEntry(aZ(aU, aY), value(bb)), StringEntry(aX(aU, value(bb)), aY)] | |
303 | - | else nil)) ++ [StringEntry(aT(aU), aY)]) | |
299 | + | else ad("Node exists") | |
300 | + | if ((bi == bi)) | |
301 | + | then (([IntegerEntry(aY(aW), (bh + 1))] ++ (if ((bd != unit)) | |
302 | + | then [StringEntry(bb(aW, ba), value(bd)), StringEntry(aZ(aW, value(bd)), ba)] | |
303 | + | else nil)) ++ [StringEntry(aV(aW), ba)]) | |
304 | 304 | else throw("Strict value is not equal to itself.") | |
305 | 305 | } | |
306 | 306 | ||
307 | 307 | ||
308 | - | func | |
309 | - | let | |
310 | - | let | |
311 | - | let | |
312 | - | let | |
313 | - | ([IntegerEntry(aW | |
314 | - | then ( | |
308 | + | func bj (aW,ba) = { | |
309 | + | let bd = getString(this, aV(aW)) | |
310 | + | let bh = valueOrElse(getInteger(this, aY(aW)), 0) | |
311 | + | let be = getString(this, aZ(aW, ba)) | |
312 | + | let bf = getString(this, bb(aW, ba)) | |
313 | + | ([IntegerEntry(aY(aW), (bh - 1))] ++ (if (if ((be != unit)) | |
314 | + | then (bf != unit) | |
315 | 315 | else false) | |
316 | - | then [StringEntry( | |
317 | - | else if (( | |
318 | - | then [StringEntry( | |
319 | - | else if (( | |
320 | - | then [DeleteEntry( | |
321 | - | else if (( | |
322 | - | then [DeleteEntry( | |
323 | - | else | |
316 | + | then [StringEntry(bb(aW, value(be)), value(bf)), StringEntry(aZ(aW, value(bf)), value(be)), DeleteEntry(aZ(aW, ba)), DeleteEntry(bb(aW, ba))] | |
317 | + | else if ((bf != unit)) | |
318 | + | then [StringEntry(aV(aW), value(bf)), DeleteEntry(bb(aW, ba)), DeleteEntry(aZ(aW, value(bf)))] | |
319 | + | else if ((be != unit)) | |
320 | + | then [DeleteEntry(aZ(aW, ba)), DeleteEntry(bb(aW, value(be)))] | |
321 | + | else if ((ba == valueOrElse(bd, ""))) | |
322 | + | then [DeleteEntry(aV(aW))] | |
323 | + | else ad(((("invalid node: " + aW) + ".") + ba)))) | |
324 | 324 | } | |
325 | 325 | ||
326 | 326 | ||
327 | - | func | |
327 | + | func bk () = "%s__managerVaultAddress" | |
328 | 328 | ||
329 | 329 | ||
330 | - | func | |
330 | + | func bl () = "%s__managerPublicKey" | |
331 | 331 | ||
332 | 332 | ||
333 | - | func | |
334 | - | let | |
335 | - | if ($isInstanceOf( | |
333 | + | func bm () = { | |
334 | + | let ai = getString(bk()) | |
335 | + | if ($isInstanceOf(ai, "String")) | |
336 | 336 | then { | |
337 | - | let | |
338 | - | addressFromStringValue( | |
337 | + | let bn = ai | |
338 | + | addressFromStringValue(bn) | |
339 | 339 | } | |
340 | 340 | else this | |
341 | 341 | } | |
342 | 342 | ||
343 | 343 | ||
344 | - | func | |
345 | - | let | |
346 | - | let | |
347 | - | if ($isInstanceOf( | |
344 | + | func bo () = { | |
345 | + | let bp = bm() | |
346 | + | let ai = getString(bp, bl()) | |
347 | + | if ($isInstanceOf(ai, "String")) | |
348 | 348 | then { | |
349 | - | let | |
350 | - | fromBase58String( | |
349 | + | let bn = ai | |
350 | + | fromBase58String(bn) | |
351 | 351 | } | |
352 | - | else if ($isInstanceOf( | |
352 | + | else if ($isInstanceOf(ai, "Unit")) | |
353 | 353 | then unit | |
354 | 354 | else throw("Match error") | |
355 | 355 | } | |
356 | 356 | ||
357 | 357 | ||
358 | - | func | |
359 | - | let | |
360 | - | if ($isInstanceOf( | |
358 | + | func bq (br) = { | |
359 | + | let ai = bo() | |
360 | + | if ($isInstanceOf(ai, "ByteVector")) | |
361 | 361 | then { | |
362 | - | let | |
363 | - | ( | |
362 | + | let bs = ai | |
363 | + | (br.callerPublicKey == bs) | |
364 | 364 | } | |
365 | - | else if ($isInstanceOf( | |
366 | - | then ( | |
365 | + | else if ($isInstanceOf(ai, "Unit")) | |
366 | + | then (br.caller == this) | |
367 | 367 | else throw("Match error") | |
368 | 368 | } | |
369 | 369 | ||
370 | 370 | ||
371 | - | func | |
371 | + | func bt (br) = if (bq(br)) | |
372 | 372 | then true | |
373 | 373 | else throw("permission denied") | |
374 | 374 | ||
375 | 375 | ||
376 | - | func | |
376 | + | func bu (br) = if ((br.caller == this)) | |
377 | 377 | then true | |
378 | 378 | else throw("permission denied") | |
379 | 379 | ||
380 | 380 | ||
381 | - | @Callable( | |
382 | - | func getUserGwxAmountAtHeight ( | |
383 | - | let | |
381 | + | @Callable(br) | |
382 | + | func getUserGwxAmountAtHeight (bv,bw) = { | |
383 | + | let bx = valueOrErrorMessage(addressFromString(al(this, v)), ab("invalid boosting contract address")) | |
384 | 384 | $Tuple2(nil, { | |
385 | - | let | |
386 | - | if ($isInstanceOf( | |
387 | - | then | |
388 | - | else throw(($getType( | |
385 | + | let am = invoke(bx, "getUserGwxAmountAtHeightREADONLY", [bv, bw], nil) | |
386 | + | if ($isInstanceOf(am, "Int")) | |
387 | + | then am | |
388 | + | else throw(($getType(am) + " couldn't be cast to Int")) | |
389 | 389 | }) | |
390 | 390 | } | |
391 | 391 | ||
392 | 392 | ||
393 | 393 | ||
394 | - | @Callable( | |
395 | - | func constructor ( | |
396 | - | let | |
394 | + | @Callable(br) | |
395 | + | func constructor (ar,by,bz,bA,bB) = { | |
396 | + | let bC = [bt(br), if ((addressFromString(ar) != unit)) | |
397 | 397 | then true | |
398 | - | else "invalid factory contract address", if ((addressFromString( | |
398 | + | else "invalid factory contract address", if ((addressFromString(by) != unit)) | |
399 | 399 | then true | |
400 | - | else "invalid voting emission candidate contract address", if ((addressFromString( | |
400 | + | else "invalid voting emission candidate contract address", if ((addressFromString(bz) != unit)) | |
401 | 401 | then true | |
402 | - | else "invalid boosting contract address", if ((addressFromString( | |
402 | + | else "invalid boosting contract address", if ((addressFromString(bA) != unit)) | |
403 | 403 | then true | |
404 | - | else "invalid staking contract address", if (( | |
404 | + | else "invalid staking contract address", if ((bB > 0)) | |
405 | 405 | then true | |
406 | - | else | |
407 | - | if (( | |
408 | - | then $Tuple2([StringEntry( | |
406 | + | else ad("invalid epoch length")] | |
407 | + | if ((bC == bC)) | |
408 | + | then $Tuple2([StringEntry(u, ar), StringEntry(s, by), StringEntry(v, bz), StringEntry(w, bA), IntegerEntry(l, bB)], unit) | |
409 | 409 | else throw("Strict value is not equal to itself.") | |
410 | 410 | } | |
411 | 411 | ||
412 | 412 | ||
413 | 413 | ||
414 | - | @Callable( | |
415 | - | func create ( | |
416 | - | let | |
414 | + | @Callable(br) | |
415 | + | func create (M,N) = { | |
416 | + | let bC = [if ((toBase58String(br.caller.bytes) == valueOrElse(getString(this, s), ""))) | |
417 | 417 | then true | |
418 | - | else br | |
419 | - | if (( | |
418 | + | else bt(br)] | |
419 | + | if ((bC == bC)) | |
420 | 420 | then { | |
421 | - | let | |
422 | - | let | |
423 | - | let | |
424 | - | let | |
421 | + | let K = $Tuple2(M, N) | |
422 | + | let bD = ([BooleanEntry(J(K), true)] ++ bg(aS, ao(K))) | |
423 | + | let bE = (getInteger(this, p) == unit) | |
424 | + | let bF = if (bE) | |
425 | 425 | then { | |
426 | - | let | |
427 | - | [IntegerEntry( | |
426 | + | let o = 0 | |
427 | + | [IntegerEntry(p, o), IntegerEntry(H(o), height), IntegerEntry(B, height), IntegerEntry(C, o), IntegerEntry(D, height)] | |
428 | 428 | } | |
429 | 429 | else nil | |
430 | - | $Tuple2(( | |
430 | + | $Tuple2((bD ++ bF), unit) | |
431 | 431 | } | |
432 | 432 | else throw("Strict value is not equal to itself.") | |
433 | 433 | } | |
434 | 434 | ||
435 | 435 | ||
436 | 436 | ||
437 | - | @Callable( | |
438 | - | func vote ( | |
439 | - | let | |
440 | - | let | |
441 | - | let | |
442 | - | let | |
443 | - | let | |
444 | - | let | |
445 | - | let | |
446 | - | let | |
447 | - | let | |
448 | - | let | |
449 | - | let | |
450 | - | let | |
451 | - | if ($isInstanceOf( | |
452 | - | then | |
453 | - | else throw(($getType( | |
437 | + | @Callable(br) | |
438 | + | func vote (M,N,bG) = { | |
439 | + | let K = $Tuple2(M, N) | |
440 | + | let o = valueOrElse(getInteger(this, p), 0) | |
441 | + | let bH = an(this, H(o)) | |
442 | + | let bB = an(this, l) | |
443 | + | let bI = (bH + bB) | |
444 | + | let bJ = getInteger(this, y) | |
445 | + | let bK = valueOrElse(getInteger(this, O(br.caller, o)), 0) | |
446 | + | let bL = valueOrElse(getInteger(this, Q(K, br.caller, o)), 0) | |
447 | + | let bM = valueOrElse(getInteger(this, S(K, o)), 0) | |
448 | + | let bN = valueOrElse(getInteger(this, Y(o)), 0) | |
449 | + | let bO = { | |
450 | + | let am = invoke(this, "getUserGwxAmountAtHeight", [toBase58String(br.caller.bytes), bI], nil) | |
451 | + | if ($isInstanceOf(am, "Int")) | |
452 | + | then am | |
453 | + | else throw(($getType(am) + " couldn't be cast to Int")) | |
454 | 454 | } | |
455 | - | let | |
456 | - | let | |
457 | - | let | |
458 | - | let | |
455 | + | let bP = (bO - bK) | |
456 | + | let bQ = (bL + bG) | |
457 | + | let bR = aO(K) | |
458 | + | let bC = [if ((getBoolean(J(K)) != unit)) | |
459 | 459 | then true | |
460 | - | else | |
460 | + | else ad("invalid assets"), if ((bI > height)) | |
461 | 461 | then true | |
462 | - | else | |
462 | + | else ad("invalid height"), if ((bJ == unit)) | |
463 | 463 | then true | |
464 | - | else | |
464 | + | else ad("finalization in progress"), if ((bO > 0)) | |
465 | 465 | then true | |
466 | - | else | |
467 | - | then ( | |
466 | + | else ad("you do not have gWX"), if (if ((bG > 0)) | |
467 | + | then (bP >= bG) | |
468 | 468 | else false) | |
469 | 469 | then true | |
470 | - | else | |
470 | + | else ad("invalid amount"), if (bR) | |
471 | 471 | then true | |
472 | - | else | |
473 | - | if (( | |
472 | + | else ad("pool hasn't WX_EMISSION label")] | |
473 | + | if ((bC == bC)) | |
474 | 474 | then { | |
475 | - | let | |
476 | - | let | |
477 | - | let | |
475 | + | let bS = aT(K) | |
476 | + | let aa = toString(br.caller) | |
477 | + | let bT = if (bc(bS, aa)) | |
478 | 478 | then nil | |
479 | - | else | |
480 | - | $Tuple2(([IntegerEntry( | |
479 | + | else bg(bS, aa) | |
480 | + | $Tuple2(([IntegerEntry(O(br.caller, o), (bK + bG)), IntegerEntry(Q(K, br.caller, o), bQ), IntegerEntry(S(K, o), (bM + bG)), IntegerEntry(Y(o), (bN + bG))] ++ bT), unit) | |
481 | 481 | } | |
482 | 482 | else throw("Strict value is not equal to itself.") | |
483 | 483 | } | |
484 | 484 | ||
485 | 485 | ||
486 | 486 | ||
487 | - | @Callable( | |
488 | - | func cancelVote ( | |
489 | - | let | |
490 | - | let | |
491 | - | let | |
492 | - | let | |
493 | - | let | |
494 | - | let | |
495 | - | let | |
496 | - | let | |
497 | - | let | |
498 | - | let | |
499 | - | let | |
487 | + | @Callable(br) | |
488 | + | func cancelVote (M,N) = { | |
489 | + | let K = $Tuple2(M, N) | |
490 | + | let o = valueOrElse(getInteger(this, p), 0) | |
491 | + | let bH = an(this, H(o)) | |
492 | + | let bB = an(this, l) | |
493 | + | let bI = (bH + bB) | |
494 | + | let bJ = getInteger(this, y) | |
495 | + | let bK = valueOrElse(getInteger(this, O(br.caller, o)), 0) | |
496 | + | let bL = valueOrElse(getInteger(this, Q(K, br.caller, o)), 0) | |
497 | + | let bM = valueOrElse(getInteger(this, S(K, o)), 0) | |
498 | + | let bN = valueOrElse(getInteger(this, Y(o)), 0) | |
499 | + | let bC = [if ((getBoolean(J(K)) != unit)) | |
500 | 500 | then true | |
501 | - | else | |
501 | + | else ad("invalid assets"), if ((bI > height)) | |
502 | 502 | then true | |
503 | - | else | |
503 | + | else ad("invalid height"), if ((bJ == unit)) | |
504 | 504 | then true | |
505 | - | else | |
505 | + | else ad("finalization in progress"), if ((bL > 0)) | |
506 | 506 | then true | |
507 | - | else | |
508 | - | if (( | |
507 | + | else ad("no vote")] | |
508 | + | if ((bC == bC)) | |
509 | 509 | then { | |
510 | - | let | |
511 | - | let | |
512 | - | $Tuple2(([IntegerEntry( | |
510 | + | let bS = aT(K) | |
511 | + | let aa = toString(br.caller) | |
512 | + | $Tuple2(([IntegerEntry(O(br.caller, o), max([(bK - bL), 0])), DeleteEntry(Q(K, br.caller, o)), IntegerEntry(S(K, o), (bM - bL)), IntegerEntry(Y(o), (bN - bL))] ++ bj(bS, aa)), unit) | |
513 | 513 | } | |
514 | 514 | else throw("Strict value is not equal to itself.") | |
515 | 515 | } | |
516 | 516 | ||
517 | 517 | ||
518 | 518 | ||
519 | - | @Callable( | |
520 | - | func setEpochLength ( | |
521 | - | let | |
519 | + | @Callable(br) | |
520 | + | func setEpochLength (bU) = { | |
521 | + | let bC = [bt(br), if ((bU > 0)) | |
522 | 522 | then true | |
523 | - | else | |
524 | - | if (( | |
525 | - | then $Tuple2([IntegerEntry( | |
523 | + | else ad("invalid epoch length")] | |
524 | + | if ((bC == bC)) | |
525 | + | then $Tuple2([IntegerEntry(m, bU)], unit) | |
526 | 526 | else throw("Strict value is not equal to itself.") | |
527 | 527 | } | |
528 | 528 | ||
529 | 529 | ||
530 | 530 | ||
531 | - | @Callable( | |
532 | - | func setMaxDepth ( | |
533 | - | let | |
531 | + | @Callable(br) | |
532 | + | func setMaxDepth (bV) = { | |
533 | + | let bC = [bt(br), if ((bV > 0)) | |
534 | 534 | then true | |
535 | - | else | |
536 | - | if (( | |
537 | - | then $Tuple2([IntegerEntry( | |
535 | + | else ad("invalid max depth")] | |
536 | + | if ((bC == bC)) | |
537 | + | then $Tuple2([IntegerEntry(q, bV)], unit) | |
538 | 538 | else throw("Strict value is not equal to itself.") | |
539 | 539 | } | |
540 | 540 | ||
541 | 541 | ||
542 | 542 | ||
543 | - | @Callable( | |
544 | - | func processPoolBalanceINTERNAL ( | |
545 | - | let | |
546 | - | if (( | |
543 | + | @Callable(br) | |
544 | + | func processPoolBalanceINTERNAL (bW) = { | |
545 | + | let bX = bu(br) | |
546 | + | if ((bX == bX)) | |
547 | 547 | then { | |
548 | - | let | |
549 | - | let | |
550 | - | let | |
551 | - | let | |
552 | - | let | |
553 | - | let | |
554 | - | let | |
555 | - | let | |
556 | - | let | |
557 | - | if ($isInstanceOf( | |
558 | - | then | |
559 | - | else throw(($getType( | |
548 | + | let o = an(this, p) | |
549 | + | let bY = (o - 1) | |
550 | + | let K = ap(bW) | |
551 | + | let bZ = K | |
552 | + | let M = bZ._1 | |
553 | + | let N = bZ._2 | |
554 | + | let aN = aD(M, N) | |
555 | + | let ca = { | |
556 | + | let am = invoke(ar, "checkBalance", [aN], nil) | |
557 | + | if ($isInstanceOf(am, "Boolean")) | |
558 | + | then am | |
559 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
560 | 560 | } | |
561 | - | let bZ = !(valueOrElse(getBoolean(this, K(G, (bW - 1))), false)) | |
562 | - | let ca = if (!(bY)) | |
563 | - | then if (!(bZ)) | |
564 | - | then { | |
565 | - | let cb = invoke(ap, "deleteWxEmissionPoolLabel", [I, J], nil) | |
566 | - | if ((cb == cb)) | |
567 | - | then { | |
568 | - | let cc = invoke(ap, "modifyWeight", [aL, 0], nil) | |
569 | - | if ((cc == cc)) | |
570 | - | then { | |
571 | - | let cd = valueOrErrorMessage(az(I, J), Z("invalid assets"))._1 | |
572 | - | let ce = 3 | |
573 | - | let cf = invoke(ap, "managePool", [toString(cd), ce], nil) | |
574 | - | if ((cf == cf)) | |
575 | - | then { | |
576 | - | let cg = ([DeleteEntry(F(G))] ++ bh(aQ, am(G))) | |
577 | - | ([IntegerEntry(U(G, bW), 0)] ++ cg) | |
578 | - | } | |
579 | - | else throw("Strict value is not equal to itself.") | |
580 | - | } | |
581 | - | else throw("Strict value is not equal to itself.") | |
582 | - | } | |
583 | - | else throw("Strict value is not equal to itself.") | |
584 | - | } | |
585 | - | else [BooleanEntry(K(G, bW), true)] | |
561 | + | let cb = if (!(ca)) | |
562 | + | then { | |
563 | + | let cc = invoke(ar, "deleteWxEmissionPoolLabel", [M, N], nil) | |
564 | + | if ((cc == cc)) | |
565 | + | then { | |
566 | + | let cd = invoke(ar, "modifyWeight", [aN, 0], nil) | |
567 | + | if ((cd == cd)) | |
568 | + | then { | |
569 | + | let ce = valueOrErrorMessage(aB(M, N), ab("invalid assets"))._1 | |
570 | + | let cf = invoke(ar, "managePool", [toString(ce), j], nil) | |
571 | + | if ((cf == cf)) | |
572 | + | then { | |
573 | + | let cg = ([DeleteEntry(J(K))] ++ bj(aS, ao(K))) | |
574 | + | ([IntegerEntry(W(K, bY), 0)] ++ cg) | |
575 | + | } | |
576 | + | else throw("Strict value is not equal to itself.") | |
577 | + | } | |
578 | + | else throw("Strict value is not equal to itself.") | |
579 | + | } | |
580 | + | else throw("Strict value is not equal to itself.") | |
581 | + | } | |
586 | 582 | else nil | |
587 | - | $Tuple2( | |
583 | + | $Tuple2(cb, unit) | |
588 | 584 | } | |
589 | 585 | else throw("Strict value is not equal to itself.") | |
590 | 586 | } | |
591 | 587 | ||
592 | 588 | ||
593 | 589 | ||
594 | - | @Callable( | |
595 | - | func processVoteINTERNAL ( | |
596 | - | let | |
597 | - | if (( | |
590 | + | @Callable(br) | |
591 | + | func processVoteINTERNAL (bW,aa) = { | |
592 | + | let bX = bu(br) | |
593 | + | if ((bX == bX)) | |
598 | 594 | then { | |
599 | - | let | |
600 | - | let | |
601 | - | let | |
602 | - | let | |
603 | - | let | |
604 | - | let | |
605 | - | let ch = | |
606 | - | let ci = | |
595 | + | let bv = valueOrErrorMessage(addressFromString(aa), ab(("processVoteINTERNAL: invalid user address " + aa))) | |
596 | + | let o = an(this, p) | |
597 | + | let bY = (o - 1) | |
598 | + | let bB = an(this, l) | |
599 | + | let bH = an(this, H(o)) | |
600 | + | let bI = (bH + bB) | |
601 | + | let ch = an(this, H(bY)) | |
602 | + | let ci = an(this, n(bY)) | |
607 | 603 | let cj = (ch + ci) | |
608 | - | let ck = if (( | |
604 | + | let ck = if ((bY >= 0)) | |
609 | 605 | then true | |
610 | - | else | |
606 | + | else ad("processVoteINTERNAL: invalid previous epoch") | |
611 | 607 | if ((ck == ck)) | |
612 | 608 | then { | |
613 | - | let | |
614 | - | let cl = | |
615 | - | let | |
616 | - | let | |
617 | - | let | |
618 | - | let | |
619 | - | if ($isInstanceOf( | |
620 | - | then | |
621 | - | else throw(($getType( | |
609 | + | let K = ap(bW) | |
610 | + | let cl = K | |
611 | + | let M = cl._1 | |
612 | + | let N = cl._2 | |
613 | + | let bO = { | |
614 | + | let am = invoke(this, "getUserGwxAmountAtHeight", [aa, bI], nil) | |
615 | + | if ($isInstanceOf(am, "Int")) | |
616 | + | then am | |
617 | + | else throw(($getType(am) + " couldn't be cast to Int")) | |
622 | 618 | } | |
623 | 619 | let cm = { | |
624 | - | let | |
625 | - | if ($isInstanceOf( | |
626 | - | then | |
627 | - | else throw(($getType( | |
620 | + | let am = invoke(this, "getUserGwxAmountAtHeight", [aa, cj], nil) | |
621 | + | if ($isInstanceOf(am, "Int")) | |
622 | + | then am | |
623 | + | else throw(($getType(am) + " couldn't be cast to Int")) | |
628 | 624 | } | |
629 | - | let | |
630 | - | let cn = valueOrElse(getInteger( | |
631 | - | let co = getInteger( | |
632 | - | let cp = valueOrErrorMessage(co, | |
633 | - | let | |
634 | - | let | |
635 | - | let cq = valueOrElse(getInteger( | |
636 | - | let | |
637 | - | let cr = valueOrElse(getInteger( | |
625 | + | let bN = valueOrElse(getInteger(Y(o)), 0) | |
626 | + | let cn = valueOrElse(getInteger(S(K, o)), 0) | |
627 | + | let co = getInteger(Q(K, bv, bY)) | |
628 | + | let cp = valueOrErrorMessage(co, ab((((("processVoteINTERNAL " + bW) + " ") + aa) + ": no previous vote"))) | |
629 | + | let bK = valueOrElse(getInteger(this, O(bv, o)), 0) | |
630 | + | let V = aD(M, N) | |
631 | + | let cq = valueOrElse(getInteger(U(V, bY)), 0) | |
632 | + | let bA = addressFromStringValue(al(this, w)) | |
633 | + | let cr = valueOrElse(getInteger(bA, Z(V, aa)), 0) | |
638 | 634 | let cs = if (if ((cr == 0)) | |
639 | 635 | then true | |
640 | 636 | else (co == unit)) | |
641 | 637 | then nil | |
642 | - | else [IntegerEntry( | |
643 | - | let | |
644 | - | let | |
645 | - | then fraction(cp, | |
638 | + | else [IntegerEntry(U(V, bY), (cq + cp))] | |
639 | + | let aN = aD(M, N) | |
640 | + | let bQ = if ((cm > 0)) | |
641 | + | then fraction(cp, bO, cm) | |
646 | 642 | else 0 | |
647 | - | let | |
643 | + | let cb = if (if ((co == unit)) | |
648 | 644 | then true | |
649 | - | else (0 >= | |
650 | - | then | |
651 | - | else [IntegerEntry( | |
652 | - | $Tuple2(( | |
645 | + | else (0 >= bQ)) | |
646 | + | then bj(aT(K), aa) | |
647 | + | else [IntegerEntry(Q(K, bv, o), bQ), IntegerEntry(Y(o), (bN + bQ)), IntegerEntry(S(K, o), (cn + bQ)), IntegerEntry(O(bv, o), (bK + bQ))] | |
648 | + | $Tuple2((cb ++ cs), unit) | |
653 | 649 | } | |
654 | 650 | else throw("Strict value is not equal to itself.") | |
655 | 651 | } | |
658 | 654 | ||
659 | 655 | ||
660 | 656 | ||
661 | - | @Callable( | |
662 | - | func processPoolINTERNAL ( | |
663 | - | let | |
664 | - | if (( | |
657 | + | @Callable(br) | |
658 | + | func processPoolINTERNAL (bW,ct) = { | |
659 | + | let bX = bu(br) | |
660 | + | if ((bX == bX)) | |
665 | 661 | then { | |
666 | 662 | let cu = { | |
667 | - | let cv = | |
663 | + | let cv = an(this, p) | |
668 | 664 | if (ct) | |
669 | 665 | then cv | |
670 | 666 | else (cv - 1) | |
671 | 667 | } | |
672 | 668 | let ck = if ((cu >= 0)) | |
673 | 669 | then true | |
674 | - | else | |
670 | + | else ad("processPoolINTERNAL: invalid target epoch") | |
675 | 671 | if ((ck == ck)) | |
676 | 672 | then { | |
677 | - | let | |
678 | - | let cw = | |
679 | - | let | |
680 | - | let | |
681 | - | let | |
682 | - | let | |
673 | + | let K = ap(bW) | |
674 | + | let cw = K | |
675 | + | let M = cw._1 | |
676 | + | let N = cw._2 | |
677 | + | let bA = addressFromStringValue(al(this, w)) | |
678 | + | let aN = aD(M, N) | |
683 | 679 | let cx = { | |
684 | - | let | |
685 | - | if ($isInstanceOf( | |
686 | - | then | |
687 | - | else throw(($getType( | |
680 | + | let am = invoke(bA, "usersListTraversal", [aN], nil) | |
681 | + | if ($isInstanceOf(am, "Boolean")) | |
682 | + | then am | |
683 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
688 | 684 | } | |
689 | 685 | if ((cx == cx)) | |
690 | 686 | then if (cx) | |
691 | 687 | then $Tuple2(nil, true) | |
692 | 688 | else { | |
693 | - | let cy = addressFromStringValue(valueOrErrorMessage(getString( | |
694 | - | let | |
695 | - | let cn = valueOrElse(getInteger(this, | |
696 | - | let cz = if (( | |
689 | + | let cy = addressFromStringValue(valueOrErrorMessage(getString(ar, x), "invalid assets store contract")) | |
690 | + | let bN = valueOrElse(getInteger(this, Y(cu)), 0) | |
691 | + | let cn = valueOrElse(getInteger(this, S(K, cu)), 0) | |
692 | + | let cz = if ((bN == 0)) | |
697 | 693 | then 0 | |
698 | - | else fraction(cn, b, | |
699 | - | let | |
700 | - | if (( | |
701 | - | then $Tuple2([IntegerEntry( | |
694 | + | else fraction(cn, b, bN) | |
695 | + | let cd = invoke(ar, "modifyWeight", [aN, cz], nil) | |
696 | + | if ((cd == cd)) | |
697 | + | then $Tuple2([IntegerEntry(W(K, cu), cz)], false) | |
702 | 698 | else throw("Strict value is not equal to itself.") | |
703 | 699 | } | |
704 | 700 | else throw("Strict value is not equal to itself.") | |
710 | 706 | ||
711 | 707 | ||
712 | 708 | ||
713 | - | @Callable( | |
709 | + | @Callable(br) | |
714 | 710 | func finalizeHelper () = { | |
715 | - | let ct = valueOrElse(getBoolean( | |
716 | - | let | |
717 | - | let cA = ( | |
718 | - | let | |
719 | - | let | |
720 | - | let | |
721 | - | let | |
722 | - | if (if (if ((height >= | |
723 | - | then ( | |
711 | + | let ct = valueOrElse(getBoolean(E), false) | |
712 | + | let o = valueOrElse(getInteger(this, p), 0) | |
713 | + | let cA = (o - 1) | |
714 | + | let bH = an(this, H(o)) | |
715 | + | let bB = an(this, l) | |
716 | + | let bI = (bH + bB) | |
717 | + | let bJ = getInteger(this, y) | |
718 | + | if (if (if ((height >= bI)) | |
719 | + | then (bJ == unit) | |
724 | 720 | else false) | |
725 | 721 | then !(ct) | |
726 | 722 | else false) | |
727 | 723 | then { | |
728 | - | let cB = ( | |
729 | - | let cC = getInteger(this, | |
724 | + | let cB = (o + 1) | |
725 | + | let cC = getInteger(this, m) | |
730 | 726 | let cD = { | |
731 | - | let | |
732 | - | if ($isInstanceOf( | |
727 | + | let ai = cC | |
728 | + | if ($isInstanceOf(ai, "Int")) | |
733 | 729 | then { | |
734 | - | let | |
735 | - | [IntegerEntry( | |
730 | + | let bU = ai | |
731 | + | [IntegerEntry(l, bU), DeleteEntry(m)] | |
736 | 732 | } | |
737 | - | else if ($isInstanceOf( | |
733 | + | else if ($isInstanceOf(ai, "Unit")) | |
738 | 734 | then nil | |
739 | 735 | else throw("Match error") | |
740 | 736 | } | |
741 | - | $Tuple2(([IntegerEntry( | |
737 | + | $Tuple2(([IntegerEntry(H(cB), height), IntegerEntry(B, height), IntegerEntry(p, cB), IntegerEntry(y, d), IntegerEntry(n(o), bB)] ++ cD), true) | |
742 | 738 | } | |
743 | 739 | else if (if (ct) | |
744 | - | then ( | |
740 | + | then (bJ == unit) | |
745 | 741 | else false) | |
746 | - | then $Tuple2([IntegerEntry( | |
747 | - | else if (( | |
742 | + | then $Tuple2([IntegerEntry(y, f)], true) | |
743 | + | else if ((bJ == unit)) | |
748 | 744 | then $Tuple2(nil, false) | |
749 | - | else if (( | |
745 | + | else if ((bJ == d)) | |
750 | 746 | then { | |
751 | - | let cE = getString( | |
752 | - | let | |
753 | - | if ($isInstanceOf( | |
747 | + | let cE = getString(z) | |
748 | + | let ai = cE | |
749 | + | if ($isInstanceOf(ai, "Unit")) | |
754 | 750 | then { | |
755 | - | let cF = getString( | |
751 | + | let cF = getString(aV(aS)) | |
756 | 752 | if ($isInstanceOf(cF, "Unit")) | |
757 | - | then $Tuple2([IntegerEntry( | |
753 | + | then $Tuple2([IntegerEntry(y, e), DeleteEntry(z)], true) | |
758 | 754 | else if ($isInstanceOf(cF, "String")) | |
759 | 755 | then { | |
760 | 756 | let cG = cF | |
761 | - | $Tuple2([StringEntry( | |
757 | + | $Tuple2([StringEntry(z, cG)], true) | |
762 | 758 | } | |
763 | 759 | else throw("Match error") | |
764 | 760 | } | |
765 | - | else if ($isInstanceOf( | |
761 | + | else if ($isInstanceOf(ai, "String")) | |
766 | 762 | then { | |
767 | - | let | |
768 | - | let cH = getString( | |
763 | + | let bW = ai | |
764 | + | let cH = getString(bb(aS, bW)) | |
769 | 765 | if ((cH == cH)) | |
770 | 766 | then { | |
771 | - | let cx = invoke(this, "processPoolBalanceINTERNAL", [ | |
767 | + | let cx = invoke(this, "processPoolBalanceINTERNAL", [bW], nil) | |
772 | 768 | if ((cx == cx)) | |
773 | 769 | then { | |
774 | 770 | let cF = cH | |
775 | 771 | if ($isInstanceOf(cF, "Unit")) | |
776 | - | then $Tuple2([IntegerEntry( | |
772 | + | then $Tuple2([IntegerEntry(y, e), DeleteEntry(z)], true) | |
777 | 773 | else if ($isInstanceOf(cF, "String")) | |
778 | 774 | then { | |
779 | 775 | let cG = cF | |
780 | - | $Tuple2([StringEntry( | |
776 | + | $Tuple2([StringEntry(z, cG)], true) | |
781 | 777 | } | |
782 | 778 | else throw("Match error") | |
783 | 779 | } | |
787 | 783 | } | |
788 | 784 | else throw("Match error") | |
789 | 785 | } | |
790 | - | else if (( | |
786 | + | else if ((bJ == e)) | |
791 | 787 | then { | |
792 | - | let cE = getString( | |
793 | - | let cI = getString( | |
794 | - | let | |
795 | - | if ($isInstanceOf( | |
788 | + | let cE = getString(z) | |
789 | + | let cI = getString(A) | |
790 | + | let ai = cE | |
791 | + | if ($isInstanceOf(ai, "Unit")) | |
796 | 792 | then { | |
797 | - | let cF = getString( | |
793 | + | let cF = getString(aV(aS)) | |
798 | 794 | if ($isInstanceOf(cF, "Unit")) | |
799 | - | then $Tuple2([IntegerEntry( | |
795 | + | then $Tuple2([IntegerEntry(y, f), DeleteEntry(z), DeleteEntry(A)], true) | |
800 | 796 | else if ($isInstanceOf(cF, "String")) | |
801 | 797 | then { | |
802 | 798 | let cJ = cF | |
803 | - | $Tuple2([StringEntry( | |
799 | + | $Tuple2([StringEntry(z, cJ)], true) | |
804 | 800 | } | |
805 | 801 | else throw("Match error") | |
806 | 802 | } | |
807 | - | else if ($isInstanceOf( | |
803 | + | else if ($isInstanceOf(ai, "String")) | |
808 | 804 | then { | |
809 | - | let | |
810 | - | let | |
805 | + | let bW = ai | |
806 | + | let K = ap(bW) | |
811 | 807 | let cK = { | |
812 | 808 | let cF = cI | |
813 | 809 | if ($isInstanceOf(cF, "Unit")) | |
814 | - | then getString(aT( | |
810 | + | then getString(aV(aT(K))) | |
815 | 811 | else if ($isInstanceOf(cF, "String")) | |
816 | 812 | then { | |
817 | 813 | let cL = cF | |
818 | - | let cM = getString( | |
814 | + | let cM = getString(bb(aT(K), cL)) | |
819 | 815 | if ((cM == cM)) | |
820 | 816 | then { | |
821 | - | let cN = invoke(this, "processVoteINTERNAL", [ | |
817 | + | let cN = invoke(this, "processVoteINTERNAL", [bW, cL], nil) | |
822 | 818 | if ((cN == cN)) | |
823 | 819 | then cM | |
824 | 820 | else throw("Strict value is not equal to itself.") | |
830 | 826 | let cF = cK | |
831 | 827 | if ($isInstanceOf(cF, "Unit")) | |
832 | 828 | then { | |
833 | - | let cH = getString( | |
829 | + | let cH = getString(bb(aS, bW)) | |
834 | 830 | let cO = cH | |
835 | 831 | if ($isInstanceOf(cO, "Unit")) | |
836 | - | then $Tuple2([IntegerEntry( | |
832 | + | then $Tuple2([IntegerEntry(y, f), DeleteEntry(z), DeleteEntry(A)], true) | |
837 | 833 | else if ($isInstanceOf(cO, "String")) | |
838 | 834 | then { | |
839 | - | let | |
840 | - | $Tuple2([StringEntry( | |
835 | + | let bn = cO | |
836 | + | $Tuple2([StringEntry(z, bn), DeleteEntry(A)], true) | |
841 | 837 | } | |
842 | 838 | else throw("Match error") | |
843 | 839 | } | |
844 | 840 | else if ($isInstanceOf(cF, "String")) | |
845 | 841 | then { | |
846 | 842 | let cP = cF | |
847 | - | $Tuple2([StringEntry( | |
843 | + | $Tuple2([StringEntry(A, cP)], true) | |
848 | 844 | } | |
849 | 845 | else throw("Match error") | |
850 | 846 | } | |
851 | 847 | else throw("Match error") | |
852 | 848 | } | |
853 | - | else if (( | |
849 | + | else if ((bJ == f)) | |
854 | 850 | then { | |
855 | - | let cE = getString( | |
856 | - | let | |
857 | - | if ($isInstanceOf( | |
851 | + | let cE = getString(z) | |
852 | + | let ai = cE | |
853 | + | if ($isInstanceOf(ai, "Unit")) | |
858 | 854 | then { | |
859 | - | let cF = getString( | |
855 | + | let cF = getString(aV(aS)) | |
860 | 856 | if ($isInstanceOf(cF, "Unit")) | |
861 | 857 | then { | |
862 | - | let | |
863 | - | then [DeleteEntry( | |
864 | - | else [DeleteEntry( | |
865 | - | let cQ = | |
858 | + | let cb = if (ct) | |
859 | + | then [DeleteEntry(y), DeleteEntry(E)] | |
860 | + | else [DeleteEntry(y), BooleanEntry(I(cA), true), IntegerEntry(C, o), IntegerEntry(D, bH)] | |
861 | + | let cQ = aQ() | |
866 | 862 | if ((cQ == cQ)) | |
867 | - | then $Tuple2( | |
863 | + | then $Tuple2(cb, true) | |
868 | 864 | else throw("Strict value is not equal to itself.") | |
869 | 865 | } | |
870 | 866 | else if ($isInstanceOf(cF, "String")) | |
871 | 867 | then { | |
872 | 868 | let cG = cF | |
873 | - | $Tuple2([StringEntry( | |
869 | + | $Tuple2([StringEntry(z, cG)], true) | |
874 | 870 | } | |
875 | 871 | else throw("Match error") | |
876 | 872 | } | |
877 | - | else if ($isInstanceOf( | |
873 | + | else if ($isInstanceOf(ai, "String")) | |
878 | 874 | then { | |
879 | - | let | |
880 | - | let cH = getString( | |
875 | + | let bW = ai | |
876 | + | let cH = getString(bb(aS, bW)) | |
881 | 877 | if ((cH == cH)) | |
882 | 878 | then { | |
883 | 879 | let cx = { | |
884 | - | let | |
885 | - | if ($isInstanceOf( | |
886 | - | then | |
887 | - | else throw(($getType( | |
880 | + | let am = invoke(this, "processPoolINTERNAL", [bW, ct], nil) | |
881 | + | if ($isInstanceOf(am, "Boolean")) | |
882 | + | then am | |
883 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
888 | 884 | } | |
889 | 885 | if ((cx == cx)) | |
890 | 886 | then if (cx) | |
893 | 889 | let cF = cH | |
894 | 890 | if ($isInstanceOf(cF, "Unit")) | |
895 | 891 | then { | |
896 | - | let | |
897 | - | then [DeleteEntry( | |
898 | - | else [DeleteEntry( | |
899 | - | let cQ = | |
892 | + | let cb = if (ct) | |
893 | + | then [DeleteEntry(y), DeleteEntry(E), DeleteEntry(z)] | |
894 | + | else [DeleteEntry(y), BooleanEntry(I(cA), true), IntegerEntry(C, o), IntegerEntry(D, bH), DeleteEntry(z)] | |
895 | + | let cQ = aQ() | |
900 | 896 | if ((cQ == cQ)) | |
901 | - | then $Tuple2( | |
897 | + | then $Tuple2(cb, true) | |
902 | 898 | else throw("Strict value is not equal to itself.") | |
903 | 899 | } | |
904 | 900 | else if ($isInstanceOf(cF, "String")) | |
905 | 901 | then { | |
906 | 902 | let cG = cF | |
907 | - | $Tuple2([StringEntry( | |
903 | + | $Tuple2([StringEntry(z, cG)], true) | |
908 | 904 | } | |
909 | 905 | else throw("Match error") | |
910 | 906 | } | |
914 | 910 | } | |
915 | 911 | else throw("Match error") | |
916 | 912 | } | |
917 | - | else | |
913 | + | else ad("finalization is broken") | |
918 | 914 | } | |
919 | 915 | ||
920 | 916 | ||
921 | 917 | ||
922 | - | @Callable( | |
918 | + | @Callable(br) | |
923 | 919 | func finalizeWrapper (cR) = { | |
924 | - | let cS = addressFromStringValue(getStringValue(this, | |
920 | + | let cS = addressFromStringValue(getStringValue(this, t)) | |
925 | 921 | let cT = { | |
926 | - | let | |
927 | - | if ($isInstanceOf( | |
928 | - | then | |
929 | - | else throw(($getType( | |
922 | + | let am = invoke(this, "finalizeHelper", nil, nil) | |
923 | + | if ($isInstanceOf(am, "Boolean")) | |
924 | + | then am | |
925 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
930 | 926 | } | |
931 | 927 | if ((cT == cT)) | |
932 | 928 | then if (!(cT)) | |
933 | 929 | then if ((cR == 0)) | |
934 | - | then | |
930 | + | then ad("Current voting is not over yet") | |
935 | 931 | else { | |
936 | 932 | let cU = invoke(cS, "finalize", nil, nil) | |
937 | 933 | if ((cU == cU)) | |
939 | 935 | else throw("Strict value is not equal to itself.") | |
940 | 936 | } | |
941 | 937 | else { | |
942 | - | let cV = valueOrElse(getInteger(this, | |
938 | + | let cV = valueOrElse(getInteger(this, q), c) | |
943 | 939 | if ((cV > cR)) | |
944 | 940 | then { | |
945 | 941 | let cU = invoke(this, "finalizeWrapper", [(cR + 1)], nil) | |
954 | 950 | ||
955 | 951 | ||
956 | 952 | ||
957 | - | @Callable( | |
953 | + | @Callable(br) | |
958 | 954 | func finalize () = { | |
959 | 955 | let cU = invoke(this, "finalizeWrapper", [0], nil) | |
960 | 956 | if ((cU == cU)) | |
964 | 960 | ||
965 | 961 | ||
966 | 962 | ||
967 | - | @Callable( | |
968 | - | func containsNodeREADONLY ( | |
963 | + | @Callable(br) | |
964 | + | func containsNodeREADONLY (aW,ba) = $Tuple2(nil, bc(aW, ba)) | |
969 | 965 | ||
970 | 966 | ||
971 | 967 | ||
972 | - | @Callable( | |
973 | - | func insertNode ( | |
974 | - | let | |
975 | - | if (( | |
976 | - | then $Tuple2( | |
968 | + | @Callable(br) | |
969 | + | func insertNode (aW,ba) = { | |
970 | + | let bX = bt(br) | |
971 | + | if ((bX == bX)) | |
972 | + | then $Tuple2(bg(aW, ba), unit) | |
977 | 973 | else throw("Strict value is not equal to itself.") | |
978 | 974 | } | |
979 | 975 | ||
980 | 976 | ||
981 | 977 | ||
982 | - | @Callable( | |
983 | - | func deleteNode ( | |
984 | - | let | |
985 | - | if (( | |
986 | - | then $Tuple2( | |
978 | + | @Callable(br) | |
979 | + | func deleteNode (aW,ba) = { | |
980 | + | let bX = bt(br) | |
981 | + | if ((bX == bX)) | |
982 | + | then $Tuple2(bj(aW, ba), unit) | |
987 | 983 | else throw("Strict value is not equal to itself.") | |
988 | 984 | } | |
989 | 985 | ||
990 | 986 | ||
991 | 987 | ||
992 | - | @Callable( | |
988 | + | @Callable(br) | |
993 | 989 | func isFinalizationInProgress () = { | |
994 | - | let | |
995 | - | let cW = ( | |
990 | + | let bJ = getInteger(this, y) | |
991 | + | let cW = (bJ != unit) | |
996 | 992 | $Tuple2(nil, cW) | |
997 | 993 | } | |
998 | 994 | ||
999 | 995 | ||
1000 | 996 | ||
1001 | - | @Callable( | |
1002 | - | func deletePool ( | |
1003 | - | let | |
997 | + | @Callable(br) | |
998 | + | func deletePool (M,N) = { | |
999 | + | let bX = if (if ((br.caller == ar)) | |
1004 | 1000 | then true | |
1005 | - | else br | |
1001 | + | else bt(br)) | |
1006 | 1002 | then true | |
1007 | - | else | |
1008 | - | if (( | |
1003 | + | else ad("Permission denied") | |
1004 | + | if ((bX == bX)) | |
1009 | 1005 | then { | |
1010 | - | let | |
1011 | - | let | |
1012 | - | let | |
1013 | - | let | |
1014 | - | then | |
1006 | + | let aW = "pools" | |
1007 | + | let K = $Tuple2(M, N) | |
1008 | + | let ba = makeString([M, N], a) | |
1009 | + | let cb = if (bc(aW, ba)) | |
1010 | + | then bj(aW, ba) | |
1015 | 1011 | else nil | |
1016 | - | ([DeleteEntry( | |
1012 | + | ([DeleteEntry(J(K))] ++ cb) | |
1017 | 1013 | } | |
1018 | 1014 | else throw("Strict value is not equal to itself.") | |
1019 | 1015 | } | |
1020 | 1016 | ||
1021 | 1017 | ||
1022 | 1018 | ||
1023 | - | @Callable( | |
1024 | - | func resume ( | |
1025 | - | let | |
1026 | - | let cY = valueOrErrorMessage( | |
1027 | - | let | |
1028 | - | let | |
1029 | - | let cZ = | |
1030 | - | let cy = addressFromStringValue(getStringValue(this, | |
1019 | + | @Callable(br) | |
1020 | + | func resume (M,N,cX) = { | |
1021 | + | let bJ = getInteger(this, y) | |
1022 | + | let cY = valueOrErrorMessage(aB(M, N), ab("invalid assets")) | |
1023 | + | let ce = cY._1 | |
1024 | + | let aN = cY._2 | |
1025 | + | let cZ = br.payments[0] | |
1026 | + | let cy = addressFromStringValue(getStringValue(this, x)) | |
1031 | 1027 | let da = "%s__config" | |
1032 | 1028 | let db = 1 | |
1033 | - | let | |
1034 | - | let dc = fromBase58String(split(getStringValue( | |
1029 | + | let bz = addressFromStringValue(al(this, v)) | |
1030 | + | let dc = fromBase58String(split(getStringValue(bz, da), a)[db]) | |
1035 | 1031 | let dd = { | |
1036 | - | let | |
1037 | - | if ($isInstanceOf( | |
1038 | - | then | |
1039 | - | else throw(($getType( | |
1032 | + | let am = invoke(cy, "isVerifiedREADONLY", [M], nil) | |
1033 | + | if ($isInstanceOf(am, "Boolean")) | |
1034 | + | then am | |
1035 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
1040 | 1036 | } | |
1041 | 1037 | let de = { | |
1042 | - | let | |
1043 | - | if ($isInstanceOf( | |
1044 | - | then | |
1045 | - | else throw(($getType( | |
1038 | + | let am = invoke(cy, "isVerifiedREADONLY", [N], nil) | |
1039 | + | if ($isInstanceOf(am, "Boolean")) | |
1040 | + | then am | |
1041 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
1046 | 1042 | } | |
1047 | - | let df = valueOrErrorMessage(getInteger(this, | |
1048 | - | let | |
1043 | + | let df = valueOrErrorMessage(getInteger(this, r), "invalid resumption fee") | |
1044 | + | let bC = [if ((bJ == unit)) | |
1049 | 1045 | then true | |
1050 | - | else | |
1046 | + | else ad("finalization is in progress"), if ((cZ.assetId == dc)) | |
1051 | 1047 | then true | |
1052 | - | else | |
1048 | + | else ad("invalid fee payment asset id"), if ((cZ.amount == df)) | |
1053 | 1049 | then true | |
1054 | - | else | |
1050 | + | else ad("invalid fee payment amount"), if (if (dd) | |
1055 | 1051 | then de | |
1056 | 1052 | else false) | |
1057 | 1053 | then true | |
1058 | - | else | |
1059 | - | if (( | |
1054 | + | else ad("both assets should be verified")] | |
1055 | + | if ((bC == bC)) | |
1060 | 1056 | then { | |
1061 | - | let dg = assetBalance(this, | |
1057 | + | let dg = assetBalance(this, aN) | |
1062 | 1058 | if ((dg == dg)) | |
1063 | 1059 | then { | |
1064 | 1060 | let dh = false | |
1065 | - | let di = if ((size( | |
1061 | + | let di = if ((size(br.payments) == 1)) | |
1066 | 1062 | then { | |
1067 | - | let | |
1068 | - | let | |
1069 | - | if ($isInstanceOf( | |
1070 | - | then | |
1071 | - | else throw(($getType( | |
1063 | + | let ca = { | |
1064 | + | let am = invoke(ar, "checkBalance", [aA(aN)], nil) | |
1065 | + | if ($isInstanceOf(am, "Boolean")) | |
1066 | + | then am | |
1067 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
1072 | 1068 | } | |
1073 | - | if ( | |
1069 | + | if (ca) | |
1074 | 1070 | then true | |
1075 | - | else | |
1071 | + | else ad("assets should be attached") | |
1076 | 1072 | } | |
1077 | - | else if ((size( | |
1073 | + | else if ((size(br.payments) == 2)) | |
1078 | 1074 | then { | |
1079 | - | let | |
1080 | - | let | |
1081 | - | let | |
1082 | - | let | |
1075 | + | let dj = valueOrErrorMessage(scriptHash(ce), ab("pool address is not scripted")) | |
1076 | + | let dk = fromBase64String(valueOrErrorMessage(getString(ar, G()), ab("allowed lp stable script hash is not set"))) | |
1077 | + | let dl = (dj == dk) | |
1078 | + | let dm = if (dl) | |
1083 | 1079 | then "putOneTknV2" | |
1084 | 1080 | else "putOneTkn" | |
1085 | - | invoke( | |
1081 | + | invoke(ce, dm, [cX, dh], [br.payments[1]]) | |
1086 | 1082 | } | |
1087 | - | else if ((size( | |
1088 | - | then invoke( | |
1089 | - | else | |
1083 | + | else if ((size(br.payments) == 3)) | |
1084 | + | then invoke(ce, "put", [cX, dh], [br.payments[1], br.payments[2]]) | |
1085 | + | else ad("invalid payments size") | |
1090 | 1086 | if ((di == di)) | |
1091 | 1087 | then { | |
1092 | - | let | |
1093 | - | if (( | |
1088 | + | let dn = assetBalance(this, aN) | |
1089 | + | if ((dn == dn)) | |
1094 | 1090 | then { | |
1095 | - | let | |
1096 | - | let | |
1097 | - | then [ScriptTransfer( | |
1091 | + | let do = (dn - dg) | |
1092 | + | let dp = if ((do > 0)) | |
1093 | + | then [ScriptTransfer(br.caller, do, aN)] | |
1098 | 1094 | else nil | |
1099 | - | let | |
1100 | - | if (( | |
1095 | + | let dq = invoke(ar, "setWxEmissionPoolLabel", [M, N], nil) | |
1096 | + | if ((dq == dq)) | |
1101 | 1097 | then { | |
1102 | - | let G = $Tuple2(I, J) | |
1103 | - | let bB = ([BooleanEntry(F(G), true)] ++ be(aQ, am(G))) | |
1104 | - | $Tuple2((bB ++ dq), unit) | |
1098 | + | let dr = { | |
1099 | + | let am = invoke(ar, "getPoolStatusREADONLY", [toString(ce)], nil) | |
1100 | + | if ($isInstanceOf(am, "Int")) | |
1101 | + | then am | |
1102 | + | else throw(($getType(am) + " couldn't be cast to Int")) | |
1103 | + | } | |
1104 | + | let cf = if ((dr == j)) | |
1105 | + | then invoke(ar, "managePool", [toString(ce), h], nil) | |
1106 | + | else unit | |
1107 | + | if ((cf == cf)) | |
1108 | + | then { | |
1109 | + | let K = $Tuple2(M, N) | |
1110 | + | let bD = ([BooleanEntry(J(K), true)] ++ bg(aS, ao(K))) | |
1111 | + | $Tuple2((bD ++ dp), unit) | |
1112 | + | } | |
1113 | + | else throw("Strict value is not equal to itself.") | |
1105 | 1114 | } | |
1106 | 1115 | else throw("Strict value is not equal to itself.") | |
1107 | 1116 | } | |
1118 | 1127 | @Verifier(ds) | |
1119 | 1128 | func dt () = { | |
1120 | 1129 | let du = { | |
1121 | - | let | |
1122 | - | if ($isInstanceOf( | |
1130 | + | let ai = bo() | |
1131 | + | if ($isInstanceOf(ai, "ByteVector")) | |
1123 | 1132 | then { | |
1124 | - | let | |
1125 | - | | |
1133 | + | let bs = ai | |
1134 | + | bs | |
1126 | 1135 | } | |
1127 | - | else if ($isInstanceOf( | |
1136 | + | else if ($isInstanceOf(ai, "Unit")) | |
1128 | 1137 | then ds.senderPublicKey | |
1129 | 1138 | else throw("Match error") | |
1130 | 1139 | } |
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 = 2 | |
15 | 15 | ||
16 | 16 | let g = "WAVES" | |
17 | 17 | ||
18 | - | let h = | |
18 | + | let h = 1 | |
19 | 19 | ||
20 | - | let i = | |
20 | + | let i = 2 | |
21 | 21 | ||
22 | - | func j (k) = makeString(["%s%d", "epochLength", toString(k)], a) | |
22 | + | let j = 3 | |
23 | + | ||
24 | + | let k = 4 | |
25 | + | ||
26 | + | let l = makeString(["%s", "epochLength"], a) | |
27 | + | ||
28 | + | let m = makeString(["%s%s", "epochLength__new"], a) | |
29 | + | ||
30 | + | func n (o) = makeString(["%s%d", "epochLength", toString(o)], a) | |
23 | 31 | ||
24 | 32 | ||
25 | - | let | |
33 | + | let p = makeString(["%s", "currentEpoch"], a) | |
26 | 34 | ||
27 | - | let | |
35 | + | let q = makeString(["%s", "maxDepth"], a) | |
28 | 36 | ||
29 | - | let | |
37 | + | let r = makeString(["%s", "resumptionFee"], a) | |
30 | 38 | ||
31 | - | let | |
39 | + | let s = makeString(["%s", "votingEmissionCandidateContract"], a) | |
32 | 40 | ||
33 | - | let | |
41 | + | let t = makeString(["%s", "votingEmissionRateContract"], a) | |
34 | 42 | ||
35 | - | let | |
43 | + | let u = makeString(["%s", "factoryContract"], a) | |
36 | 44 | ||
37 | - | let | |
45 | + | let v = makeString(["%s", "boostingContract"], a) | |
38 | 46 | ||
39 | - | let | |
47 | + | let w = makeString(["%s", "stakingContract"], a) | |
40 | 48 | ||
41 | - | let | |
49 | + | let x = makeString(["%s", "assetsStoreContract"], a) | |
42 | 50 | ||
43 | - | let | |
51 | + | let y = makeString(["%s", "finalizationStage"], a) | |
44 | 52 | ||
45 | - | let | |
53 | + | let z = makeString(["%s", "nextPool"], a) | |
46 | 54 | ||
47 | - | let | |
55 | + | let A = makeString(["%s", "nextUser"], a) | |
48 | 56 | ||
49 | - | let | |
57 | + | let B = makeString(["%s", "startHeight"], a) | |
50 | 58 | ||
51 | - | let | |
59 | + | let C = makeString(["%s", "currentEpochUi"], a) | |
52 | 60 | ||
53 | - | let | |
61 | + | let D = makeString(["%s", "startHeightUi"], a) | |
54 | 62 | ||
55 | - | let | |
63 | + | let E = makeString(["%s", "force"], a) | |
56 | 64 | ||
57 | - | func | |
65 | + | func F () = "%s__allowedLpScriptHash" | |
58 | 66 | ||
59 | 67 | ||
60 | - | func | |
68 | + | func G () = "%s__allowedLpStableScriptHash" | |
61 | 69 | ||
62 | 70 | ||
63 | - | func | |
71 | + | func H (o) = makeString(["%s%d", "startHeight", toString(o)], a) | |
64 | 72 | ||
65 | 73 | ||
66 | - | func | |
74 | + | func I (o) = makeString(["%s%d", "finalized", toString(o)], a) | |
67 | 75 | ||
68 | 76 | ||
69 | - | func | |
70 | - | let | |
71 | - | let | |
72 | - | let | |
73 | - | makeString(["%s%s%s", "inList", | |
77 | + | func J (K) = { | |
78 | + | let L = K | |
79 | + | let M = L._1 | |
80 | + | let N = L._2 | |
81 | + | makeString(["%s%s%s", "inList", M, N], a) | |
74 | 82 | } | |
75 | 83 | ||
76 | 84 | ||
77 | - | func K (G,k) = { | |
78 | - | let L = G | |
79 | - | let I = L._1 | |
80 | - | let J = L._2 | |
81 | - | makeString(["%s%s%s%d", "insufficientBalances", I, J, toString(k)], a) | |
85 | + | func O (P,o) = makeString(["%s%s%d", "used", toString(P), toString(o)], a) | |
86 | + | ||
87 | + | ||
88 | + | func Q (K,P,o) = { | |
89 | + | let R = K | |
90 | + | let M = R._1 | |
91 | + | let N = R._2 | |
92 | + | makeString(["%s%s%s%s%d", "vote", M, N, toString(P), toString(o)], a) | |
82 | 93 | } | |
83 | 94 | ||
84 | 95 | ||
85 | - | func M (N,k) = makeString(["%s%s%d", "used", toString(N), toString(k)], a) | |
86 | - | ||
87 | - | ||
88 | - | func O (G,N,k) = { | |
89 | - | let P = G | |
90 | - | let I = P._1 | |
91 | - | let J = P._2 | |
92 | - | makeString(["%s%s%s%s%d", "vote", I, J, toString(N), toString(k)], a) | |
96 | + | func S (K,o) = { | |
97 | + | let T = K | |
98 | + | let M = T._1 | |
99 | + | let N = T._2 | |
100 | + | makeString(["%s%s%s%d", "votingResult", M, N, toString(o)], a) | |
93 | 101 | } | |
94 | 102 | ||
95 | 103 | ||
96 | - | func Q (G,k) = { | |
97 | - | let R = G | |
98 | - | let I = R._1 | |
99 | - | let J = R._2 | |
100 | - | makeString(["%s%s%s%d", "votingResult", I, J, toString(k)], a) | |
104 | + | func U (V,o) = makeString(["%s%s%d", "votingResultStaked", V, toString(o)], a) | |
105 | + | ||
106 | + | ||
107 | + | func W (K,o) = { | |
108 | + | let X = K | |
109 | + | let M = X._1 | |
110 | + | let N = X._2 | |
111 | + | makeString(["%s%s%s%d", "poolShare", M, N, toString(o)], a) | |
101 | 112 | } | |
102 | 113 | ||
103 | 114 | ||
104 | - | func | |
115 | + | func Y (o) = makeString(["%s%d", "totalVotes", toString(o)], a) | |
105 | 116 | ||
106 | 117 | ||
107 | - | func U (G,k) = { | |
108 | - | let V = G | |
109 | - | let I = V._1 | |
110 | - | let J = V._2 | |
111 | - | makeString(["%s%s%s%d", "poolShare", I, J, toString(k)], a) | |
118 | + | func Z (V,aa) = makeString(["%s%s%s", "staked", aa, V], a) | |
119 | + | ||
120 | + | ||
121 | + | func ab (ac) = makeString(["voting_emission.ride:", ac], " ") | |
122 | + | ||
123 | + | ||
124 | + | func ad (ac) = throw(ab(ac)) | |
125 | + | ||
126 | + | ||
127 | + | func ae (P,af,ag) = { | |
128 | + | let ah = ab(makeString(["mandatory ", toString(P), ".", af, " is not defined"], "")) | |
129 | + | valueOrErrorMessage({ | |
130 | + | let ai = ag | |
131 | + | if ($isInstanceOf(ai, "String")) | |
132 | + | then { | |
133 | + | let aj = ai | |
134 | + | getString(P, af) | |
135 | + | } | |
136 | + | else if ($isInstanceOf(ai, "Int")) | |
137 | + | then { | |
138 | + | let ak = ai | |
139 | + | getInteger(P, af) | |
140 | + | } | |
141 | + | else ad("invalid entry type") | |
142 | + | }, ah) | |
112 | 143 | } | |
113 | 144 | ||
114 | 145 | ||
115 | - | func W (k) = makeString(["%s%d", "totalVotes", toString(k)], a) | |
116 | - | ||
117 | - | ||
118 | - | func X (T,Y) = makeString(["%s%s%s", "staked", Y, T], a) | |
119 | - | ||
120 | - | ||
121 | - | func Z (aa) = makeString(["voting_emission.ride:", aa], " ") | |
122 | - | ||
123 | - | ||
124 | - | func ab (aa) = throw(Z(aa)) | |
125 | - | ||
126 | - | ||
127 | - | func ac (N,ad,ae) = { | |
128 | - | let af = Z(makeString(["mandatory ", toString(N), ".", ad, " is not defined"], "")) | |
129 | - | valueOrErrorMessage({ | |
130 | - | let ag = ae | |
131 | - | if ($isInstanceOf(ag, "String")) | |
132 | - | then { | |
133 | - | let ah = ag | |
134 | - | getString(N, ad) | |
135 | - | } | |
136 | - | else if ($isInstanceOf(ag, "Int")) | |
137 | - | then { | |
138 | - | let ai = ag | |
139 | - | getInteger(N, ad) | |
140 | - | } | |
141 | - | else ab("invalid entry type") | |
142 | - | }, af) | |
146 | + | func al (P,af) = { | |
147 | + | let am = ae(P, af, "") | |
148 | + | if ($isInstanceOf(am, "String")) | |
149 | + | then am | |
150 | + | else throw(($getType(am) + " couldn't be cast to String")) | |
143 | 151 | } | |
144 | 152 | ||
145 | 153 | ||
146 | - | func | |
147 | - | let | |
148 | - | if ($isInstanceOf( | |
149 | - | then | |
150 | - | else throw(($getType( | |
154 | + | func an (P,af) = { | |
155 | + | let am = ae(P, af, 0) | |
156 | + | if ($isInstanceOf(am, "Int")) | |
157 | + | then am | |
158 | + | else throw(($getType(am) + " couldn't be cast to Int")) | |
151 | 159 | } | |
152 | 160 | ||
153 | 161 | ||
154 | - | func al (N,ad) = { | |
155 | - | let ak = ac(N, ad, 0) | |
156 | - | if ($isInstanceOf(ak, "Int")) | |
157 | - | then ak | |
158 | - | else throw(($getType(ak) + " couldn't be cast to Int")) | |
162 | + | func ao (K) = ((K._1 + a) + K._2) | |
163 | + | ||
164 | + | ||
165 | + | func ap (aj) = { | |
166 | + | let aq = split(aj, a) | |
167 | + | if ((size(aq) == 2)) | |
168 | + | then $Tuple2(aq[0], aq[1]) | |
169 | + | else ad("invalid pool string") | |
159 | 170 | } | |
160 | 171 | ||
161 | 172 | ||
162 | - | func am (G) = ((G._1 + a) + G._2) | |
173 | + | let ar = addressFromStringValue(al(this, u)) | |
174 | + | ||
175 | + | let as = 10 | |
176 | + | ||
177 | + | func at () = "%s__factoryConfig" | |
163 | 178 | ||
164 | 179 | ||
165 | - | func an (ah) = { | |
166 | - | let ao = split(ah, a) | |
167 | - | if ((size(ao) == 2)) | |
168 | - | then $Tuple2(ao[0], ao[1]) | |
169 | - | else ab("invalid pool string") | |
180 | + | func au (av) = split(al(av, at()), a) | |
181 | + | ||
182 | + | ||
183 | + | func aw (ax) = addressFromStringValue(ax[as]) | |
184 | + | ||
185 | + | ||
186 | + | func ay (az) = if ((az == g)) | |
187 | + | then unit | |
188 | + | else fromBase58String(az) | |
189 | + | ||
190 | + | ||
191 | + | func aA (az) = if ((az == unit)) | |
192 | + | then g | |
193 | + | else toBase58String(value(az)) | |
194 | + | ||
195 | + | ||
196 | + | func aB (M,N) = { | |
197 | + | let aC = { | |
198 | + | let am = invoke(ar, "poolInfoREADONLY", [M, N], nil) | |
199 | + | if ($isInstanceOf(am, "(Address, ByteVector)")) | |
200 | + | then am | |
201 | + | else unit | |
202 | + | } | |
203 | + | aC | |
170 | 204 | } | |
171 | 205 | ||
172 | 206 | ||
173 | - | let ap = addressFromStringValue(aj(this, q)) | |
207 | + | func aD (M,N) = { | |
208 | + | func aE (aF) = ("%s%s%s__mappings__baseAsset2internalId__" + aF) | |
174 | 209 | ||
175 | - | ||
210 | + | func aG (aH,aI) = (((("%d%d%s%s__" + toString(aH)) + "__") + toString(aI)) + "__mappings__poolAssets2PoolContract") | |
176 | 211 | ||
177 | - | func | |
212 | + | func aJ (aK) = (("%s%s%s__" + aK) + "__mappings__poolContract2LpAsset") | |
178 | 213 | ||
179 | - | ||
180 | - | func as (at) = split(aj(at, ar()), a) | |
181 | - | ||
182 | - | ||
183 | - | func au (av) = addressFromStringValue(av[aq]) | |
184 | - | ||
185 | - | ||
186 | - | func aw (ax) = if ((ax == g)) | |
187 | - | then unit | |
188 | - | else fromBase58String(ax) | |
189 | - | ||
190 | - | ||
191 | - | func ay (ax) = if ((ax == unit)) | |
192 | - | then g | |
193 | - | else toBase58String(value(ax)) | |
194 | - | ||
195 | - | ||
196 | - | func az (I,J) = { | |
197 | - | let aA = { | |
198 | - | let ak = invoke(ap, "poolInfoREADONLY", [I, J], nil) | |
199 | - | if ($isInstanceOf(ak, "(Address, ByteVector)")) | |
200 | - | then ak | |
201 | - | else unit | |
202 | - | } | |
203 | - | aA | |
214 | + | let aL = an(ar, aE(M)) | |
215 | + | let aM = an(ar, aE(N)) | |
216 | + | let aK = al(ar, aG(aL, aM)) | |
217 | + | let aN = al(ar, aJ(aK)) | |
218 | + | aN | |
204 | 219 | } | |
205 | 220 | ||
206 | 221 | ||
207 | - | func aB (I,J) = { | |
208 | - | func aC (aD) = ("%s%s%s__mappings__baseAsset2internalId__" + aD) | |
209 | - | ||
210 | - | func aE (aF,aG) = (((("%d%d%s%s__" + toString(aF)) + "__") + toString(aG)) + "__mappings__poolAssets2PoolContract") | |
211 | - | ||
212 | - | func aH (aI) = (("%s%s%s__" + aI) + "__mappings__poolContract2LpAsset") | |
213 | - | ||
214 | - | let aJ = al(ap, aC(I)) | |
215 | - | let aK = al(ap, aC(J)) | |
216 | - | let aI = aj(ap, aE(aJ, aK)) | |
217 | - | let aL = aj(ap, aH(aI)) | |
218 | - | aL | |
222 | + | func aO (K) = { | |
223 | + | let aP = K | |
224 | + | let M = aP._1 | |
225 | + | let N = aP._2 | |
226 | + | let am = invoke(ar, "checkWxEmissionPoolLabel", [M, N], nil) | |
227 | + | if ($isInstanceOf(am, "Boolean")) | |
228 | + | then am | |
229 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
219 | 230 | } | |
220 | 231 | ||
221 | 232 | ||
222 | - | func aM (G) = { | |
223 | - | let aN = G | |
224 | - | let I = aN._1 | |
225 | - | let J = aN._2 | |
226 | - | let ak = invoke(ap, "checkWxEmissionPoolLabel", [I, J], nil) | |
227 | - | if ($isInstanceOf(ak, "Boolean")) | |
228 | - | then ak | |
229 | - | else throw(($getType(ak) + " couldn't be cast to Boolean")) | |
233 | + | func aQ () = { | |
234 | + | let ax = au(ar) | |
235 | + | let aR = aw(ax) | |
236 | + | invoke(aR, "deposit", nil, nil) | |
230 | 237 | } | |
231 | 238 | ||
232 | 239 | ||
233 | - | func aO () = { | |
234 | - | let av = as(ap) | |
235 | - | let aP = au(av) | |
236 | - | invoke(aP, "deposit", nil, nil) | |
240 | + | let aS = "pools" | |
241 | + | ||
242 | + | func aT (K) = { | |
243 | + | let aU = K | |
244 | + | let M = aU._1 | |
245 | + | let N = aU._2 | |
246 | + | makeString(["votes", M, N], a) | |
237 | 247 | } | |
238 | 248 | ||
239 | 249 | ||
240 | - | let aQ = "pools" | |
241 | - | ||
242 | - | func aR (G) = { | |
243 | - | let aS = G | |
244 | - | let I = aS._1 | |
245 | - | let J = aS._2 | |
246 | - | makeString(["votes", I, J], a) | |
250 | + | func aV (aW) = { | |
251 | + | let aX = if ((aW == aS)) | |
252 | + | then "%s%s" | |
253 | + | else "%s%s%s%s" | |
254 | + | makeString([aX, aW, "head"], a) | |
247 | 255 | } | |
248 | 256 | ||
249 | 257 | ||
250 | - | func | |
251 | - | let | |
258 | + | func aY (aW) = { | |
259 | + | let aX = if ((aW == aS)) | |
252 | 260 | then "%s%s" | |
253 | 261 | else "%s%s%s%s" | |
254 | - | makeString([ | |
262 | + | makeString([aX, aW, "size"], a) | |
255 | 263 | } | |
256 | 264 | ||
257 | 265 | ||
258 | - | func | |
259 | - | let | |
260 | - | then "%s%s" | |
261 | - | else "%s%s%s%s" | |
262 | - | makeString([ | |
266 | + | func aZ (aW,ba) = { | |
267 | + | let aX = if ((aW == aS)) | |
268 | + | then "%s%s%s%s" | |
269 | + | else "%s%s%s%s%s" | |
270 | + | makeString([aX, aW, ba, "prev"], a) | |
263 | 271 | } | |
264 | 272 | ||
265 | 273 | ||
266 | - | func | |
267 | - | let | |
274 | + | func bb (aW,ba) = { | |
275 | + | let aX = if ((aW == aS)) | |
268 | 276 | then "%s%s%s%s" | |
269 | 277 | else "%s%s%s%s%s" | |
270 | - | makeString([ | |
278 | + | makeString([aX, aW, ba, "next"], a) | |
271 | 279 | } | |
272 | 280 | ||
273 | 281 | ||
274 | - | func aZ (aU,aY) = { | |
275 | - | let aV = if ((aU == aQ)) | |
276 | - | then "%s%s%s%s" | |
277 | - | else "%s%s%s%s%s" | |
278 | - | makeString([aV, aU, aY, "next"], a) | |
282 | + | func bc (aW,ba) = { | |
283 | + | let bd = getString(this, aV(aW)) | |
284 | + | let be = getString(this, aZ(aW, ba)) | |
285 | + | let bf = getString(this, bb(aW, ba)) | |
286 | + | if (if ((ba == valueOrElse(bd, ""))) | |
287 | + | then true | |
288 | + | else (be != unit)) | |
289 | + | then true | |
290 | + | else (bf != unit) | |
279 | 291 | } | |
280 | 292 | ||
281 | 293 | ||
282 | - | func ba (aU,aY) = { | |
283 | - | let bb = getString(this, aT(aU)) | |
284 | - | let bc = getString(this, aX(aU, aY)) | |
285 | - | let bd = getString(this, aZ(aU, aY)) | |
286 | - | if (if ((aY == valueOrElse(bb, ""))) | |
294 | + | func bg (aW,ba) = { | |
295 | + | let bd = getString(this, aV(aW)) | |
296 | + | let bh = valueOrElse(getInteger(this, aY(aW)), 0) | |
297 | + | let bi = if (!(bc(aW, ba))) | |
287 | 298 | then true | |
288 | - | else (bc != unit)) | |
289 | - | then true | |
290 | - | else (bd != unit) | |
291 | - | } | |
292 | - | ||
293 | - | ||
294 | - | func be (aU,aY) = { | |
295 | - | let bb = getString(this, aT(aU)) | |
296 | - | let bf = valueOrElse(getInteger(this, aW(aU)), 0) | |
297 | - | let bg = if (!(ba(aU, aY))) | |
298 | - | then true | |
299 | - | else ab("Node exists") | |
300 | - | if ((bg == bg)) | |
301 | - | then (([IntegerEntry(aW(aU), (bf + 1))] ++ (if ((bb != unit)) | |
302 | - | then [StringEntry(aZ(aU, aY), value(bb)), StringEntry(aX(aU, value(bb)), aY)] | |
303 | - | else nil)) ++ [StringEntry(aT(aU), aY)]) | |
299 | + | else ad("Node exists") | |
300 | + | if ((bi == bi)) | |
301 | + | then (([IntegerEntry(aY(aW), (bh + 1))] ++ (if ((bd != unit)) | |
302 | + | then [StringEntry(bb(aW, ba), value(bd)), StringEntry(aZ(aW, value(bd)), ba)] | |
303 | + | else nil)) ++ [StringEntry(aV(aW), ba)]) | |
304 | 304 | else throw("Strict value is not equal to itself.") | |
305 | 305 | } | |
306 | 306 | ||
307 | 307 | ||
308 | - | func | |
309 | - | let | |
310 | - | let | |
311 | - | let | |
312 | - | let | |
313 | - | ([IntegerEntry(aW | |
314 | - | then ( | |
308 | + | func bj (aW,ba) = { | |
309 | + | let bd = getString(this, aV(aW)) | |
310 | + | let bh = valueOrElse(getInteger(this, aY(aW)), 0) | |
311 | + | let be = getString(this, aZ(aW, ba)) | |
312 | + | let bf = getString(this, bb(aW, ba)) | |
313 | + | ([IntegerEntry(aY(aW), (bh - 1))] ++ (if (if ((be != unit)) | |
314 | + | then (bf != unit) | |
315 | 315 | else false) | |
316 | - | then [StringEntry( | |
317 | - | else if (( | |
318 | - | then [StringEntry( | |
319 | - | else if (( | |
320 | - | then [DeleteEntry( | |
321 | - | else if (( | |
322 | - | then [DeleteEntry( | |
323 | - | else | |
316 | + | then [StringEntry(bb(aW, value(be)), value(bf)), StringEntry(aZ(aW, value(bf)), value(be)), DeleteEntry(aZ(aW, ba)), DeleteEntry(bb(aW, ba))] | |
317 | + | else if ((bf != unit)) | |
318 | + | then [StringEntry(aV(aW), value(bf)), DeleteEntry(bb(aW, ba)), DeleteEntry(aZ(aW, value(bf)))] | |
319 | + | else if ((be != unit)) | |
320 | + | then [DeleteEntry(aZ(aW, ba)), DeleteEntry(bb(aW, value(be)))] | |
321 | + | else if ((ba == valueOrElse(bd, ""))) | |
322 | + | then [DeleteEntry(aV(aW))] | |
323 | + | else ad(((("invalid node: " + aW) + ".") + ba)))) | |
324 | 324 | } | |
325 | 325 | ||
326 | 326 | ||
327 | - | func | |
327 | + | func bk () = "%s__managerVaultAddress" | |
328 | 328 | ||
329 | 329 | ||
330 | - | func | |
330 | + | func bl () = "%s__managerPublicKey" | |
331 | 331 | ||
332 | 332 | ||
333 | - | func | |
334 | - | let | |
335 | - | if ($isInstanceOf( | |
333 | + | func bm () = { | |
334 | + | let ai = getString(bk()) | |
335 | + | if ($isInstanceOf(ai, "String")) | |
336 | 336 | then { | |
337 | - | let | |
338 | - | addressFromStringValue( | |
337 | + | let bn = ai | |
338 | + | addressFromStringValue(bn) | |
339 | 339 | } | |
340 | 340 | else this | |
341 | 341 | } | |
342 | 342 | ||
343 | 343 | ||
344 | - | func | |
345 | - | let | |
346 | - | let | |
347 | - | if ($isInstanceOf( | |
344 | + | func bo () = { | |
345 | + | let bp = bm() | |
346 | + | let ai = getString(bp, bl()) | |
347 | + | if ($isInstanceOf(ai, "String")) | |
348 | 348 | then { | |
349 | - | let | |
350 | - | fromBase58String( | |
349 | + | let bn = ai | |
350 | + | fromBase58String(bn) | |
351 | 351 | } | |
352 | - | else if ($isInstanceOf( | |
352 | + | else if ($isInstanceOf(ai, "Unit")) | |
353 | 353 | then unit | |
354 | 354 | else throw("Match error") | |
355 | 355 | } | |
356 | 356 | ||
357 | 357 | ||
358 | - | func | |
359 | - | let | |
360 | - | if ($isInstanceOf( | |
358 | + | func bq (br) = { | |
359 | + | let ai = bo() | |
360 | + | if ($isInstanceOf(ai, "ByteVector")) | |
361 | 361 | then { | |
362 | - | let | |
363 | - | ( | |
362 | + | let bs = ai | |
363 | + | (br.callerPublicKey == bs) | |
364 | 364 | } | |
365 | - | else if ($isInstanceOf( | |
366 | - | then ( | |
365 | + | else if ($isInstanceOf(ai, "Unit")) | |
366 | + | then (br.caller == this) | |
367 | 367 | else throw("Match error") | |
368 | 368 | } | |
369 | 369 | ||
370 | 370 | ||
371 | - | func | |
371 | + | func bt (br) = if (bq(br)) | |
372 | 372 | then true | |
373 | 373 | else throw("permission denied") | |
374 | 374 | ||
375 | 375 | ||
376 | - | func | |
376 | + | func bu (br) = if ((br.caller == this)) | |
377 | 377 | then true | |
378 | 378 | else throw("permission denied") | |
379 | 379 | ||
380 | 380 | ||
381 | - | @Callable( | |
382 | - | func getUserGwxAmountAtHeight ( | |
383 | - | let | |
381 | + | @Callable(br) | |
382 | + | func getUserGwxAmountAtHeight (bv,bw) = { | |
383 | + | let bx = valueOrErrorMessage(addressFromString(al(this, v)), ab("invalid boosting contract address")) | |
384 | 384 | $Tuple2(nil, { | |
385 | - | let | |
386 | - | if ($isInstanceOf( | |
387 | - | then | |
388 | - | else throw(($getType( | |
385 | + | let am = invoke(bx, "getUserGwxAmountAtHeightREADONLY", [bv, bw], nil) | |
386 | + | if ($isInstanceOf(am, "Int")) | |
387 | + | then am | |
388 | + | else throw(($getType(am) + " couldn't be cast to Int")) | |
389 | 389 | }) | |
390 | 390 | } | |
391 | 391 | ||
392 | 392 | ||
393 | 393 | ||
394 | - | @Callable( | |
395 | - | func constructor ( | |
396 | - | let | |
394 | + | @Callable(br) | |
395 | + | func constructor (ar,by,bz,bA,bB) = { | |
396 | + | let bC = [bt(br), if ((addressFromString(ar) != unit)) | |
397 | 397 | then true | |
398 | - | else "invalid factory contract address", if ((addressFromString( | |
398 | + | else "invalid factory contract address", if ((addressFromString(by) != unit)) | |
399 | 399 | then true | |
400 | - | else "invalid voting emission candidate contract address", if ((addressFromString( | |
400 | + | else "invalid voting emission candidate contract address", if ((addressFromString(bz) != unit)) | |
401 | 401 | then true | |
402 | - | else "invalid boosting contract address", if ((addressFromString( | |
402 | + | else "invalid boosting contract address", if ((addressFromString(bA) != unit)) | |
403 | 403 | then true | |
404 | - | else "invalid staking contract address", if (( | |
404 | + | else "invalid staking contract address", if ((bB > 0)) | |
405 | 405 | then true | |
406 | - | else | |
407 | - | if (( | |
408 | - | then $Tuple2([StringEntry( | |
406 | + | else ad("invalid epoch length")] | |
407 | + | if ((bC == bC)) | |
408 | + | then $Tuple2([StringEntry(u, ar), StringEntry(s, by), StringEntry(v, bz), StringEntry(w, bA), IntegerEntry(l, bB)], unit) | |
409 | 409 | else throw("Strict value is not equal to itself.") | |
410 | 410 | } | |
411 | 411 | ||
412 | 412 | ||
413 | 413 | ||
414 | - | @Callable( | |
415 | - | func create ( | |
416 | - | let | |
414 | + | @Callable(br) | |
415 | + | func create (M,N) = { | |
416 | + | let bC = [if ((toBase58String(br.caller.bytes) == valueOrElse(getString(this, s), ""))) | |
417 | 417 | then true | |
418 | - | else br | |
419 | - | if (( | |
418 | + | else bt(br)] | |
419 | + | if ((bC == bC)) | |
420 | 420 | then { | |
421 | - | let | |
422 | - | let | |
423 | - | let | |
424 | - | let | |
421 | + | let K = $Tuple2(M, N) | |
422 | + | let bD = ([BooleanEntry(J(K), true)] ++ bg(aS, ao(K))) | |
423 | + | let bE = (getInteger(this, p) == unit) | |
424 | + | let bF = if (bE) | |
425 | 425 | then { | |
426 | - | let | |
427 | - | [IntegerEntry( | |
426 | + | let o = 0 | |
427 | + | [IntegerEntry(p, o), IntegerEntry(H(o), height), IntegerEntry(B, height), IntegerEntry(C, o), IntegerEntry(D, height)] | |
428 | 428 | } | |
429 | 429 | else nil | |
430 | - | $Tuple2(( | |
430 | + | $Tuple2((bD ++ bF), unit) | |
431 | 431 | } | |
432 | 432 | else throw("Strict value is not equal to itself.") | |
433 | 433 | } | |
434 | 434 | ||
435 | 435 | ||
436 | 436 | ||
437 | - | @Callable( | |
438 | - | func vote ( | |
439 | - | let | |
440 | - | let | |
441 | - | let | |
442 | - | let | |
443 | - | let | |
444 | - | let | |
445 | - | let | |
446 | - | let | |
447 | - | let | |
448 | - | let | |
449 | - | let | |
450 | - | let | |
451 | - | if ($isInstanceOf( | |
452 | - | then | |
453 | - | else throw(($getType( | |
437 | + | @Callable(br) | |
438 | + | func vote (M,N,bG) = { | |
439 | + | let K = $Tuple2(M, N) | |
440 | + | let o = valueOrElse(getInteger(this, p), 0) | |
441 | + | let bH = an(this, H(o)) | |
442 | + | let bB = an(this, l) | |
443 | + | let bI = (bH + bB) | |
444 | + | let bJ = getInteger(this, y) | |
445 | + | let bK = valueOrElse(getInteger(this, O(br.caller, o)), 0) | |
446 | + | let bL = valueOrElse(getInteger(this, Q(K, br.caller, o)), 0) | |
447 | + | let bM = valueOrElse(getInteger(this, S(K, o)), 0) | |
448 | + | let bN = valueOrElse(getInteger(this, Y(o)), 0) | |
449 | + | let bO = { | |
450 | + | let am = invoke(this, "getUserGwxAmountAtHeight", [toBase58String(br.caller.bytes), bI], nil) | |
451 | + | if ($isInstanceOf(am, "Int")) | |
452 | + | then am | |
453 | + | else throw(($getType(am) + " couldn't be cast to Int")) | |
454 | 454 | } | |
455 | - | let | |
456 | - | let | |
457 | - | let | |
458 | - | let | |
455 | + | let bP = (bO - bK) | |
456 | + | let bQ = (bL + bG) | |
457 | + | let bR = aO(K) | |
458 | + | let bC = [if ((getBoolean(J(K)) != unit)) | |
459 | 459 | then true | |
460 | - | else | |
460 | + | else ad("invalid assets"), if ((bI > height)) | |
461 | 461 | then true | |
462 | - | else | |
462 | + | else ad("invalid height"), if ((bJ == unit)) | |
463 | 463 | then true | |
464 | - | else | |
464 | + | else ad("finalization in progress"), if ((bO > 0)) | |
465 | 465 | then true | |
466 | - | else | |
467 | - | then ( | |
466 | + | else ad("you do not have gWX"), if (if ((bG > 0)) | |
467 | + | then (bP >= bG) | |
468 | 468 | else false) | |
469 | 469 | then true | |
470 | - | else | |
470 | + | else ad("invalid amount"), if (bR) | |
471 | 471 | then true | |
472 | - | else | |
473 | - | if (( | |
472 | + | else ad("pool hasn't WX_EMISSION label")] | |
473 | + | if ((bC == bC)) | |
474 | 474 | then { | |
475 | - | let | |
476 | - | let | |
477 | - | let | |
475 | + | let bS = aT(K) | |
476 | + | let aa = toString(br.caller) | |
477 | + | let bT = if (bc(bS, aa)) | |
478 | 478 | then nil | |
479 | - | else | |
480 | - | $Tuple2(([IntegerEntry( | |
479 | + | else bg(bS, aa) | |
480 | + | $Tuple2(([IntegerEntry(O(br.caller, o), (bK + bG)), IntegerEntry(Q(K, br.caller, o), bQ), IntegerEntry(S(K, o), (bM + bG)), IntegerEntry(Y(o), (bN + bG))] ++ bT), unit) | |
481 | 481 | } | |
482 | 482 | else throw("Strict value is not equal to itself.") | |
483 | 483 | } | |
484 | 484 | ||
485 | 485 | ||
486 | 486 | ||
487 | - | @Callable( | |
488 | - | func cancelVote ( | |
489 | - | let | |
490 | - | let | |
491 | - | let | |
492 | - | let | |
493 | - | let | |
494 | - | let | |
495 | - | let | |
496 | - | let | |
497 | - | let | |
498 | - | let | |
499 | - | let | |
487 | + | @Callable(br) | |
488 | + | func cancelVote (M,N) = { | |
489 | + | let K = $Tuple2(M, N) | |
490 | + | let o = valueOrElse(getInteger(this, p), 0) | |
491 | + | let bH = an(this, H(o)) | |
492 | + | let bB = an(this, l) | |
493 | + | let bI = (bH + bB) | |
494 | + | let bJ = getInteger(this, y) | |
495 | + | let bK = valueOrElse(getInteger(this, O(br.caller, o)), 0) | |
496 | + | let bL = valueOrElse(getInteger(this, Q(K, br.caller, o)), 0) | |
497 | + | let bM = valueOrElse(getInteger(this, S(K, o)), 0) | |
498 | + | let bN = valueOrElse(getInteger(this, Y(o)), 0) | |
499 | + | let bC = [if ((getBoolean(J(K)) != unit)) | |
500 | 500 | then true | |
501 | - | else | |
501 | + | else ad("invalid assets"), if ((bI > height)) | |
502 | 502 | then true | |
503 | - | else | |
503 | + | else ad("invalid height"), if ((bJ == unit)) | |
504 | 504 | then true | |
505 | - | else | |
505 | + | else ad("finalization in progress"), if ((bL > 0)) | |
506 | 506 | then true | |
507 | - | else | |
508 | - | if (( | |
507 | + | else ad("no vote")] | |
508 | + | if ((bC == bC)) | |
509 | 509 | then { | |
510 | - | let | |
511 | - | let | |
512 | - | $Tuple2(([IntegerEntry( | |
510 | + | let bS = aT(K) | |
511 | + | let aa = toString(br.caller) | |
512 | + | $Tuple2(([IntegerEntry(O(br.caller, o), max([(bK - bL), 0])), DeleteEntry(Q(K, br.caller, o)), IntegerEntry(S(K, o), (bM - bL)), IntegerEntry(Y(o), (bN - bL))] ++ bj(bS, aa)), unit) | |
513 | 513 | } | |
514 | 514 | else throw("Strict value is not equal to itself.") | |
515 | 515 | } | |
516 | 516 | ||
517 | 517 | ||
518 | 518 | ||
519 | - | @Callable( | |
520 | - | func setEpochLength ( | |
521 | - | let | |
519 | + | @Callable(br) | |
520 | + | func setEpochLength (bU) = { | |
521 | + | let bC = [bt(br), if ((bU > 0)) | |
522 | 522 | then true | |
523 | - | else | |
524 | - | if (( | |
525 | - | then $Tuple2([IntegerEntry( | |
523 | + | else ad("invalid epoch length")] | |
524 | + | if ((bC == bC)) | |
525 | + | then $Tuple2([IntegerEntry(m, bU)], unit) | |
526 | 526 | else throw("Strict value is not equal to itself.") | |
527 | 527 | } | |
528 | 528 | ||
529 | 529 | ||
530 | 530 | ||
531 | - | @Callable( | |
532 | - | func setMaxDepth ( | |
533 | - | let | |
531 | + | @Callable(br) | |
532 | + | func setMaxDepth (bV) = { | |
533 | + | let bC = [bt(br), if ((bV > 0)) | |
534 | 534 | then true | |
535 | - | else | |
536 | - | if (( | |
537 | - | then $Tuple2([IntegerEntry( | |
535 | + | else ad("invalid max depth")] | |
536 | + | if ((bC == bC)) | |
537 | + | then $Tuple2([IntegerEntry(q, bV)], unit) | |
538 | 538 | else throw("Strict value is not equal to itself.") | |
539 | 539 | } | |
540 | 540 | ||
541 | 541 | ||
542 | 542 | ||
543 | - | @Callable( | |
544 | - | func processPoolBalanceINTERNAL ( | |
545 | - | let | |
546 | - | if (( | |
543 | + | @Callable(br) | |
544 | + | func processPoolBalanceINTERNAL (bW) = { | |
545 | + | let bX = bu(br) | |
546 | + | if ((bX == bX)) | |
547 | 547 | then { | |
548 | - | let | |
549 | - | let | |
550 | - | let | |
551 | - | let | |
552 | - | let | |
553 | - | let | |
554 | - | let | |
555 | - | let | |
556 | - | let | |
557 | - | if ($isInstanceOf( | |
558 | - | then | |
559 | - | else throw(($getType( | |
548 | + | let o = an(this, p) | |
549 | + | let bY = (o - 1) | |
550 | + | let K = ap(bW) | |
551 | + | let bZ = K | |
552 | + | let M = bZ._1 | |
553 | + | let N = bZ._2 | |
554 | + | let aN = aD(M, N) | |
555 | + | let ca = { | |
556 | + | let am = invoke(ar, "checkBalance", [aN], nil) | |
557 | + | if ($isInstanceOf(am, "Boolean")) | |
558 | + | then am | |
559 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
560 | 560 | } | |
561 | - | let bZ = !(valueOrElse(getBoolean(this, K(G, (bW - 1))), false)) | |
562 | - | let ca = if (!(bY)) | |
563 | - | then if (!(bZ)) | |
564 | - | then { | |
565 | - | let cb = invoke(ap, "deleteWxEmissionPoolLabel", [I, J], nil) | |
566 | - | if ((cb == cb)) | |
567 | - | then { | |
568 | - | let cc = invoke(ap, "modifyWeight", [aL, 0], nil) | |
569 | - | if ((cc == cc)) | |
570 | - | then { | |
571 | - | let cd = valueOrErrorMessage(az(I, J), Z("invalid assets"))._1 | |
572 | - | let ce = 3 | |
573 | - | let cf = invoke(ap, "managePool", [toString(cd), ce], nil) | |
574 | - | if ((cf == cf)) | |
575 | - | then { | |
576 | - | let cg = ([DeleteEntry(F(G))] ++ bh(aQ, am(G))) | |
577 | - | ([IntegerEntry(U(G, bW), 0)] ++ cg) | |
578 | - | } | |
579 | - | else throw("Strict value is not equal to itself.") | |
580 | - | } | |
581 | - | else throw("Strict value is not equal to itself.") | |
582 | - | } | |
583 | - | else throw("Strict value is not equal to itself.") | |
584 | - | } | |
585 | - | else [BooleanEntry(K(G, bW), true)] | |
561 | + | let cb = if (!(ca)) | |
562 | + | then { | |
563 | + | let cc = invoke(ar, "deleteWxEmissionPoolLabel", [M, N], nil) | |
564 | + | if ((cc == cc)) | |
565 | + | then { | |
566 | + | let cd = invoke(ar, "modifyWeight", [aN, 0], nil) | |
567 | + | if ((cd == cd)) | |
568 | + | then { | |
569 | + | let ce = valueOrErrorMessage(aB(M, N), ab("invalid assets"))._1 | |
570 | + | let cf = invoke(ar, "managePool", [toString(ce), j], nil) | |
571 | + | if ((cf == cf)) | |
572 | + | then { | |
573 | + | let cg = ([DeleteEntry(J(K))] ++ bj(aS, ao(K))) | |
574 | + | ([IntegerEntry(W(K, bY), 0)] ++ cg) | |
575 | + | } | |
576 | + | else throw("Strict value is not equal to itself.") | |
577 | + | } | |
578 | + | else throw("Strict value is not equal to itself.") | |
579 | + | } | |
580 | + | else throw("Strict value is not equal to itself.") | |
581 | + | } | |
586 | 582 | else nil | |
587 | - | $Tuple2( | |
583 | + | $Tuple2(cb, unit) | |
588 | 584 | } | |
589 | 585 | else throw("Strict value is not equal to itself.") | |
590 | 586 | } | |
591 | 587 | ||
592 | 588 | ||
593 | 589 | ||
594 | - | @Callable( | |
595 | - | func processVoteINTERNAL ( | |
596 | - | let | |
597 | - | if (( | |
590 | + | @Callable(br) | |
591 | + | func processVoteINTERNAL (bW,aa) = { | |
592 | + | let bX = bu(br) | |
593 | + | if ((bX == bX)) | |
598 | 594 | then { | |
599 | - | let | |
600 | - | let | |
601 | - | let | |
602 | - | let | |
603 | - | let | |
604 | - | let | |
605 | - | let ch = | |
606 | - | let ci = | |
595 | + | let bv = valueOrErrorMessage(addressFromString(aa), ab(("processVoteINTERNAL: invalid user address " + aa))) | |
596 | + | let o = an(this, p) | |
597 | + | let bY = (o - 1) | |
598 | + | let bB = an(this, l) | |
599 | + | let bH = an(this, H(o)) | |
600 | + | let bI = (bH + bB) | |
601 | + | let ch = an(this, H(bY)) | |
602 | + | let ci = an(this, n(bY)) | |
607 | 603 | let cj = (ch + ci) | |
608 | - | let ck = if (( | |
604 | + | let ck = if ((bY >= 0)) | |
609 | 605 | then true | |
610 | - | else | |
606 | + | else ad("processVoteINTERNAL: invalid previous epoch") | |
611 | 607 | if ((ck == ck)) | |
612 | 608 | then { | |
613 | - | let | |
614 | - | let cl = | |
615 | - | let | |
616 | - | let | |
617 | - | let | |
618 | - | let | |
619 | - | if ($isInstanceOf( | |
620 | - | then | |
621 | - | else throw(($getType( | |
609 | + | let K = ap(bW) | |
610 | + | let cl = K | |
611 | + | let M = cl._1 | |
612 | + | let N = cl._2 | |
613 | + | let bO = { | |
614 | + | let am = invoke(this, "getUserGwxAmountAtHeight", [aa, bI], nil) | |
615 | + | if ($isInstanceOf(am, "Int")) | |
616 | + | then am | |
617 | + | else throw(($getType(am) + " couldn't be cast to Int")) | |
622 | 618 | } | |
623 | 619 | let cm = { | |
624 | - | let | |
625 | - | if ($isInstanceOf( | |
626 | - | then | |
627 | - | else throw(($getType( | |
620 | + | let am = invoke(this, "getUserGwxAmountAtHeight", [aa, cj], nil) | |
621 | + | if ($isInstanceOf(am, "Int")) | |
622 | + | then am | |
623 | + | else throw(($getType(am) + " couldn't be cast to Int")) | |
628 | 624 | } | |
629 | - | let | |
630 | - | let cn = valueOrElse(getInteger( | |
631 | - | let co = getInteger( | |
632 | - | let cp = valueOrErrorMessage(co, | |
633 | - | let | |
634 | - | let | |
635 | - | let cq = valueOrElse(getInteger( | |
636 | - | let | |
637 | - | let cr = valueOrElse(getInteger( | |
625 | + | let bN = valueOrElse(getInteger(Y(o)), 0) | |
626 | + | let cn = valueOrElse(getInteger(S(K, o)), 0) | |
627 | + | let co = getInteger(Q(K, bv, bY)) | |
628 | + | let cp = valueOrErrorMessage(co, ab((((("processVoteINTERNAL " + bW) + " ") + aa) + ": no previous vote"))) | |
629 | + | let bK = valueOrElse(getInteger(this, O(bv, o)), 0) | |
630 | + | let V = aD(M, N) | |
631 | + | let cq = valueOrElse(getInteger(U(V, bY)), 0) | |
632 | + | let bA = addressFromStringValue(al(this, w)) | |
633 | + | let cr = valueOrElse(getInteger(bA, Z(V, aa)), 0) | |
638 | 634 | let cs = if (if ((cr == 0)) | |
639 | 635 | then true | |
640 | 636 | else (co == unit)) | |
641 | 637 | then nil | |
642 | - | else [IntegerEntry( | |
643 | - | let | |
644 | - | let | |
645 | - | then fraction(cp, | |
638 | + | else [IntegerEntry(U(V, bY), (cq + cp))] | |
639 | + | let aN = aD(M, N) | |
640 | + | let bQ = if ((cm > 0)) | |
641 | + | then fraction(cp, bO, cm) | |
646 | 642 | else 0 | |
647 | - | let | |
643 | + | let cb = if (if ((co == unit)) | |
648 | 644 | then true | |
649 | - | else (0 >= | |
650 | - | then | |
651 | - | else [IntegerEntry( | |
652 | - | $Tuple2(( | |
645 | + | else (0 >= bQ)) | |
646 | + | then bj(aT(K), aa) | |
647 | + | else [IntegerEntry(Q(K, bv, o), bQ), IntegerEntry(Y(o), (bN + bQ)), IntegerEntry(S(K, o), (cn + bQ)), IntegerEntry(O(bv, o), (bK + bQ))] | |
648 | + | $Tuple2((cb ++ cs), unit) | |
653 | 649 | } | |
654 | 650 | else throw("Strict value is not equal to itself.") | |
655 | 651 | } | |
656 | 652 | else throw("Strict value is not equal to itself.") | |
657 | 653 | } | |
658 | 654 | ||
659 | 655 | ||
660 | 656 | ||
661 | - | @Callable( | |
662 | - | func processPoolINTERNAL ( | |
663 | - | let | |
664 | - | if (( | |
657 | + | @Callable(br) | |
658 | + | func processPoolINTERNAL (bW,ct) = { | |
659 | + | let bX = bu(br) | |
660 | + | if ((bX == bX)) | |
665 | 661 | then { | |
666 | 662 | let cu = { | |
667 | - | let cv = | |
663 | + | let cv = an(this, p) | |
668 | 664 | if (ct) | |
669 | 665 | then cv | |
670 | 666 | else (cv - 1) | |
671 | 667 | } | |
672 | 668 | let ck = if ((cu >= 0)) | |
673 | 669 | then true | |
674 | - | else | |
670 | + | else ad("processPoolINTERNAL: invalid target epoch") | |
675 | 671 | if ((ck == ck)) | |
676 | 672 | then { | |
677 | - | let | |
678 | - | let cw = | |
679 | - | let | |
680 | - | let | |
681 | - | let | |
682 | - | let | |
673 | + | let K = ap(bW) | |
674 | + | let cw = K | |
675 | + | let M = cw._1 | |
676 | + | let N = cw._2 | |
677 | + | let bA = addressFromStringValue(al(this, w)) | |
678 | + | let aN = aD(M, N) | |
683 | 679 | let cx = { | |
684 | - | let | |
685 | - | if ($isInstanceOf( | |
686 | - | then | |
687 | - | else throw(($getType( | |
680 | + | let am = invoke(bA, "usersListTraversal", [aN], nil) | |
681 | + | if ($isInstanceOf(am, "Boolean")) | |
682 | + | then am | |
683 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
688 | 684 | } | |
689 | 685 | if ((cx == cx)) | |
690 | 686 | then if (cx) | |
691 | 687 | then $Tuple2(nil, true) | |
692 | 688 | else { | |
693 | - | let cy = addressFromStringValue(valueOrErrorMessage(getString( | |
694 | - | let | |
695 | - | let cn = valueOrElse(getInteger(this, | |
696 | - | let cz = if (( | |
689 | + | let cy = addressFromStringValue(valueOrErrorMessage(getString(ar, x), "invalid assets store contract")) | |
690 | + | let bN = valueOrElse(getInteger(this, Y(cu)), 0) | |
691 | + | let cn = valueOrElse(getInteger(this, S(K, cu)), 0) | |
692 | + | let cz = if ((bN == 0)) | |
697 | 693 | then 0 | |
698 | - | else fraction(cn, b, | |
699 | - | let | |
700 | - | if (( | |
701 | - | then $Tuple2([IntegerEntry( | |
694 | + | else fraction(cn, b, bN) | |
695 | + | let cd = invoke(ar, "modifyWeight", [aN, cz], nil) | |
696 | + | if ((cd == cd)) | |
697 | + | then $Tuple2([IntegerEntry(W(K, cu), cz)], false) | |
702 | 698 | else throw("Strict value is not equal to itself.") | |
703 | 699 | } | |
704 | 700 | else throw("Strict value is not equal to itself.") | |
705 | 701 | } | |
706 | 702 | else throw("Strict value is not equal to itself.") | |
707 | 703 | } | |
708 | 704 | else throw("Strict value is not equal to itself.") | |
709 | 705 | } | |
710 | 706 | ||
711 | 707 | ||
712 | 708 | ||
713 | - | @Callable( | |
709 | + | @Callable(br) | |
714 | 710 | func finalizeHelper () = { | |
715 | - | let ct = valueOrElse(getBoolean( | |
716 | - | let | |
717 | - | let cA = ( | |
718 | - | let | |
719 | - | let | |
720 | - | let | |
721 | - | let | |
722 | - | if (if (if ((height >= | |
723 | - | then ( | |
711 | + | let ct = valueOrElse(getBoolean(E), false) | |
712 | + | let o = valueOrElse(getInteger(this, p), 0) | |
713 | + | let cA = (o - 1) | |
714 | + | let bH = an(this, H(o)) | |
715 | + | let bB = an(this, l) | |
716 | + | let bI = (bH + bB) | |
717 | + | let bJ = getInteger(this, y) | |
718 | + | if (if (if ((height >= bI)) | |
719 | + | then (bJ == unit) | |
724 | 720 | else false) | |
725 | 721 | then !(ct) | |
726 | 722 | else false) | |
727 | 723 | then { | |
728 | - | let cB = ( | |
729 | - | let cC = getInteger(this, | |
724 | + | let cB = (o + 1) | |
725 | + | let cC = getInteger(this, m) | |
730 | 726 | let cD = { | |
731 | - | let | |
732 | - | if ($isInstanceOf( | |
727 | + | let ai = cC | |
728 | + | if ($isInstanceOf(ai, "Int")) | |
733 | 729 | then { | |
734 | - | let | |
735 | - | [IntegerEntry( | |
730 | + | let bU = ai | |
731 | + | [IntegerEntry(l, bU), DeleteEntry(m)] | |
736 | 732 | } | |
737 | - | else if ($isInstanceOf( | |
733 | + | else if ($isInstanceOf(ai, "Unit")) | |
738 | 734 | then nil | |
739 | 735 | else throw("Match error") | |
740 | 736 | } | |
741 | - | $Tuple2(([IntegerEntry( | |
737 | + | $Tuple2(([IntegerEntry(H(cB), height), IntegerEntry(B, height), IntegerEntry(p, cB), IntegerEntry(y, d), IntegerEntry(n(o), bB)] ++ cD), true) | |
742 | 738 | } | |
743 | 739 | else if (if (ct) | |
744 | - | then ( | |
740 | + | then (bJ == unit) | |
745 | 741 | else false) | |
746 | - | then $Tuple2([IntegerEntry( | |
747 | - | else if (( | |
742 | + | then $Tuple2([IntegerEntry(y, f)], true) | |
743 | + | else if ((bJ == unit)) | |
748 | 744 | then $Tuple2(nil, false) | |
749 | - | else if (( | |
745 | + | else if ((bJ == d)) | |
750 | 746 | then { | |
751 | - | let cE = getString( | |
752 | - | let | |
753 | - | if ($isInstanceOf( | |
747 | + | let cE = getString(z) | |
748 | + | let ai = cE | |
749 | + | if ($isInstanceOf(ai, "Unit")) | |
754 | 750 | then { | |
755 | - | let cF = getString( | |
751 | + | let cF = getString(aV(aS)) | |
756 | 752 | if ($isInstanceOf(cF, "Unit")) | |
757 | - | then $Tuple2([IntegerEntry( | |
753 | + | then $Tuple2([IntegerEntry(y, e), DeleteEntry(z)], true) | |
758 | 754 | else if ($isInstanceOf(cF, "String")) | |
759 | 755 | then { | |
760 | 756 | let cG = cF | |
761 | - | $Tuple2([StringEntry( | |
757 | + | $Tuple2([StringEntry(z, cG)], true) | |
762 | 758 | } | |
763 | 759 | else throw("Match error") | |
764 | 760 | } | |
765 | - | else if ($isInstanceOf( | |
761 | + | else if ($isInstanceOf(ai, "String")) | |
766 | 762 | then { | |
767 | - | let | |
768 | - | let cH = getString( | |
763 | + | let bW = ai | |
764 | + | let cH = getString(bb(aS, bW)) | |
769 | 765 | if ((cH == cH)) | |
770 | 766 | then { | |
771 | - | let cx = invoke(this, "processPoolBalanceINTERNAL", [ | |
767 | + | let cx = invoke(this, "processPoolBalanceINTERNAL", [bW], nil) | |
772 | 768 | if ((cx == cx)) | |
773 | 769 | then { | |
774 | 770 | let cF = cH | |
775 | 771 | if ($isInstanceOf(cF, "Unit")) | |
776 | - | then $Tuple2([IntegerEntry( | |
772 | + | then $Tuple2([IntegerEntry(y, e), DeleteEntry(z)], true) | |
777 | 773 | else if ($isInstanceOf(cF, "String")) | |
778 | 774 | then { | |
779 | 775 | let cG = cF | |
780 | - | $Tuple2([StringEntry( | |
776 | + | $Tuple2([StringEntry(z, cG)], true) | |
781 | 777 | } | |
782 | 778 | else throw("Match error") | |
783 | 779 | } | |
784 | 780 | else throw("Strict value is not equal to itself.") | |
785 | 781 | } | |
786 | 782 | else throw("Strict value is not equal to itself.") | |
787 | 783 | } | |
788 | 784 | else throw("Match error") | |
789 | 785 | } | |
790 | - | else if (( | |
786 | + | else if ((bJ == e)) | |
791 | 787 | then { | |
792 | - | let cE = getString( | |
793 | - | let cI = getString( | |
794 | - | let | |
795 | - | if ($isInstanceOf( | |
788 | + | let cE = getString(z) | |
789 | + | let cI = getString(A) | |
790 | + | let ai = cE | |
791 | + | if ($isInstanceOf(ai, "Unit")) | |
796 | 792 | then { | |
797 | - | let cF = getString( | |
793 | + | let cF = getString(aV(aS)) | |
798 | 794 | if ($isInstanceOf(cF, "Unit")) | |
799 | - | then $Tuple2([IntegerEntry( | |
795 | + | then $Tuple2([IntegerEntry(y, f), DeleteEntry(z), DeleteEntry(A)], true) | |
800 | 796 | else if ($isInstanceOf(cF, "String")) | |
801 | 797 | then { | |
802 | 798 | let cJ = cF | |
803 | - | $Tuple2([StringEntry( | |
799 | + | $Tuple2([StringEntry(z, cJ)], true) | |
804 | 800 | } | |
805 | 801 | else throw("Match error") | |
806 | 802 | } | |
807 | - | else if ($isInstanceOf( | |
803 | + | else if ($isInstanceOf(ai, "String")) | |
808 | 804 | then { | |
809 | - | let | |
810 | - | let | |
805 | + | let bW = ai | |
806 | + | let K = ap(bW) | |
811 | 807 | let cK = { | |
812 | 808 | let cF = cI | |
813 | 809 | if ($isInstanceOf(cF, "Unit")) | |
814 | - | then getString(aT( | |
810 | + | then getString(aV(aT(K))) | |
815 | 811 | else if ($isInstanceOf(cF, "String")) | |
816 | 812 | then { | |
817 | 813 | let cL = cF | |
818 | - | let cM = getString( | |
814 | + | let cM = getString(bb(aT(K), cL)) | |
819 | 815 | if ((cM == cM)) | |
820 | 816 | then { | |
821 | - | let cN = invoke(this, "processVoteINTERNAL", [ | |
817 | + | let cN = invoke(this, "processVoteINTERNAL", [bW, cL], nil) | |
822 | 818 | if ((cN == cN)) | |
823 | 819 | then cM | |
824 | 820 | else throw("Strict value is not equal to itself.") | |
825 | 821 | } | |
826 | 822 | else throw("Strict value is not equal to itself.") | |
827 | 823 | } | |
828 | 824 | else throw("Match error") | |
829 | 825 | } | |
830 | 826 | let cF = cK | |
831 | 827 | if ($isInstanceOf(cF, "Unit")) | |
832 | 828 | then { | |
833 | - | let cH = getString( | |
829 | + | let cH = getString(bb(aS, bW)) | |
834 | 830 | let cO = cH | |
835 | 831 | if ($isInstanceOf(cO, "Unit")) | |
836 | - | then $Tuple2([IntegerEntry( | |
832 | + | then $Tuple2([IntegerEntry(y, f), DeleteEntry(z), DeleteEntry(A)], true) | |
837 | 833 | else if ($isInstanceOf(cO, "String")) | |
838 | 834 | then { | |
839 | - | let | |
840 | - | $Tuple2([StringEntry( | |
835 | + | let bn = cO | |
836 | + | $Tuple2([StringEntry(z, bn), DeleteEntry(A)], true) | |
841 | 837 | } | |
842 | 838 | else throw("Match error") | |
843 | 839 | } | |
844 | 840 | else if ($isInstanceOf(cF, "String")) | |
845 | 841 | then { | |
846 | 842 | let cP = cF | |
847 | - | $Tuple2([StringEntry( | |
843 | + | $Tuple2([StringEntry(A, cP)], true) | |
848 | 844 | } | |
849 | 845 | else throw("Match error") | |
850 | 846 | } | |
851 | 847 | else throw("Match error") | |
852 | 848 | } | |
853 | - | else if (( | |
849 | + | else if ((bJ == f)) | |
854 | 850 | then { | |
855 | - | let cE = getString( | |
856 | - | let | |
857 | - | if ($isInstanceOf( | |
851 | + | let cE = getString(z) | |
852 | + | let ai = cE | |
853 | + | if ($isInstanceOf(ai, "Unit")) | |
858 | 854 | then { | |
859 | - | let cF = getString( | |
855 | + | let cF = getString(aV(aS)) | |
860 | 856 | if ($isInstanceOf(cF, "Unit")) | |
861 | 857 | then { | |
862 | - | let | |
863 | - | then [DeleteEntry( | |
864 | - | else [DeleteEntry( | |
865 | - | let cQ = | |
858 | + | let cb = if (ct) | |
859 | + | then [DeleteEntry(y), DeleteEntry(E)] | |
860 | + | else [DeleteEntry(y), BooleanEntry(I(cA), true), IntegerEntry(C, o), IntegerEntry(D, bH)] | |
861 | + | let cQ = aQ() | |
866 | 862 | if ((cQ == cQ)) | |
867 | - | then $Tuple2( | |
863 | + | then $Tuple2(cb, true) | |
868 | 864 | else throw("Strict value is not equal to itself.") | |
869 | 865 | } | |
870 | 866 | else if ($isInstanceOf(cF, "String")) | |
871 | 867 | then { | |
872 | 868 | let cG = cF | |
873 | - | $Tuple2([StringEntry( | |
869 | + | $Tuple2([StringEntry(z, cG)], true) | |
874 | 870 | } | |
875 | 871 | else throw("Match error") | |
876 | 872 | } | |
877 | - | else if ($isInstanceOf( | |
873 | + | else if ($isInstanceOf(ai, "String")) | |
878 | 874 | then { | |
879 | - | let | |
880 | - | let cH = getString( | |
875 | + | let bW = ai | |
876 | + | let cH = getString(bb(aS, bW)) | |
881 | 877 | if ((cH == cH)) | |
882 | 878 | then { | |
883 | 879 | let cx = { | |
884 | - | let | |
885 | - | if ($isInstanceOf( | |
886 | - | then | |
887 | - | else throw(($getType( | |
880 | + | let am = invoke(this, "processPoolINTERNAL", [bW, ct], nil) | |
881 | + | if ($isInstanceOf(am, "Boolean")) | |
882 | + | then am | |
883 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
888 | 884 | } | |
889 | 885 | if ((cx == cx)) | |
890 | 886 | then if (cx) | |
891 | 887 | then $Tuple2(nil, true) | |
892 | 888 | else { | |
893 | 889 | let cF = cH | |
894 | 890 | if ($isInstanceOf(cF, "Unit")) | |
895 | 891 | then { | |
896 | - | let | |
897 | - | then [DeleteEntry( | |
898 | - | else [DeleteEntry( | |
899 | - | let cQ = | |
892 | + | let cb = if (ct) | |
893 | + | then [DeleteEntry(y), DeleteEntry(E), DeleteEntry(z)] | |
894 | + | else [DeleteEntry(y), BooleanEntry(I(cA), true), IntegerEntry(C, o), IntegerEntry(D, bH), DeleteEntry(z)] | |
895 | + | let cQ = aQ() | |
900 | 896 | if ((cQ == cQ)) | |
901 | - | then $Tuple2( | |
897 | + | then $Tuple2(cb, true) | |
902 | 898 | else throw("Strict value is not equal to itself.") | |
903 | 899 | } | |
904 | 900 | else if ($isInstanceOf(cF, "String")) | |
905 | 901 | then { | |
906 | 902 | let cG = cF | |
907 | - | $Tuple2([StringEntry( | |
903 | + | $Tuple2([StringEntry(z, cG)], true) | |
908 | 904 | } | |
909 | 905 | else throw("Match error") | |
910 | 906 | } | |
911 | 907 | else throw("Strict value is not equal to itself.") | |
912 | 908 | } | |
913 | 909 | else throw("Strict value is not equal to itself.") | |
914 | 910 | } | |
915 | 911 | else throw("Match error") | |
916 | 912 | } | |
917 | - | else | |
913 | + | else ad("finalization is broken") | |
918 | 914 | } | |
919 | 915 | ||
920 | 916 | ||
921 | 917 | ||
922 | - | @Callable( | |
918 | + | @Callable(br) | |
923 | 919 | func finalizeWrapper (cR) = { | |
924 | - | let cS = addressFromStringValue(getStringValue(this, | |
920 | + | let cS = addressFromStringValue(getStringValue(this, t)) | |
925 | 921 | let cT = { | |
926 | - | let | |
927 | - | if ($isInstanceOf( | |
928 | - | then | |
929 | - | else throw(($getType( | |
922 | + | let am = invoke(this, "finalizeHelper", nil, nil) | |
923 | + | if ($isInstanceOf(am, "Boolean")) | |
924 | + | then am | |
925 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
930 | 926 | } | |
931 | 927 | if ((cT == cT)) | |
932 | 928 | then if (!(cT)) | |
933 | 929 | then if ((cR == 0)) | |
934 | - | then | |
930 | + | then ad("Current voting is not over yet") | |
935 | 931 | else { | |
936 | 932 | let cU = invoke(cS, "finalize", nil, nil) | |
937 | 933 | if ((cU == cU)) | |
938 | 934 | then $Tuple2(nil, unit) | |
939 | 935 | else throw("Strict value is not equal to itself.") | |
940 | 936 | } | |
941 | 937 | else { | |
942 | - | let cV = valueOrElse(getInteger(this, | |
938 | + | let cV = valueOrElse(getInteger(this, q), c) | |
943 | 939 | if ((cV > cR)) | |
944 | 940 | then { | |
945 | 941 | let cU = invoke(this, "finalizeWrapper", [(cR + 1)], nil) | |
946 | 942 | if ((cU == cU)) | |
947 | 943 | then $Tuple2(nil, unit) | |
948 | 944 | else throw("Strict value is not equal to itself.") | |
949 | 945 | } | |
950 | 946 | else $Tuple2(nil, unit) | |
951 | 947 | } | |
952 | 948 | else throw("Strict value is not equal to itself.") | |
953 | 949 | } | |
954 | 950 | ||
955 | 951 | ||
956 | 952 | ||
957 | - | @Callable( | |
953 | + | @Callable(br) | |
958 | 954 | func finalize () = { | |
959 | 955 | let cU = invoke(this, "finalizeWrapper", [0], nil) | |
960 | 956 | if ((cU == cU)) | |
961 | 957 | then $Tuple2(nil, unit) | |
962 | 958 | else throw("Strict value is not equal to itself.") | |
963 | 959 | } | |
964 | 960 | ||
965 | 961 | ||
966 | 962 | ||
967 | - | @Callable( | |
968 | - | func containsNodeREADONLY ( | |
963 | + | @Callable(br) | |
964 | + | func containsNodeREADONLY (aW,ba) = $Tuple2(nil, bc(aW, ba)) | |
969 | 965 | ||
970 | 966 | ||
971 | 967 | ||
972 | - | @Callable( | |
973 | - | func insertNode ( | |
974 | - | let | |
975 | - | if (( | |
976 | - | then $Tuple2( | |
968 | + | @Callable(br) | |
969 | + | func insertNode (aW,ba) = { | |
970 | + | let bX = bt(br) | |
971 | + | if ((bX == bX)) | |
972 | + | then $Tuple2(bg(aW, ba), unit) | |
977 | 973 | else throw("Strict value is not equal to itself.") | |
978 | 974 | } | |
979 | 975 | ||
980 | 976 | ||
981 | 977 | ||
982 | - | @Callable( | |
983 | - | func deleteNode ( | |
984 | - | let | |
985 | - | if (( | |
986 | - | then $Tuple2( | |
978 | + | @Callable(br) | |
979 | + | func deleteNode (aW,ba) = { | |
980 | + | let bX = bt(br) | |
981 | + | if ((bX == bX)) | |
982 | + | then $Tuple2(bj(aW, ba), unit) | |
987 | 983 | else throw("Strict value is not equal to itself.") | |
988 | 984 | } | |
989 | 985 | ||
990 | 986 | ||
991 | 987 | ||
992 | - | @Callable( | |
988 | + | @Callable(br) | |
993 | 989 | func isFinalizationInProgress () = { | |
994 | - | let | |
995 | - | let cW = ( | |
990 | + | let bJ = getInteger(this, y) | |
991 | + | let cW = (bJ != unit) | |
996 | 992 | $Tuple2(nil, cW) | |
997 | 993 | } | |
998 | 994 | ||
999 | 995 | ||
1000 | 996 | ||
1001 | - | @Callable( | |
1002 | - | func deletePool ( | |
1003 | - | let | |
997 | + | @Callable(br) | |
998 | + | func deletePool (M,N) = { | |
999 | + | let bX = if (if ((br.caller == ar)) | |
1004 | 1000 | then true | |
1005 | - | else br | |
1001 | + | else bt(br)) | |
1006 | 1002 | then true | |
1007 | - | else | |
1008 | - | if (( | |
1003 | + | else ad("Permission denied") | |
1004 | + | if ((bX == bX)) | |
1009 | 1005 | then { | |
1010 | - | let | |
1011 | - | let | |
1012 | - | let | |
1013 | - | let | |
1014 | - | then | |
1006 | + | let aW = "pools" | |
1007 | + | let K = $Tuple2(M, N) | |
1008 | + | let ba = makeString([M, N], a) | |
1009 | + | let cb = if (bc(aW, ba)) | |
1010 | + | then bj(aW, ba) | |
1015 | 1011 | else nil | |
1016 | - | ([DeleteEntry( | |
1012 | + | ([DeleteEntry(J(K))] ++ cb) | |
1017 | 1013 | } | |
1018 | 1014 | else throw("Strict value is not equal to itself.") | |
1019 | 1015 | } | |
1020 | 1016 | ||
1021 | 1017 | ||
1022 | 1018 | ||
1023 | - | @Callable( | |
1024 | - | func resume ( | |
1025 | - | let | |
1026 | - | let cY = valueOrErrorMessage( | |
1027 | - | let | |
1028 | - | let | |
1029 | - | let cZ = | |
1030 | - | let cy = addressFromStringValue(getStringValue(this, | |
1019 | + | @Callable(br) | |
1020 | + | func resume (M,N,cX) = { | |
1021 | + | let bJ = getInteger(this, y) | |
1022 | + | let cY = valueOrErrorMessage(aB(M, N), ab("invalid assets")) | |
1023 | + | let ce = cY._1 | |
1024 | + | let aN = cY._2 | |
1025 | + | let cZ = br.payments[0] | |
1026 | + | let cy = addressFromStringValue(getStringValue(this, x)) | |
1031 | 1027 | let da = "%s__config" | |
1032 | 1028 | let db = 1 | |
1033 | - | let | |
1034 | - | let dc = fromBase58String(split(getStringValue( | |
1029 | + | let bz = addressFromStringValue(al(this, v)) | |
1030 | + | let dc = fromBase58String(split(getStringValue(bz, da), a)[db]) | |
1035 | 1031 | let dd = { | |
1036 | - | let | |
1037 | - | if ($isInstanceOf( | |
1038 | - | then | |
1039 | - | else throw(($getType( | |
1032 | + | let am = invoke(cy, "isVerifiedREADONLY", [M], nil) | |
1033 | + | if ($isInstanceOf(am, "Boolean")) | |
1034 | + | then am | |
1035 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
1040 | 1036 | } | |
1041 | 1037 | let de = { | |
1042 | - | let | |
1043 | - | if ($isInstanceOf( | |
1044 | - | then | |
1045 | - | else throw(($getType( | |
1038 | + | let am = invoke(cy, "isVerifiedREADONLY", [N], nil) | |
1039 | + | if ($isInstanceOf(am, "Boolean")) | |
1040 | + | then am | |
1041 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
1046 | 1042 | } | |
1047 | - | let df = valueOrErrorMessage(getInteger(this, | |
1048 | - | let | |
1043 | + | let df = valueOrErrorMessage(getInteger(this, r), "invalid resumption fee") | |
1044 | + | let bC = [if ((bJ == unit)) | |
1049 | 1045 | then true | |
1050 | - | else | |
1046 | + | else ad("finalization is in progress"), if ((cZ.assetId == dc)) | |
1051 | 1047 | then true | |
1052 | - | else | |
1048 | + | else ad("invalid fee payment asset id"), if ((cZ.amount == df)) | |
1053 | 1049 | then true | |
1054 | - | else | |
1050 | + | else ad("invalid fee payment amount"), if (if (dd) | |
1055 | 1051 | then de | |
1056 | 1052 | else false) | |
1057 | 1053 | then true | |
1058 | - | else | |
1059 | - | if (( | |
1054 | + | else ad("both assets should be verified")] | |
1055 | + | if ((bC == bC)) | |
1060 | 1056 | then { | |
1061 | - | let dg = assetBalance(this, | |
1057 | + | let dg = assetBalance(this, aN) | |
1062 | 1058 | if ((dg == dg)) | |
1063 | 1059 | then { | |
1064 | 1060 | let dh = false | |
1065 | - | let di = if ((size( | |
1061 | + | let di = if ((size(br.payments) == 1)) | |
1066 | 1062 | then { | |
1067 | - | let | |
1068 | - | let | |
1069 | - | if ($isInstanceOf( | |
1070 | - | then | |
1071 | - | else throw(($getType( | |
1063 | + | let ca = { | |
1064 | + | let am = invoke(ar, "checkBalance", [aA(aN)], nil) | |
1065 | + | if ($isInstanceOf(am, "Boolean")) | |
1066 | + | then am | |
1067 | + | else throw(($getType(am) + " couldn't be cast to Boolean")) | |
1072 | 1068 | } | |
1073 | - | if ( | |
1069 | + | if (ca) | |
1074 | 1070 | then true | |
1075 | - | else | |
1071 | + | else ad("assets should be attached") | |
1076 | 1072 | } | |
1077 | - | else if ((size( | |
1073 | + | else if ((size(br.payments) == 2)) | |
1078 | 1074 | then { | |
1079 | - | let | |
1080 | - | let | |
1081 | - | let | |
1082 | - | let | |
1075 | + | let dj = valueOrErrorMessage(scriptHash(ce), ab("pool address is not scripted")) | |
1076 | + | let dk = fromBase64String(valueOrErrorMessage(getString(ar, G()), ab("allowed lp stable script hash is not set"))) | |
1077 | + | let dl = (dj == dk) | |
1078 | + | let dm = if (dl) | |
1083 | 1079 | then "putOneTknV2" | |
1084 | 1080 | else "putOneTkn" | |
1085 | - | invoke( | |
1081 | + | invoke(ce, dm, [cX, dh], [br.payments[1]]) | |
1086 | 1082 | } | |
1087 | - | else if ((size( | |
1088 | - | then invoke( | |
1089 | - | else | |
1083 | + | else if ((size(br.payments) == 3)) | |
1084 | + | then invoke(ce, "put", [cX, dh], [br.payments[1], br.payments[2]]) | |
1085 | + | else ad("invalid payments size") | |
1090 | 1086 | if ((di == di)) | |
1091 | 1087 | then { | |
1092 | - | let | |
1093 | - | if (( | |
1088 | + | let dn = assetBalance(this, aN) | |
1089 | + | if ((dn == dn)) | |
1094 | 1090 | then { | |
1095 | - | let | |
1096 | - | let | |
1097 | - | then [ScriptTransfer( | |
1091 | + | let do = (dn - dg) | |
1092 | + | let dp = if ((do > 0)) | |
1093 | + | then [ScriptTransfer(br.caller, do, aN)] | |
1098 | 1094 | else nil | |
1099 | - | let | |
1100 | - | if (( | |
1095 | + | let dq = invoke(ar, "setWxEmissionPoolLabel", [M, N], nil) | |
1096 | + | if ((dq == dq)) | |
1101 | 1097 | then { | |
1102 | - | let G = $Tuple2(I, J) | |
1103 | - | let bB = ([BooleanEntry(F(G), true)] ++ be(aQ, am(G))) | |
1104 | - | $Tuple2((bB ++ dq), unit) | |
1098 | + | let dr = { | |
1099 | + | let am = invoke(ar, "getPoolStatusREADONLY", [toString(ce)], nil) | |
1100 | + | if ($isInstanceOf(am, "Int")) | |
1101 | + | then am | |
1102 | + | else throw(($getType(am) + " couldn't be cast to Int")) | |
1103 | + | } | |
1104 | + | let cf = if ((dr == j)) | |
1105 | + | then invoke(ar, "managePool", [toString(ce), h], nil) | |
1106 | + | else unit | |
1107 | + | if ((cf == cf)) | |
1108 | + | then { | |
1109 | + | let K = $Tuple2(M, N) | |
1110 | + | let bD = ([BooleanEntry(J(K), true)] ++ bg(aS, ao(K))) | |
1111 | + | $Tuple2((bD ++ dp), unit) | |
1112 | + | } | |
1113 | + | else throw("Strict value is not equal to itself.") | |
1105 | 1114 | } | |
1106 | 1115 | else throw("Strict value is not equal to itself.") | |
1107 | 1116 | } | |
1108 | 1117 | else throw("Strict value is not equal to itself.") | |
1109 | 1118 | } | |
1110 | 1119 | else throw("Strict value is not equal to itself.") | |
1111 | 1120 | } | |
1112 | 1121 | else throw("Strict value is not equal to itself.") | |
1113 | 1122 | } | |
1114 | 1123 | else throw("Strict value is not equal to itself.") | |
1115 | 1124 | } | |
1116 | 1125 | ||
1117 | 1126 | ||
1118 | 1127 | @Verifier(ds) | |
1119 | 1128 | func dt () = { | |
1120 | 1129 | let du = { | |
1121 | - | let | |
1122 | - | if ($isInstanceOf( | |
1130 | + | let ai = bo() | |
1131 | + | if ($isInstanceOf(ai, "ByteVector")) | |
1123 | 1132 | then { | |
1124 | - | let | |
1125 | - | | |
1133 | + | let bs = ai | |
1134 | + | bs | |
1126 | 1135 | } | |
1127 | - | else if ($isInstanceOf( | |
1136 | + | else if ($isInstanceOf(ai, "Unit")) | |
1128 | 1137 | then ds.senderPublicKey | |
1129 | 1138 | else throw("Match error") | |
1130 | 1139 | } | |
1131 | 1140 | sigVerify(ds.bodyBytes, ds.proofs[0], du) | |
1132 | 1141 | } | |
1133 | 1142 |
github/deemru/w8io/6500d08 547.29 ms ◑