tx · 9eVb3p4s8WX1DWApeLM47hFinqjrMK2nfYEqDVNKrjEf 3Myn55vLkduxbX3ZXfiDCZhaQsLxYp1kmCy: -0.02600000 Waves 2023.08.10 10:57 [2704219] smart account 3Myn55vLkduxbX3ZXfiDCZhaQsLxYp1kmCy > SELF 0.00000000 Waves
{ "type": 13, "id": "9eVb3p4s8WX1DWApeLM47hFinqjrMK2nfYEqDVNKrjEf", "fee": 2600000, "feeAssetId": null, "timestamp": 1691654271673, "version": 2, "chainId": 84, "sender": "3Myn55vLkduxbX3ZXfiDCZhaQsLxYp1kmCy", "senderPublicKey": "9W33iCCNfmFxUbiC6XZcH5x7f6xfwC7Jb3BoExT5q2PV", "proofs": [ "2xGB3yc9o88y4XEW6XrHeiP5JgMj1Jp8NeRHJ47KomTPLepqEsb5sM93vsZZBYmLXrH4XbwJAzz9F1XNYwr1UPPa" ], "script": "base64:BgL9LQgCEggKBggIAQEBCBIFCgMBCAISAwoBARIECgIICBIECgIICBIECgIIARIDCgEIEgMKAQgSBAoCCAESAwoBCBIAEgASBQoDCAgEEgMKAQgSAwoBCBIECgIICBIECgIICCIDU0VQIgZTQ0FMRTgiBU1VTFQ4Ig5QT09MV0VJR0hUTVVMVCIQY29udHJhY3RGaWxlbmFtZSIHU0NBTEUxOCIGTVVMVDE4IghNVUxUMThCSSILYmxvY2tzSW5EYXkiDWJsb2Nrc0luTW9udGgiB3dyYXBFcnIiA21zZyIIdGhyb3dFcnIiD2dldFN0cmluZ09yRmFpbCIHYWRkcmVzcyIDa2V5IgxnZXRJbnRPclplcm8iD2dldEludE9yRGVmYXVsdCIKZGVmYXVsdFZhbCIMZ2V0SW50T3JGYWlsIgNhYnMiA3ZhbCIOZW5zdXJlUG9zaXRpdmUiAXYiAW0iG2tleVJlZmVycmFsc0NvbnRyYWN0QWRkcmVzcyIecmVmZXJyYWxzQ29udHJhY3RBZGRyZXNzT3JGYWlsIhZrZXlSZWZlcnJhbFByb2dyYW1OYW1lIhpyZWZlcnJhbFByb2dyYW1OYW1lRGVmYXVsdCITcmVmZXJyYWxQcm9ncmFtTmFtZSIRa2V5RmFjdG9yeUFkZHJlc3MiGElkeEZhY3RvcnlDZmdTdGFraW5nRGFwcCIZSWR4RmFjdG9yeUNmZ0Jvb3N0aW5nRGFwcCIUSWR4RmFjdG9yeUNmZ0lkb0RhcHAiFUlkeEZhY3RvcnlDZmdUZWFtRGFwcCIZSWR4RmFjdG9yeUNmZ0VtaXNzaW9uRGFwcCIVSWR4RmFjdG9yeUNmZ1Jlc3REYXBwIhlJZHhGYWN0b3J5Q2ZnU2xpcHBhZ2VEYXBwIhRJZHhGYWN0b3J5Q2ZnRGFvRGFwcCIaSWR4RmFjdG9yeUNmZ01hcmtldGluZ0RhcHAiGklkeEZhY3RvcnlDZmdHd3hSZXdhcmREYXBwIhZJZHhGYWN0b3J5Q2ZnQmlyZHNEYXBwIg1rZXlGYWN0b3J5Q2ZnIiZrZXlGYWN0b3J5THBBc3NldFRvUG9vbENvbnRyYWN0QWRkcmVzcyIKbHBBc3NldFN0ciIUa2V5RmFjdG9yeVBvb2xXZWlnaHQiD2NvbnRyYWN0QWRkcmVzcyIba2V5RmFjdG9yeVBvb2xXZWlnaHRIaXN0b3J5Igtwb29sQWRkcmVzcyIDbnVtIhhyZWFkRmFjdG9yeUFkZHJlc3NPckZhaWwiFHJlYWRGYWN0b3J5Q2ZnT3JGYWlsIgdmYWN0b3J5IhhnZXRCb29zdGluZ0FkZHJlc3NPckZhaWwiCmZhY3RvcnlDZmciGGdldEVtaXNzaW9uQWRkcmVzc09yRmFpbCIXZ2V0U3Rha2luZ0FkZHJlc3NPckZhaWwiGWdldEd3eFJld2FyZEFkZHJlc3NPckZhaWwiE2tleU1hbmFnZXJQdWJsaWNLZXkiFmtleU1hbmFnZXJWYXVsdEFkZHJlc3MiHmtleUVtaXNzaW9uUmF0ZVBlckJsb2NrQ3VycmVudCIha2V5RW1pc3Npb25SYXRlUGVyQmxvY2tNYXhDdXJyZW50IhVrZXlFbWlzc2lvblN0YXJ0QmxvY2siHWtleUJvb3N0aW5nVjJMYXN0VXBkYXRlSGVpZ2h0IhVrZXlCb29zdGluZ1YySW50ZWdyYWwiG2tleUVtaXNzaW9uRHVyYXRpb25JbkJsb2NrcyITa2V5RW1pc3Npb25FbmRCbG9jayIZa2V5TmV4dFBlcmdldEludE9yRGVmYXVsdCIfa2V5R3d4UmV3YXJkRW1pc3Npb25TdGFydEhlaWdodCINSWR4Q2ZnQXNzZXRJZCITSWR4Q2ZnTWluTG9ja0Ftb3VudCIVSWR4Q2ZnTWluTG9ja0R1cmF0aW9uIhVJZHhDZmdNYXhMb2NrRHVyYXRpb24iEklkeENmZ01hdGhDb250cmFjdCIUSWR4Q2ZnQmxvY2tzSW5QZXJpb2QiCWtleUNvbmZpZyIVcmVhZENvbmZpZ0FycmF5T3JGYWlsIghjZmdBcnJheSIHYXNzZXRJZCINbWluTG9ja0Ftb3VudCIPbWluTG9ja0R1cmF0aW9uIg9tYXhMb2NrRHVyYXRpb24iDG1hdGhDb250cmFjdCIOYmxvY2tzSW5QZXJpb2QiDWZvcm1hdENvbmZpZ1MiDGZvcm1hdENvbmZpZyIcZ2V0TWFuYWdlclZhdWx0QWRkcmVzc09yVGhpcyIHJG1hdGNoMCIBcyIWbWFuYWdlclB1YmxpY0tleU9yVW5pdCITbWFuYWdlclZhdWx0QWRkcmVzcyILbXVzdE1hbmFnZXIiAWkiAnBkIgJwayINSWR4TG9ja0Ftb3VudCIMSWR4TG9ja1N0YXJ0Ig9JZHhMb2NrRHVyYXRpb24iGklkeExvY2tMYXN0VXBkYXRlVGltZXN0YW1wIhBJZHhMb2NrR3d4QW1vdW50IhBJZHhMb2NrV3hDbGFpbWVkIhNrZXlMb2NrUGFyYW1zUmVjb3JkIgt1c2VyQWRkcmVzcyIEdHhJZCIBYiIacmVhZExvY2tQYXJhbXNSZWNvcmRPckZhaWwiFWtleVVzZXJHd3hBbW91bnRUb3RhbCIWZm9ybWF0TG9ja1BhcmFtc1JlY29yZCIGYW1vdW50IgVzdGFydCIIZHVyYXRpb24iCWd3eEFtb3VudCIJd3hDbGFpbWVkIg5rZXlOZXh0VXNlck51bSISa2V5VXNlcjJOdW1NYXBwaW5nIhJrZXlOdW0yVXNlck1hcHBpbmciF2tleUxvY2tQYXJhbVRvdGFsQW1vdW50IiBrZXlTdGF0c0xvY2tzRHVyYXRpb25TdW1JbkJsb2NrcyISa2V5U3RhdHNMb2Nrc0NvdW50IhJrZXlTdGF0c1VzZXJzQ291bnQiIGtleVVzZXJCb29zdEVtaXNzaW9uTGFzdElOVEVHUkFMIgd1c2VyTnVtIiJrZXlVc2VyTHBCb29zdEVtaXNzaW9uTGFzdElOVEVHUkFMIglscEFzc2V0SWQiF2tleVVzZXJNYXhCb29zdElOVEVHUkFMIhhrZXlUb3RhbE1heEJvb3N0SU5URUdSQUwiIWtleVVzZXJCb29zdEF2YWxhaWJsZVRvQ2xhaW1Ub3RhbCITa2V5VXNlckJvb3N0Q2xhaW1lZCILa2V5R3d4VG90YWwiB2tleVZvdGUiDWFtb3VudEFzc2V0SWQiDHByaWNlQXNzZXRJZCIFZXBvY2giFWtleVN0YXJ0SGVpZ2h0QnlFcG9jaCIRa2V5Q3VycmVudEVwb2NoVWkiFWtleVZvdGluZ1Jlc3VsdFN0YWtlZCIMbHBBc3NldElkU3RyIh1rZXlWb3RpbmdSZXN1bHRTdGFrZWRJbnRlZ3JhbCIla2V5Vm90aW5nUmVzdWx0U3Rha2VkTGFzdFVwZGF0ZUhlaWdodCIha2V5Vm90aW5nUmVzdWx0U3Rha2VkSW50ZWdyYWxMYXN0IhVrZXlWb3RlU3Rha2VkSW50ZWdyYWwiHWtleVZvdGVTdGFrZWRMYXN0VXBkYXRlSGVpZ2h0IhlrZXlWb3RlU3Rha2VkSW50ZWdyYWxMYXN0Ig9rZXlTdGFrZWRCeVVzZXIiDnVzZXJBZGRyZXNzU3RyIg9mYWN0b3J5Q29udHJhY3QiEGVtaXNzaW9uQ29udHJhY3QiD3N0YWtpbmdDb250cmFjdCIRZ3d4UmV3YXJkQ29udHJhY3QiFmxwU3Rha2luZ1Bvb2xzQ29udHJhY3QiGWtleVZvdGluZ0VtaXNzaW9uQ29udHJhY3QiFnZvdGluZ0VtaXNzaW9uQ29udHJhY3QiHWtleVZvdGluZ0VtaXNzaW9uUmF0ZUNvbnRyYWN0Igpib29zdENvZWZmIgFAIhl1c2VyTnVtYmVyQnlBZGRyZXNzT3JGYWlsIhFnZXRHd3hBbW91bnRUb3RhbCISZ2V0TG9ja2VkR3d4QW1vdW50IgxmdW5jdGlvbk5hbWUiGnZvdGluZ0VtaXNzaW9uUmF0ZUNvbnRyYWN0Ihhsb2NrZWRWb3RpbmdFbWlzc2lvblJhdGUiFGxvY2tlZFZvdGluZ0VtaXNzaW9uIgZsb2NrZWQiDEhpc3RvcnlFbnRyeSIEdHlwZSIEdXNlciIJbG9ja1N0YXJ0IgpoaXN0b3J5S0VZIgtoaXN0b3J5REFUQSIKU3RhdHNFbnRyeSIOdG90YWxMb2NrZWRJbmMiC2R1cmF0aW9uSW5jIgxsb2NrQ291bnRJbmMiDXVzZXJzQ291bnRJbmMiG2xvY2tzRHVyYXRpb25TdW1JbkJsb2Nrc0tFWSINbG9ja3NDb3VudEtFWSINdXNlcnNDb3VudEtFWSIOdG90YWxBbW91bnRLRVkiGGxvY2tzRHVyYXRpb25TdW1JbkJsb2NrcyIKbG9ja3NDb3VudCIKdXNlcnNDb3VudCILdG90YWxBbW91bnQiD0xvY2tQYXJhbXNFbnRyeSIiZXh0cmFjdE9wdGlvbmFsUGF5bWVudEFtb3VudE9yRmFpbCIPZXhwZWN0ZWRBc3NldElkIgNwbXQiFWdldFVzZXJHd3hBbW91bnRUb3RhbCIaZ2V0Vm90aW5nRW1pc3Npb25FcG9jaEluZm8iDSR0MDE1MTY0MTU0NTQiDmN1cnJlbnRFcG9jaFVpIhJsYXN0RmluYWxpemVkRXBvY2giF2N1cnJlbnRFcG9jaFN0YXJ0SGVpZ2h0IhhnZXRQb29sQXNzZXRzQnlMcEFzc2V0SWQiEGlkeEFtb3VudEFzc2V0SWQiD2lkeFByaWNlQXNzZXRJZCIHcG9vbENmZyIUZ2V0VXNlclZvdGVGaW5hbGl6ZWQiDSR0MDE2MTQ1MTYyMjUiDSR0MDE2MjI4MTYzMDMiC3VzZXJWb3RlS2V5Igh1c2VyVm90ZSIRZ2V0VXNlclZvdGVTdGFrZWQiDHN0YWtlZEJ5VXNlciIVZ2V0Vm90aW5nUmVzdWx0U3Rha2VkIg0kdDAxNjg0NzE2OTI3Ihd2b3RpbmdSZXN1bHRTdGFrZWRTdGFydCISdm90aW5nUmVzdWx0U3Rha2VkIh1nZXRWb3RpbmdSZXN1bHRTdGFrZWRJbnRlZ3JhbCINJHQwMTcyODkxNzM2OSIedm90aW5nUmVzdWx0U3Rha2VkSW50ZWdyYWxQcmV2IiJ2b3RpbmdSZXN1bHRTdGFrZWRMYXN0VXBkYXRlSGVpZ2h0Ihx2b3RpbmdSZXN1bHRTdGFrZWRJbnRlZ3JhbERoIhp2b3RpbmdSZXN1bHRTdGFrZWRJbnRlZ3JhbCIhcmVmcmVzaFZvdGluZ1Jlc3VsdFN0YWtlZEludGVncmFsIg9zdGFrZWRWb3RlRGVsdGEiDSR0MDE4MjA2MTgyODYiFXZvdGluZ1Jlc3VsdFN0YWtlZE5ldyIZZ2V0VXNlclZvdGVTdGFrZWRJbnRlZ3JhbCINJHQwMTg4OTcxODk3NyIOdXNlclZvdGVTdGFrZWQiGnVzZXJWb3RlU3Rha2VkSW50ZWdyYWxQcmV2Ih51c2VyVm90ZVN0YWtlZExhc3RVcGRhdGVIZWlnaHQiGHVzZXJWb3RlU3Rha2VkSW50ZWdyYWxEaCIWdXNlclZvdGVTdGFrZWRJbnRlZ3JhbCIZcmVmcmVzaFZvdGVTdGFrZWRJbnRlZ3JhbCIEZWRnZSINJHQwMTk3NjUxOTg0NSIRdXNlclZvdGVGaW5hbGl6ZWQiB2FjdGlvbnMiE3ZvdGluZ1Jlc3VsdEFjdGlvbnMiC3ZvdGVBY3Rpb25zIhtnZXRTdGFrZWRWb3Rlc0ludGVncmFsc0RpZmYiDSR0MDIwNjk5MjA3NzkiHXVzZXJWb3RlU3Rha2VkSW50ZWdyYWxMYXN0S2V5Ihp1c2VyVm90ZVN0YWtlZEludGVncmFsTGFzdCIhdm90aW5nUmVzdWx0U3Rha2VkSW50ZWdyYWxMYXN0S2V5Ih52b3RpbmdSZXN1bHRTdGFrZWRJbnRlZ3JhbExhc3QiGnVzZXJWb3RlU3Rha2VkSW50ZWdyYWxEaWZmIh52b3RpbmdSZXN1bHRTdGFrZWRJbnRlZ3JhbERpZmYiHHJlZnJlc2hCb29zdEVtaXNzaW9uSW50ZWdyYWwiEnd4RW1pc3Npb25QZXJCbG9jayIgYm9vc3RpbmdWMkxhc3RVcGRhdGVIZWlnaHRPcHRpb24iGGJvb3N0aW5nVjJJbmdlcmdhbE9wdGlvbiILZW1pc3Npb25FbmQiAWgiAmRoIhBsYXN0VXBkYXRlSGVpZ2h0IhVib29zdEVtaXNzaW9uUGVyQmxvY2siGWJvb3N0RW1pc3Npb25JbnRlZ3JhbFByZXYiFWJvb3N0RW1pc3Npb25JbnRlZ3JhbCIUaW50ZXJuYWxDbGFpbVd4Qm9vc3QiCHJlYWRPbmx5IghFTVBUWVNUUiIKcG9vbFdlaWdodCIOcG9vbEFkZHJlc3NTdHIiInVzZXJMcEJvb3N0RW1pc3Npb25MYXN0SW50ZWdyYWxLRVkiIHVzZXJCb29zdEVtaXNzaW9uTGFzdEludGVncmFsS0VZIh11c2VyQm9vc3RFbWlzc2lvbkxhc3RJbnRlZ3JhbCIZdXNlckJvb3N0RW1pc3Npb25JbnRlZ3JhbCINJHQwMjQzMjEyNDQ2MCIbc3Rha2VkVm90ZXNJbnRlZ3JhbHNBY3Rpb25zIhR1c2VyVm90ZUludGVncmFsRGlmZiIWdG90YWxWb3Rlc0ludGVncmFsRGlmZiIdcG9vbFVzZXJCb29zdEVtaXNzaW9uSW50ZWdyYWwiIXVzZXJCb29zdEF2YWxpYWJsZVRvQ2xhaW1Ub3RhbE5ldyIJZGF0YVN0YXRlIgVkZWJ1ZyILbG9ja0FjdGlvbnMiDmR1cmF0aW9uTW9udGhzIhVkdXJhdGlvbk1vbnRoc0FsbG93ZWQiCmFzc2V0SWRTdHIiCXBtdEFtb3VudCIObmV4dFVzZXJOdW1LRVkiDnVzZXJJc0V4aXN0aW5nIgp1c2VyTnVtU3RyIgdjb2VmZlg4Ig5nV3hBbW91bnRTdGFydCIOZ3d4QW1vdW50VG90YWwiEnVzZXJHd3hBbW91bnRUb3RhbCIMZ3d4UmV3YXJkSW52IgNhcnIiEWdldFd4V2l0aGRyYXdhYmxlIgp0eElkT3B0aW9uIg91c2VyUmVjb3JkQXJyYXkiCnVzZXJBbW91bnQiDGxvY2tEdXJhdGlvbiIHbG9ja0VuZCIBdCIIZXhwb25lbnQiDnd4V2l0aGRyYXdhYmxlIhFmYWN0b3J5QWRkcmVzc1N0ciIObG9ja0Fzc2V0SWRTdHIiC21pbkR1cmF0aW9uIgttYXhEdXJhdGlvbiILY2hlY2tDYWxsZXIiD3JlZmVycmVyQWRkcmVzcyIJc2lnbmF0dXJlIg0kdDAyOTQyNzI5NDkyIhFsb2NrQWN0aW9uc1Jlc3VsdCIPcmVmZXJyYWxBZGRyZXNzIgZyZWZJbnYiEXVwZGF0ZVJlZkFjdGl2aXR5Ig0kdDAyOTk1MDMwMDE1Ig0kdDAzMDMyNTMwNDI3IhJ1c2VyQm9vc3RBdmFpbGFibGUiDSR0MDMwNTU5MzA2NjAiB3R4SWRTdHIiCWd3eEJ1cm5lZCIMZ3d4UmVtYWluaW5nIg9sb2NrZWRHd3hBbW91bnQiDHRhcmdldEhlaWdodCICdHgiBnZlcmlmeSIPdGFyZ2V0UHVibGljS2V5jwEAAWECAl9fAAFiAAgAAWMAgMLXLwABZAUBYwABZQINYm9vc3RpbmcucmlkZQABZgASAAFnAICAkLu61q3wDQABaAkAtgIBBQFnAAFpAKALAAFqAJjWAgEBawEBbAkAuQkCCQDMCAIFAWUJAMwIAgICOiAJAMwIAgUBbAUDbmlsAgABAW0BAWwJAAIBCQEBawEFAWwBAW4CAW8BcAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFAW8FAXAJAQFrAQkArAICCQCsAgICD21hbmRhdG9yeSB0aGlzLgUBcAIPIGlzIG5vdCBkZWZpbmVkAQFxAgFvAXAJAQt2YWx1ZU9yRWxzZQIJAJoIAgUBbwUBcAAAAQFyAwFvAXABcwkBC3ZhbHVlT3JFbHNlAgkAmggCBQFvBQFwBQFzAQF0AgFvAXAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQFvBQFwCQEBawEJAKwCAgkArAICAg9tYW5kYXRvcnkgdGhpcy4FAXACDyBpcyBub3QgZGVmaW5l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ZXNzYWdlAgkAoggBCQC5CQIJAMwIAgICJXMJAMwIAgIWbHBTdGFraW5nUG9vbHNDb250cmFjdAUDbmlsBQFhCQEBawECLmxwX3N0YWtpbmdfcG9vbHMgY29udHJhY3QgYWRkcmVzcyBpcyB1bmRlZmluZWQJAQFrAQIpaW52YWxpZCBscF9zdGFraW5nX3Bvb2xzIGNvbnRyYWN0IGFkZHJlc3MAAmJVCQC5CQIJAMwIAgICJXMJAMwIAgIWdm90aW5nRW1pc3Npb25Db250cmFjdAUDbmlsBQFhAAJiVgkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUCYlAFAmJVAAJiVwkAuQkCCQDMCAICAiVzCQDMCAICGnZvdGluZ0VtaXNzaW9uUmF0ZUNvbnRyYWN0BQNuaWwFAWEAAmJYCgACYlkJAPwHBAUCYlECFWdldEJvb3N0Q29lZmZSRUFET05MWQUDbmlsBQNuaWwDCQABAgUCYlkCA0ludAUCYlkJAAIBCQCsAgIJAAMBBQJiWQIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50AQJiWgECYVkEAmFKCQCdCAIFBHRoaXMJAQJiawEJAKUIAQUCYVkDCQABAgUCYUoCBlN0cmluZwQCYUsFAmFKCQETdmFsdWVPckVycm9yTWVzc2FnZQIJALYJAQUCYUsJAQFrAQITaW52YWxpZCB1c2VyIG51bWJlcgMJAAECBQJhSgIEVW5pdAkBAW0BAgxpbnZhbGlkIHVzZXIJAAIBAgtNYXRjaCBlcnJvcgECY2EACQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQJieQAAAAECY2IBAmFZBAJjYwISZ2V0TG9ja2VkR3d4QW1vdW50BAJjZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCBAJhSgkAnQgCBQJiVgUCYlcDCQABAgUCYUoCBFVuaXQFBHVuaXQDCQABAgUCYUoCBlN0cmluZwQCYUsFAmFKCQCmCAEFAmFLCQACAQILTWF0Y2ggZXJyb3IJAQFrAQIkaW52YWxpZCB2b3RpbmcgZW1pc3Npb24gcmF0ZSBhZGRyZXNzBAJjZQoAAmJZCQD8BwQFAmJWBQJjYwkAzAgCCQClCAEFAmFZBQNuaWwFA25pbAMJAAECBQJiWQIDSW50BQJiWQkAAgEJAKwCAgkAAwEFAmJZAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQEAmNmCgACYlkJAPwHBAUCY2QFAmNjCQDMCAIJAKUIAQUCYVkFA25pbAUDbmlsAwkAAQIFAmJZAgNJbnQFAmJZCQACAQkArAICCQADAQUCYlkCGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAQCY2cJAJYDAQkAzAgCBQJjZQkAzAgCBQJjZgUDbmlsBQJjZwECY2gHAmNpAmNqAmJlAmNrAmJnAmJoAmFPBAJjbAkAuQkCCQDMCAICESVzJXMlcyVzX19oaXN0b3J5CQDMCAIFAmNpCQDMCAIFAmNqCQDMCAIJANgEAQgFAmFPDXRyYW5zYWN0aW9uSWQFA25pbAUBYQQCY20JALkJAgkAzAgCAg4lZCVkJWQlZCVkJWQlZAkAzAgCCQCkAwEIBQlsYXN0QmxvY2sGaGVpZ2h0CQDMCAIJAKQDAQgFCWxhc3RCbG9jawl0aW1lc3RhbXAJAMwIAgkApAMBBQJiZQkAzAgCCQCkAwEFAmNrCQDMCAIJAKQDAQUCYmcJAMwIAgkApAMBBQJiaAUDbmlsBQFhCQELU3RyaW5nRW50cnkCBQJjbAUCY20BAmNuBAJjbwJjcAJjcQJjcgQCY3MJAQJibgAEAmN0CQECYm8ABAJjdQkBAmJwAAQCY3YJAQJibQAEAmN3CQEBcQIFBHRoaXMFAmNzBAJjeAkBAXECBQR0aGlzBQJjdAQCY3kJAQFxAgUEdGhpcwUCY3UEAmN6CQEBcQIFBHRoaXMFAmN2CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQJjcwkAZAIFAmN3BQJjcAkAzAgCCQEMSW50ZWdlckVudHJ5AgUCY3QJAGQCBQJjeAUCY3EJAMwIAgkBDEludGVnZXJFbnRyeQIFAmN1CQBkAgUCY3kFAmNyCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQJjdgkAZAIFAmN6BQJjbwUDbmlsAQJjQQcCYVkCYVoCYmUCYmYCYmcCYmgCYmkJAMwIAgkBC1N0cmluZ0VudHJ5AgkBAmFYAgUCYVkFAmFaCQECYmQFBQJiZQUCYmYFAmJnBQJiaAUCYmkFA25pbAECY0ICAmFPAmNDAwkAZgIJAJADAQgFAmFPCHBheW1lbnRzAAEJAQFtAQIbb25seSBvbmUgcGF5bWVudCBpcyBhbGxvd2VkAwkAAAIJAJADAQgFAmFPCHBheW1lbnRzAAAAAAQCY0QJAJEDAggFAmFPCHBheW1lbnRzAAADCQECIT0CCQEFdmFsdWUBCAUCY0QHYXNzZXRJZAUCY0MJAQFtAQIbaW52YWxpZCBhc3NldCBpZCBpbiBwYXltZW50CAUCY0QGYW1vdW50AQJjRQECYVkJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBAmJjAQUCYVkAAAECY0YABAJjRwQCY0gJAQV2YWx1ZQEJAJoIAgUCYlYJAQJiRQAEAmNJCQBlAgUCY0gAAQMJAGYCAAAFAmNJCQEBbQECDWludmFsaWQgZXBvY2gJAJQKAgUCY0gFAmNJBAJjSAgFAmNHAl8xBAJjSQgFAmNHAl8yBAJjSgkBBXZhbHVlAQkAmggCBQJiVgkBAmJEAQUCY0gJAJQKAgUCY0kFAmNKAQJjSwECYkcEAmNMAAQEAmNNAAUEAmNOCgACYlkJAPwHBAUCYlACIGdldFBvb2xDb25maWdCeUxwQXNzZXRJZFJFQURPTkxZCQDMCAIFAmJHBQNuaWwFA25pbAMJAAECBQJiWQIJTGlzdFtBbnldBQJiWQkAAgEJAKwCAgkAAwEFAmJZAh4gY291bGRuJ3QgYmUgY2FzdCB0byBMaXN0W0FueV0EAmJBCgACYlkJAJEDAgUCY04FAmNMAwkAAQIFAmJZAgZTdHJpbmcFAmJZCQACAQkArAICCQADAQUCYlkCGyBjb3VsZG4ndCBiZSBjYXN0IHRvIFN0cmluZwQCYkIKAAJiWQkAkQMCBQJjTgUCY00DCQABAgUCYlkCBlN0cmluZwUCYlkJAAIBCQCsAgIJAAMBBQJiWQIbIGNvdWxkbid0IGJlIGNhc3QgdG8gU3RyaW5nCQCUCgIFAmJBBQJiQgECY08CAmJHAmJPBAJhWQkBEUBleHRyTmF0aXZlKDEwNjIpAQUCYk8EAmNQCQECY0YABAJjSQgFAmNQAl8xBAJjSggFAmNQAl8yBAJjUQkBAmNLAQUCYkcEAmJBCAUCY1ECXzEEAmJCCAUCY1ECXzIEAmNSCQECYnoEBQJiQQUCYkIFAmFZBQJjSQQCY1MJAQt2YWx1ZU9yRWxzZQIJAJoIAgUCYlYFAmNSAAAFAmNTAQJjVAICYkcCYk8EAmNVCQELdmFsdWVPckVsc2UCCQCaCAIFAmJSCQECYk4CBQJiTwUCYkcAAAQCY1MJAQJjTwIFAmJHBQJiTwMJAAACBQJjVQAAAAAFAmNTAQJjVgECYkcEAmNXCQECY0YABAJjSQgFAmNXAl8xBAJjSggFAmNXAl8yBAJjWAkBC3ZhbHVlT3JFbHNlAgkAmggCBQJiVgkBAmJGAgUCYkcFAmNJAAAEAmNZCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQJiRgIFAmJHBQJjSQUCY1gFAmNZAQJjWgECYkcEAmRhCQECY0YABAJjSQgFAmRhAl8xBAJjSggFAmRhAl8yBAJjWQkBAmNWAQUCYkcEAmRiCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQJiSAIFAmJHBQJjSQAABAJkYwkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQECYkkCBQJiRwUCY0kFAmNKBAJkZAkAZQIFBmhlaWdodAUCZGMEAmRlCQBkAgkAaAIFAmRkBQJjWQUCZGIFAmRlAQJkZgICYkcCZGcEAmRoCQECY0YABAJjSQgFAmRoAl8xBAJjSggFAmRoAl8yBAJjWQkBAmNWAQUCYkcEAmRpCQBkAgUCY1kFAmRnBAJkZQkBAmNaAQUCYkcJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJiRgIFAmJHBQJjSQUCZGkJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJiSQIFAmJHBQJjSQUGaGVpZ2h0CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYkgCBQJiRwUCY0kFAmRlBQNuaWwBAmRqAgJiRwJiTwQCZGsJAQJjRgAEAmNJCAUCZGsCXzEEAmNKCAUCZGsCXzIEAmFZCQERQGV4dHJOYXRpdmUoMTA2MikBBQJiTwQCZGwJAQJjVAIFAmJHBQJiTwQCZG0JAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBAmJLAwUCYkcFAmFZBQJjSQAABAJkbgkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQECYkwDBQJiRwUCYVkFAmNJBQJjSgQCZG8JAGUCBQZoZWlnaHQFAmRuBAJkcAkAZAIJAGgCBQJkbwUCZGwFAmRtBQJkcAECZHEDAmJHAmJPAmRyBAJkcwkBAmNGAAQCY0kIBQJkcwJfMQQCY0oIBQJkcwJfMgQCYVkJARFAZXh0ck5hdGl2ZSgxMDYyKQEFAmJPBAJkdAkBAmNPAgUCYkcFAmJPBAJkdQMJAAACBQJkdAAABQNuaWwEAmRnAwUCZHIFAmR0CQEBLQEFAmR0BAJkdgkBAmRmAgUCYkcFAmRnBAJkcAkBAmRqAgUCYkcFAmJPBAJkdwkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAmJMAwUCYkcFAmFZBQJjSQUGaGVpZ2h0CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYksDBQJiRwUCYVkFAmNJBQJkcAUDbmlsCQDOCAIFAmR2BQJkdwUCZHUBAmR4AgJiRwJiTwQCZHkJAQJjRgAEAmNJCAUCZHkCXzEEAmNKCAUCZHkCXzIEAmFZCQERQGV4dHJOYXRpdmUoMTA2MikBBQJiTwQCZHoJAQJiTQMFAmJHBQJhWQUCY0kEAmRBCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFAmR6AAAEAmRCCQECYkoDBQJiRwUCYVkFAmNJBAJkQwkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQJkQgAABAJkcAkBAmRqAgUCYkcFAmJPBAJkZQkBAmNaAQUCYkcEAmRECQBlAgUCZHAFAmRBBAJkRQkAZQIFAmRlBQJkQwkAlQoDCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQJkegUCZHAJAMwIAgkBDEludGVnZXJFbnRyeQIFAmRCBQJkZQUDbmlsBQJkRAUCZEUBAmRGAAQCZEcJAQF0AgUCYlEJAQJhaQAEAmRICQCaCAIFBHRoaXMJAQJhbAAEAmRJCQCaCAIFBHRoaXMJAQJhbQAEAmRKCQEBdAIFAmJRCQECYW8ABAJkSwMJAGYCBQZoZWlnaHQFAmRKBQJkSgUGaGVpZ2h0BAJkTAQCYUoFAmRIAwkAAQIFAmFKAgNJbnQEAmRNBQJhSgkAlgMBCQDMCAIJAGUCBQJkSwUCZE0JAMwIAgAABQNuaWwDCQABAgUCYUoCBFVuaXQAAAkAAgECC01hdGNoIGVycm9yBAJkTgkAaQIJAGgCBQJkRwkAZQIFAmJYAAEFAmJYBAJkTwkBC3ZhbHVlT3JFbHNlAgUCZEkAAAQCZFAJAGQCCQBoAgUCZE4FAmRMBQJkTwkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYW0ABQJkUAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAmFsAAUGaGVpZ2h0BQNuaWwFAmRQAQJkUQMCYkcCYk8CZFIEAmFZCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQUCYk8JAQFrAQIUaW52YWxpZCB1c2VyIGFkZHJlc3MEAmJyCQECYloBBQJhWQMJAAACBQJicgUCYnIEAmRTAgVlbXB0eQQCZFQDCQECIT0CBQJiRwUCZFMEAmRVCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUCYlAJAQFSAQUCYkcJAQFrAQkArAICAhV1bnN1cHBvcnRlZCBscCBhc3NldCAFAmJHCQERQGV4dHJOYXRpdmUoMTA1MCkCBQJiUAkBAVQBBQJkVQMFAmRSAAAJAQFtAQkArAICAihub3QgcmVhZG9ubHkgbW9kZTogdW5zdXBwb3J0ZWQgbHAgYXNzZXQgBQJiRwQCZFYJAQJicwIFAmJyBQJiRwQCZFcJAQJicQEFAmJyBAJkWAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQJkVgkBAXECBQR0aGlzBQJkVwQCZFAICQECZEYAAl8yBAJkWQkAZQIFAmRQBQJkWAMJAGYCAAAFAmRZCQEBbQECEndyb25nIGNhbGN1bGF0aW9ucwQCZFoJAQJkeAIFAmJHBQJiTwQCZWEIBQJkWgJfMQQCZWIIBQJkWgJfMgQCZWMIBQJkWgJfMwQCZWQJAGsDBQJkWQUCZFQFAWQEAmVlAwkAAAIFAmVjAAAAAAkAawMFAmVkBQJlYgUCZWMEAmVmCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIFAmRWBQJkUAUDbmlsBQJlYQQCZWcJALkJAgkAzAgCCQCkAwEFAmRYCQDMCAIJAKQDAQUCZFkJAMwIAgkApAMBBQJkVAkAzAgCCQCkAwEFAmViCQDMCAIJAKQDAQUCZWMFA25pbAIBOgkAlQoDBQJlZQUCZWYFAmVnCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJlaAICYU8CZWkEAmVqCQDMCAIAAQkAzAgCAAMJAMwIAgAGCQDMCAIADAkAzAgCABgJAMwIAgAwBQNuaWwDCQEBIQEJAQ9jb250YWluc0VsZW1lbnQCBQJlagUCZWkJAQFtAQIQaW52YWxpZCBkdXJhdGlvbgQCYmcJAGgCBQJlaQUBagQCZWsJANgEAQUCYUEDCQECIT0CCQCQAwEIBQJhTwhwYXltZW50cwABCQEBbQECNGludmFsaWQgcGF5bWVudCAtIGV4YWN0IG9uZSBwYXltZW50IG11c3QgYmUgYXR0YWNoZWQEAmNECQCRAwIIBQJhTwhwYXltZW50cwAABAJlbAgFAmNEBmFtb3VudAMJAQIhPQIFAmFBCQEFdmFsdWUBCAUCY0QHYXNzZXRJZAkBAW0BCQCsAgIJAKwCAgIeaW52YWxpZCBhc3NldCBpcyBpbiBwYXltZW50IC0gBQJlawIMIGlzIGV4cGVjdGVkBAJlbQkBAmJqAAQCYVkIBQJhTwZjYWxsZXIEAmJPCQClCAEFAmFZBAJlbgkBCWlzRGVmaW5lZAEJAKIIAQkBAmJrAQUCYk8EAmVvAwUCZW4JAQV2YWx1ZQEJAKIIAQkBAmJrAQUCYk8JAKQDAQkBAXQCBQR0aGlzBQJlbQQCYnIJAQ1wYXJzZUludFZhbHVlAQUCZW8EAmNrBQZoZWlnaHQDAwkAZgIFAmFCBQJlbAkBAiE9AgUCYVkFAmJUBwkBAW0BCQCsAgICImFtb3VudCBpcyBsZXNzIHRoZW4gbWluTG9ja0Ftb3VudD0JAKQDAQUCYUIDCQBmAgUCYUMFAmJnCQEBbQEJAKwCAgItcGFzc2VkIGR1cmF0aW9uIGlzIGxlc3MgdGhlbiBtaW5Mb2NrRHVyYXRpb249CQCkAwEFAmFDAwkAZgIFAmJnBQJhRAkBAW0BCQCsAgICMHBhc3NlZCBkdXJhdGlvbiBpcyBncmVhdGVyIHRoZW4gbWF4TG9ja0R1cmF0aW9uPQkApAMBBQJhRAQCZXAJAGsDBQJiZwUBYwUCYUQEAmVxCQBrAwUCZWwFAmVwBQFjBAJlcgkBAmNhAAQCZFcJAQJicQEFAmJyBAJkUAgJAQJkRgACXzIEAmVzCQECY0UBBQJhWQQCZXQJAP0HBAUCYlMCEXJlZnJlc2hVc2VyUmV3YXJkCQDMCAIIBQJhWQVieXRlcwUDbmlsBQNuaWwDCQAAAgUCZXQFAmV0BAJldQMFAmVuBQNuaWwJAMwIAgkBDEludGVnZXJFbnRyeQIFAmVtCQBkAgUCYnIAAQkAzAgCCQELU3RyaW5nRW50cnkCCQECYmsBBQJiTwUCZW8JAMwIAgkBC1N0cmluZ0VudHJ5AgkBAmJsAQUCZW8FAmJPBQNuaWwJAJQKAgkAzggCCQDNCAIJAM4IAgkAzggCBQJldQkBAmNBBwUCYVkIBQJhTw10cmFuc2FjdGlvbklkBQJlbAUCY2sFAmJnBQJlcQAACQECY24EBQJlbAUCYmcAAQMFAmVuAAAAAQkBAmNoBwIEbG9jawUCYk8FAmVsBQJjawUCYmcFAmVxBQJhTwkAzAgCCQEMSW50ZWdlckVudHJ5AgUCZFcFAmRQCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYnkACQBkAgUCZXIFAmVxCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYmMBBQJhWQkAZAIFAmVzBQJlcQUDbmlsBQJlcQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgECZXYCAmFZAmV3BAJleAkBAmJiAgUCYVkFAmV3BAJleQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmV4BQJhUgQCY2sJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJleAUCYVMEAmV6CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCZXgFAmFUBAJlQQkAZAIFAmNrBQJlegQCYmkJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJleAUCYVcEAmJoCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCZXgFAmFWBAJlQgkAaQIJAGUCBQZoZWlnaHQFAmNrBQJhRgQCZUMJALwCAwkAtgIBBQJlQgkAuQICCQC2AgEJAGgCAAgFAmFGBQFoCQC2AgEFAmV6BAJlRAMJAGYCBQZoZWlnaHQFAmVBCQBlAgUCZXkFAmJpCQCgAwEJALwCAwkAtgIBBQJleQkAuAICBQFoCQB2BgkAtgIBAAUAAQUCZUMFAWYFAWYFBERPV04FAWgFAmVEEQJhTwELY29uc3RydWN0b3IGAmVFAmVGAmFCAmVHAmVIAmFFBAJlSQkBAmFOAQUCYU8DCQAAAgUCZUkFAmVJCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJiagAAAAkAzAgCCQELU3RyaW5nRW50cnkCCQECYXgACQECYUgFBQJlRgUCYUIFAmVHBQJlSAUCYUUJAMwIAgkBC1N0cmluZ0VudHJ5AgkBAUUABQJlRQUDbmlsCQECY24EAAAAAAAAAAAJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYU8BB2xvY2tSZWYDAmJnAmVKAmVLBAJlTAkBAmVoAgUCYU8FAmJnBAJlTQgFAmVMAl8xBAJlcQgFAmVMAl8yBAJlTgkApQgBCAUCYU8GY2FsbGVyBAJlTwMDCQAAAgUCZUoCAAYJAAACBQJlSwEABQR1bml0CQD8BwQFAUECCmNyZWF0ZVBhaXIJAMwIAgUBRAkAzAgCBQJlSgkAzAgCBQJlTgkAzAgCBQJlSwUDbmlsBQNuaWwDCQAAAgUCZU8FAmVPBAJlUAkA/AcEBQJhRQIWdXBkYXRlUmVmZXJyYWxBY3Rpdml0eQkAzAgCCQClCAEIBQJhTwZjYWxsZXIJAMwIAgUCZXEFA25pbAUDbmlsAwkAAAIFAmVQBQJlUAkAlAoCBQJlTQUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJhTwEEbG9jawECYmcEAmVRCQECZWgCBQJhTwUCYmcEAmVNCAUCZVECXzEEAmVxCAUCZVECXzIEAmVQCQD8BwQFAmFFAhZ1cGRhdGVSZWZlcnJhbEFjdGl2aXR5CQDMCAIJAKUIAQgFAmFPBmNhbGxlcgkAzAgCBQJlcQUDbmlsBQNuaWwDCQAAAgUCZVAFAmVQCQCUCgIFAmVNBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmFPAQxjbGFpbVd4Qm9vc3QCAmJHAmJPAwkBAiE9AgUCYlIIBQJhTwZjYWxsZXIJAQFtAQIScGVybWlzc2lvbnMgZGVuaWVkBAJlUgkBAmRRAwUCYkcFAmJPBwQCZVMIBQJlUgJfMQQCZWYIBQJlUgJfMgQCZWcIBQJlUgJfMwkAlAoCBQJlZgkAzAgCBQJlUwUDbmlsAmFPARRjbGFpbVd4Qm9vc3RSRUFET05MWQICYkcCYk8EAmVUCQECZFEDBQJiRwUCYk8GBAJlUwgFAmVUAl8xBAJlZggFAmVUAl8yBAJlZwgFAmVUAl8zCQCUCgIFA25pbAkAzAgCBQJlUwkAzAgCBQJlZwUDbmlsAmFPAQZ1bmxvY2sCAmVVAmJlBAJhWQgFAmFPBmNhbGxlcgQCYk8JAKUIAQUCYVkEAmFaCQDZBAEFAmVVBAJleAkBAmJiAgUCYVkDCQAAAgUCZVUCAAUEdW5pdAUCYVoEAmV5CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCZXgFAmFSBAJjawkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmV4BQJhUwQCZXoJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJleAUCYVQEAmVBCQBkAgUCY2sFAmV6BAJiaQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmV4BQJhVwQCYmgJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJleAUCYVYEAmVCCQBpAgkAZQIFBmhlaWdodAUCY2sFAmFGBAJlRAkBAmV2AgUCYVkDCQAAAgUCZVUCAAUEdW5pdAUCYVoDCQBmAgUCYmUFAmVECQEBbQEJAKwCAgIabWF4aW11bSBhbW91bnQgdG8gdW5sb2NrOiAJAKQDAQUCZUQEAmVWCQCWAwEJAMwIAgUCYmUJAMwIAgkAawMJAGgCBQJlQgUCYUYFAmV5BQJhRAUDbmlsBAJlVwkBAXcCCQBlAgUCYmgFAmVWAgxnd3hSZW1haW5pbmcEAmVYCQECY2IBBQJhWQMJAGYCBQJlWAUCZVcJAQFtAQkArAICAhNsb2NrZWQgZ3d4IGFtb3VudDogCQCkAwEFAmVYAwkAZwIAAAUCZXkJAQFtAQIRbm90aGluZyB0byB1bmxvY2sEAmVyCQECY2EABAJlcwkBAmNFAQUCYVkEAmV0CQD9BwQFAmJTAhFyZWZyZXNoVXNlclJld2FyZAkAzAgCCAUCYVkFYnl0ZXMFA25pbAUDbmlsAwkAAAIFAmV0BQJldAkAzggCCQDNCAIJAM0IAgkAzggCCQECY0EHBQJhWQUCYVoFAmV5BQJjawUCZXoFAmVXCQBkAgUCYmkFAmJlCQECY24ECQEBLQEFAmJlAAAAAAAACQECY2gHAgZ1bmxvY2sFAmJPBQJiZQUCY2sFAmV6BQJlVgUCYU8JAQ5TY3JpcHRUcmFuc2ZlcgMFAmFZBQJiZQUCYUEJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJieQAJAQF3AgkAZQIFAmVyBQJlVgIIZ3d4VG90YWwJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJiYwEFAmFZCQEBdwIJAGUCBQJlcwUCZVYCEnVzZXJHd3hBbW91bnRUb3RhbAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmFPARNnd3hVc2VySW5mb1JFQURPTkxZAQJiTwQCYVkJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBBQJiTwkBAWsBAhRpbnZhbGlkIHVzZXIgYWRkcmVzcwQCYmgJAQJjRQEFAmFZCQCUCgIFA25pbAkAzAgCBQJiaAUDbmlsAmFPARd1c2VyTWF4RHVyYXRpb25SRUFET05MWQECYk8JAJQKAgUDbmlsCQCUCgICDGluY3JlYXNlTG9jawUCYUQCYU8BIGdldFVzZXJHd3hBbW91bnRBdEhlaWdodFJFQURPTkxZAgJiTwJlWQQCYVkJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBBQJiTwkBAWsBAhRpbnZhbGlkIHVzZXIgYWRkcmVzcwQCYmgJAQJjRQEFAmFZCQCUCgIFA25pbAUCYmgCYU8BEGdldFVzZXJHd3hBbW91bnQBAmJPBAJhWQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEFAmJPCQEBawECFGludmFsaWQgdXNlciBhZGRyZXNzBAJiaAkBAmNFAQUCYVkJAJQKAgUDbmlsBQJiaAJhTwETZ2V0R3d4VG90YWxSRUFET05MWQAJAJQKAgUDbmlsCQECY2EAAmFPARVvbkJvb3N0RW1pc3Npb25VcGRhdGUABAJlSQMJAAACCAUCYU8GY2FsbGVyBQJiUQYJAQJhTgEFAmFPAwkAAAIFAmVJBQJlSQkBAmRGAAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJhTwESb25TdGFrZWRWb3RlVXBkYXRlAwJiRwJiTwJkcgQCZUkDCQAAAggFAmFPBmNhbGxlcgUCYlIGCQECYU4BBQJhTwMJAAACBQJlSQUCZUkEAmR1CQECZHEDBQJiRwUCYk8FAmRyCQCUCgIFAmR1BQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmFPAR1nZXRWb3RpbmdSZXN1bHRTdGFrZWRSRUFET05MWQECYkcJAJQKAgUDbmlsCQECY1YBBQJiRwJhTwElZ2V0Vm90aW5nUmVzdWx0U3Rha2VkSW50ZWdyYWxSRUFET05MWQECYkcJAJQKAgUDbmlsCQECY1oBBQJiRwJhTwEcZ2V0VXNlclZvdGVGaW5hbGl6ZWRSRUFET05MWQICYkcCYk8JAJQKAgUDbmlsCQECY08CBQJiRwUCYk8CYU8BIWdldFVzZXJWb3RlU3Rha2VkSW50ZWdyYWxSRUFET05MWQICYkcCYk8JAJQKAgUDbmlsCQECZGoCBQJiRwUCYk8BAmVaAQJmYQAEAmZiBAJhSgkBAmFMAAMJAAECBQJhSgIKQnl0ZVZlY3RvcgQCYVEFAmFKBQJhUQMJAAECBQJhSgIEVW5pdAgFAmVaD3NlbmRlclB1YmxpY0tleQkAAgECC01hdGNoIGVycm9yCQD0AwMIBQJlWglib2R5Qnl0ZXMJAJEDAggFAmVaBnByb29mcwAABQJmYvDf4mQ=", "height": 2704219, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: zA6j6EDYvB3GAAWCpZvJFNXRXhhNnGpY6FZfzemuy8K Next: AfNWRVN7bymiUtmGAYa1qUApok2Y2dPo1hHZMmrE7T6U Diff:
Old | New | Differences | |
---|---|---|---|
158 | 158 | ||
159 | 159 | let av = 5 | |
160 | 160 | ||
161 | - | func aw () = "%s__config" | |
161 | + | let aw = 6 | |
162 | + | ||
163 | + | func ax () = "%s__config" | |
162 | 164 | ||
163 | 165 | ||
164 | - | func | |
166 | + | func ay () = split(n(this, ax()), a) | |
165 | 167 | ||
166 | 168 | ||
167 | - | let | |
169 | + | let az = ay() | |
168 | 170 | ||
169 | - | let | |
171 | + | let aA = fromBase58String(az[ar]) | |
170 | 172 | ||
171 | - | let | |
173 | + | let aB = valueOrErrorMessage(parseInt(az[as]), k("invalid min lock amount")) | |
172 | 174 | ||
173 | - | let | |
175 | + | let aC = valueOrErrorMessage(parseInt(az[at]), k("invalid min lock duration")) | |
174 | 176 | ||
175 | - | let | |
177 | + | let aD = valueOrErrorMessage(parseInt(az[au]), k("invalid max lock duration")) | |
176 | 178 | ||
177 | - | let | |
179 | + | let aE = valueOrErrorMessage(addressFromString(az[av]), k("invalid math contract address")) | |
178 | 180 | ||
179 | - | func aE (az,aA,aB,aC,aD) = makeString(["%s%d%d%d%s", az, aA, aB, aC, aD], a) | |
181 | + | let aF = valueOrErrorMessage(parseInt(az[aw]), k("invalid blocks in period")) | |
182 | + | ||
183 | + | func aG (aA,aB,aC,aD,aE) = makeString(["%s%d%d%d%s", aA, aB, aC, aD, aE], a) | |
180 | 184 | ||
181 | 185 | ||
182 | - | func | |
186 | + | func aH (aA,aB,aC,aD,aE) = aG(aA, toString(aB), toString(aC), toString(aD), aE) | |
183 | 187 | ||
184 | 188 | ||
185 | - | func | |
186 | - | let | |
187 | - | if ($isInstanceOf( | |
189 | + | func aI () = { | |
190 | + | let aJ = getString(ah()) | |
191 | + | if ($isInstanceOf(aJ, "String")) | |
188 | 192 | then { | |
189 | - | let | |
190 | - | addressFromStringValue( | |
193 | + | let aK = aJ | |
194 | + | addressFromStringValue(aK) | |
191 | 195 | } | |
192 | 196 | else this | |
193 | 197 | } | |
194 | 198 | ||
195 | 199 | ||
196 | - | func | |
197 | - | let | |
198 | - | let | |
199 | - | if ($isInstanceOf( | |
200 | + | func aL () = { | |
201 | + | let aM = aI() | |
202 | + | let aJ = getString(aM, ag()) | |
203 | + | if ($isInstanceOf(aJ, "String")) | |
200 | 204 | then { | |
201 | - | let | |
202 | - | fromBase58String( | |
205 | + | let aK = aJ | |
206 | + | fromBase58String(aK) | |
203 | 207 | } | |
204 | - | else if ($isInstanceOf( | |
208 | + | else if ($isInstanceOf(aJ, "Unit")) | |
205 | 209 | then unit | |
206 | 210 | else throw("Match error") | |
207 | 211 | } | |
208 | 212 | ||
209 | 213 | ||
210 | - | func | |
211 | - | let | |
212 | - | let | |
213 | - | if ($isInstanceOf( | |
214 | + | func aN (aO) = { | |
215 | + | let aP = m("Permission denied") | |
216 | + | let aJ = aL() | |
217 | + | if ($isInstanceOf(aJ, "ByteVector")) | |
214 | 218 | then { | |
215 | - | let | |
216 | - | if (( | |
219 | + | let aQ = aJ | |
220 | + | if ((aO.callerPublicKey == aQ)) | |
217 | 221 | then true | |
218 | - | else | |
222 | + | else aP | |
219 | 223 | } | |
220 | - | else if ($isInstanceOf( | |
221 | - | then if (( | |
224 | + | else if ($isInstanceOf(aJ, "Unit")) | |
225 | + | then if ((aO.caller == this)) | |
222 | 226 | then true | |
223 | - | else | |
227 | + | else aP | |
224 | 228 | else throw("Match error") | |
225 | 229 | } | |
226 | 230 | ||
227 | 231 | ||
228 | - | let | |
232 | + | let aR = 1 | |
229 | 233 | ||
230 | - | let | |
234 | + | let aS = 2 | |
231 | 235 | ||
232 | - | let | |
236 | + | let aT = 3 | |
233 | 237 | ||
234 | - | let | |
238 | + | let aU = 4 | |
235 | 239 | ||
236 | - | let | |
240 | + | let aV = 5 | |
237 | 241 | ||
238 | - | let | |
242 | + | let aW = 6 | |
239 | 243 | ||
240 | - | func | |
241 | - | let | |
242 | - | if ($isInstanceOf( | |
244 | + | func aX (aY,aZ) = makeString(["%s%s%s__lock", toString(aY), { | |
245 | + | let aJ = aZ | |
246 | + | if ($isInstanceOf(aJ, "ByteVector")) | |
243 | 247 | then { | |
244 | - | let | |
245 | - | toBase58String( | |
248 | + | let ba = aJ | |
249 | + | toBase58String(ba) | |
246 | 250 | } | |
247 | - | else if ($isInstanceOf( | |
251 | + | else if ($isInstanceOf(aJ, "Unit")) | |
248 | 252 | then "legacy" | |
249 | 253 | else throw("Match error") | |
250 | 254 | }], a) | |
251 | 255 | ||
252 | 256 | ||
253 | - | func | |
257 | + | func bb (aY,aZ) = split(n(this, aX(aY, aZ)), a) | |
254 | 258 | ||
255 | 259 | ||
256 | - | func | |
260 | + | func bc (aY) = makeString(["%s%s__gwxAmountTotal", toString(aY)], a) | |
257 | 261 | ||
258 | 262 | ||
259 | - | func | |
263 | + | func bd (be,bf,bg,bh,bi) = makeString(["%d%d%d%d%d%d%d", toString(be), toString(bf), toString(bg), toString(lastBlock.timestamp), toString(bh), toString(bi)], a) | |
260 | 264 | ||
261 | 265 | ||
262 | - | func | |
266 | + | func bj () = "%s__nextUserNum" | |
263 | 267 | ||
264 | 268 | ||
265 | - | func | |
269 | + | func bk (aY) = makeString(["%s%s%s__mapping__user2num", aY], a) | |
266 | 270 | ||
267 | 271 | ||
268 | - | func | |
272 | + | func bl (X) = makeString(["%s%s%s__mapping__num2user", X], a) | |
269 | 273 | ||
270 | 274 | ||
271 | - | func | |
275 | + | func bm () = "%s%s__stats__activeTotalLocked" | |
272 | 276 | ||
273 | 277 | ||
274 | - | func | |
278 | + | func bn () = "%s%s__stats__locksDurationSumInBlocks" | |
275 | 279 | ||
276 | 280 | ||
277 | - | func | |
281 | + | func bo () = "%s%s__stats__locksCount" | |
278 | 282 | ||
279 | 283 | ||
280 | - | func | |
284 | + | func bp () = "%s%s__stats__activeUsersCount" | |
281 | 285 | ||
282 | 286 | ||
283 | - | func | |
287 | + | func bq (br) = makeString(["%s%d__userBoostEmissionLastIntV2", toString(br)], a) | |
284 | 288 | ||
285 | 289 | ||
286 | - | func | |
290 | + | func bs (br,bt) = makeString(["%s%d__userBoostEmissionLastIntV2", toString(br), bt], a) | |
287 | 291 | ||
288 | 292 | ||
289 | - | func | |
293 | + | func bu (br) = makeString(["%s%d__maxBoostInt", toString(br)], a) | |
290 | 294 | ||
291 | 295 | ||
292 | - | func | |
296 | + | func bv () = "%s%s__maxBoostInt__total" | |
293 | 297 | ||
294 | 298 | ||
295 | - | func | |
299 | + | func bw (br) = makeString(["%s%d__userBoostAvaliableToClaimTotal", toString(br)], a) | |
296 | 300 | ||
297 | 301 | ||
298 | - | func | |
302 | + | func bx (br) = makeString(["%s%d__userBoostClaimed", toString(br)], a) | |
299 | 303 | ||
300 | 304 | ||
301 | - | func | |
305 | + | func by () = "%s%s__gwx__total" | |
302 | 306 | ||
303 | 307 | ||
304 | - | func | |
308 | + | func bz (bA,bB,o,bC) = makeString(["%s%s%s%s%d", "vote", bA, bB, toString(o), toString(bC)], a) | |
305 | 309 | ||
306 | 310 | ||
307 | - | func | |
311 | + | func bD (bC) = makeString(["%s%d", "startHeight", toString(bC)], a) | |
308 | 312 | ||
309 | 313 | ||
310 | - | func | |
314 | + | func bE () = makeString(["%s", "currentEpochUi"], a) | |
311 | 315 | ||
312 | 316 | ||
313 | - | func | |
317 | + | func bF (bG,bC) = makeString(["%s%s%d", "votingResultStaked", bG, toString(bC)], a) | |
314 | 318 | ||
315 | 319 | ||
316 | - | func | |
320 | + | func bH (bG,bC) = makeString(["%s%s%d", "votingResultStakedIntegral", bG, toString(bC)], a) | |
317 | 321 | ||
318 | 322 | ||
319 | - | func | |
323 | + | func bI (bG,bC) = makeString(["%s%s%d", "votingResultStakedIntegralLastUpdateHeight", bG, toString(bC)], a) | |
320 | 324 | ||
321 | 325 | ||
322 | - | func | |
326 | + | func bJ (bG,o,bC) = makeString(["%s%s%s%d", "votingResultStakedIntegralLast", bG, toString(o), toString(bC)], a) | |
323 | 327 | ||
324 | 328 | ||
325 | - | func | |
329 | + | func bK (bG,o,bC) = makeString(["%s%s%s%d", "voteStakedIntegral", bG, toString(o), toString(bC)], a) | |
326 | 330 | ||
327 | 331 | ||
328 | - | func | |
332 | + | func bL (bG,o,bC) = makeString(["%s%s%s%d", "voteStakedIntegralLastUpdateHeight", bG, toString(o), toString(bC)], a) | |
329 | 333 | ||
330 | 334 | ||
331 | - | func | |
335 | + | func bM (bG,o,bC) = makeString(["%s%s%s%d", "voteStakedIntegralLast", bG, toString(o), toString(bC)], a) | |
332 | 336 | ||
333 | 337 | ||
334 | - | func | |
338 | + | func bN (bO,bG) = makeString(["%s%s%s", "staked", bO, bG], a) | |
335 | 339 | ||
336 | 340 | ||
337 | - | let | |
341 | + | let bP = Y() | |
338 | 342 | ||
339 | - | let ac = Z( | |
343 | + | let ac = Z(bP) | |
340 | 344 | ||
341 | - | let | |
345 | + | let bQ = ad(ac) | |
342 | 346 | ||
343 | - | let | |
347 | + | let bR = ae(ac) | |
344 | 348 | ||
345 | - | let | |
349 | + | let bS = af(ac) | |
346 | 350 | ||
347 | - | let | |
351 | + | let bT = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(makeString(["%s", "lpStakingPoolsContract"], a)), k("lp_staking_pools contract address is undefined"))), k("invalid lp_staking_pools contract address")) | |
348 | 352 | ||
349 | - | let | |
353 | + | let bU = makeString(["%s", "votingEmissionContract"], a) | |
350 | 354 | ||
351 | - | let | |
355 | + | let bV = addressFromStringValue(getStringValue(bP, bU)) | |
352 | 356 | ||
353 | - | let | |
357 | + | let bW = makeString(["%s", "votingEmissionRateContract"], a) | |
354 | 358 | ||
355 | - | let | |
356 | - | let | |
357 | - | if ($isInstanceOf( | |
358 | - | then | |
359 | - | else throw(($getType( | |
359 | + | let bX = { | |
360 | + | let bY = invoke(bQ, "getBoostCoeffREADONLY", nil, nil) | |
361 | + | if ($isInstanceOf(bY, "Int")) | |
362 | + | then bY | |
363 | + | else throw(($getType(bY) + " couldn't be cast to Int")) | |
360 | 364 | } | |
361 | 365 | ||
362 | - | func | |
363 | - | let | |
364 | - | if ($isInstanceOf( | |
366 | + | func bZ (aY) = { | |
367 | + | let aJ = getString(this, bk(toString(aY))) | |
368 | + | if ($isInstanceOf(aJ, "String")) | |
365 | 369 | then { | |
366 | - | let | |
367 | - | valueOrErrorMessage(parseInt( | |
370 | + | let aK = aJ | |
371 | + | valueOrErrorMessage(parseInt(aK), k("invalid user number")) | |
368 | 372 | } | |
369 | - | else if ($isInstanceOf( | |
373 | + | else if ($isInstanceOf(aJ, "Unit")) | |
370 | 374 | then m("invalid user") | |
371 | 375 | else throw("Match error") | |
372 | 376 | } | |
373 | 377 | ||
374 | 378 | ||
375 | - | func | |
379 | + | func ca () = valueOrElse(getInteger(this, by()), 0) | |
376 | 380 | ||
377 | 381 | ||
378 | - | func | |
379 | - | let | |
380 | - | let | |
381 | - | let | |
382 | - | if ($isInstanceOf( | |
382 | + | func cb (aY) = { | |
383 | + | let cc = "getLockedGwxAmount" | |
384 | + | let cd = valueOrErrorMessage({ | |
385 | + | let aJ = getString(bV, bW) | |
386 | + | if ($isInstanceOf(aJ, "Unit")) | |
383 | 387 | then unit | |
384 | - | else if ($isInstanceOf( | |
388 | + | else if ($isInstanceOf(aJ, "String")) | |
385 | 389 | then { | |
386 | - | let | |
387 | - | addressFromString( | |
390 | + | let aK = aJ | |
391 | + | addressFromString(aK) | |
388 | 392 | } | |
389 | 393 | else throw("Match error") | |
390 | 394 | }, k("invalid voting emission rate address")) | |
391 | - | let | |
392 | - | let | |
393 | - | if ($isInstanceOf( | |
394 | - | then | |
395 | - | else throw(($getType( | |
395 | + | let ce = { | |
396 | + | let bY = invoke(bV, cc, [toString(aY)], nil) | |
397 | + | if ($isInstanceOf(bY, "Int")) | |
398 | + | then bY | |
399 | + | else throw(($getType(bY) + " couldn't be cast to Int")) | |
396 | 400 | } | |
397 | - | let | |
398 | - | let | |
399 | - | if ($isInstanceOf( | |
400 | - | then | |
401 | - | else throw(($getType( | |
401 | + | let cf = { | |
402 | + | let bY = invoke(cd, cc, [toString(aY)], nil) | |
403 | + | if ($isInstanceOf(bY, "Int")) | |
404 | + | then bY | |
405 | + | else throw(($getType(bY) + " couldn't be cast to Int")) | |
402 | 406 | } | |
403 | - | let | |
404 | - | | |
407 | + | let cg = max([ce, cf]) | |
408 | + | cg | |
405 | 409 | } | |
406 | 410 | ||
407 | 411 | ||
408 | - | func | |
409 | - | let | |
410 | - | let | |
411 | - | StringEntry( | |
412 | + | func ch (ci,cj,be,ck,bg,bh,aO) = { | |
413 | + | let cl = makeString(["%s%s%s%s__history", ci, cj, toBase58String(aO.transactionId)], a) | |
414 | + | let cm = makeString(["%d%d%d%d%d%d%d", toString(lastBlock.height), toString(lastBlock.timestamp), toString(be), toString(ck), toString(bg), toString(bh)], a) | |
415 | + | StringEntry(cl, cm) | |
412 | 416 | } | |
413 | 417 | ||
414 | 418 | ||
415 | - | func cl (cm,cn,co,cp) = { | |
416 | - | let cq = bl() | |
417 | - | let cr = bm() | |
419 | + | func cn (co,cp,cq,cr) = { | |
418 | 420 | let cs = bn() | |
419 | - | let ct = | |
420 | - | let cu = | |
421 | - | let cv = | |
421 | + | let ct = bo() | |
422 | + | let cu = bp() | |
423 | + | let cv = bm() | |
422 | 424 | let cw = q(this, cs) | |
423 | 425 | let cx = q(this, ct) | |
424 | - | [IntegerEntry(cq, (cu + cn)), IntegerEntry(cr, (cv + co)), IntegerEntry(cs, (cw + cp)), IntegerEntry(ct, (cx + cm))] | |
426 | + | let cy = q(this, cu) | |
427 | + | let cz = q(this, cv) | |
428 | + | [IntegerEntry(cs, (cw + cp)), IntegerEntry(ct, (cx + cq)), IntegerEntry(cu, (cy + cr)), IntegerEntry(cv, (cz + co))] | |
425 | 429 | } | |
426 | 430 | ||
427 | 431 | ||
428 | - | func | |
432 | + | func cA (aY,aZ,be,bf,bg,bh,bi) = [StringEntry(aX(aY, aZ), bd(be, bf, bg, bh, bi))] | |
429 | 433 | ||
430 | 434 | ||
431 | - | func | |
435 | + | func cB (aO,cC) = if ((size(aO.payments) > 1)) | |
432 | 436 | then m("only one payment is allowed") | |
433 | - | else if ((size( | |
437 | + | else if ((size(aO.payments) == 0)) | |
434 | 438 | then 0 | |
435 | 439 | else { | |
436 | - | let | |
437 | - | if ((value( | |
440 | + | let cD = aO.payments[0] | |
441 | + | if ((value(cD.assetId) != cC)) | |
438 | 442 | then m("invalid asset id in payment") | |
439 | - | else | |
443 | + | else cD.amount | |
440 | 444 | } | |
441 | 445 | ||
442 | 446 | ||
443 | - | func | |
447 | + | func cE (aY) = valueOrElse(getInteger(this, bc(aY)), 0) | |
444 | 448 | ||
445 | 449 | ||
446 | - | func | |
447 | - | let | |
448 | - | let | |
449 | - | let | |
450 | - | if ((0 > | |
450 | + | func cF () = { | |
451 | + | let cG = { | |
452 | + | let cH = value(getInteger(bV, bE())) | |
453 | + | let cI = (cH - 1) | |
454 | + | if ((0 > cI)) | |
451 | 455 | then m("invalid epoch") | |
452 | - | else $Tuple2( | |
456 | + | else $Tuple2(cH, cI) | |
453 | 457 | } | |
454 | - | let | |
455 | - | let | |
456 | - | let | |
457 | - | $Tuple2( | |
458 | + | let cH = cG._1 | |
459 | + | let cI = cG._2 | |
460 | + | let cJ = value(getInteger(bV, bD(cH))) | |
461 | + | $Tuple2(cI, cJ) | |
458 | 462 | } | |
459 | 463 | ||
460 | 464 | ||
461 | - | func | |
462 | - | let | |
463 | - | let | |
464 | - | let | |
465 | - | let | |
466 | - | if ($isInstanceOf( | |
467 | - | then | |
468 | - | else throw(($getType( | |
465 | + | func cK (bG) = { | |
466 | + | let cL = 4 | |
467 | + | let cM = 5 | |
468 | + | let cN = { | |
469 | + | let bY = invoke(bP, "getPoolConfigByLpAssetIdREADONLY", [bG], nil) | |
470 | + | if ($isInstanceOf(bY, "List[Any]")) | |
471 | + | then bY | |
472 | + | else throw(($getType(bY) + " couldn't be cast to List[Any]")) | |
469 | 473 | } | |
470 | - | let | |
471 | - | let | |
472 | - | if ($isInstanceOf( | |
473 | - | then | |
474 | - | else throw(($getType( | |
474 | + | let bA = { | |
475 | + | let bY = cN[cL] | |
476 | + | if ($isInstanceOf(bY, "String")) | |
477 | + | then bY | |
478 | + | else throw(($getType(bY) + " couldn't be cast to String")) | |
475 | 479 | } | |
476 | - | let | |
477 | - | let | |
478 | - | if ($isInstanceOf( | |
479 | - | then | |
480 | - | else throw(($getType( | |
480 | + | let bB = { | |
481 | + | let bY = cN[cM] | |
482 | + | if ($isInstanceOf(bY, "String")) | |
483 | + | then bY | |
484 | + | else throw(($getType(bY) + " couldn't be cast to String")) | |
481 | 485 | } | |
482 | - | $Tuple2( | |
486 | + | $Tuple2(bA, bB) | |
483 | 487 | } | |
484 | 488 | ||
485 | 489 | ||
486 | - | func | |
487 | - | let | |
488 | - | let | |
489 | - | let | |
490 | - | let | |
491 | - | let | |
492 | - | let | |
493 | - | let | |
494 | - | let | |
495 | - | let | |
496 | - | | |
490 | + | func cO (bG,bO) = { | |
491 | + | let aY = addressFromStringValue(bO) | |
492 | + | let cP = cF() | |
493 | + | let cI = cP._1 | |
494 | + | let cJ = cP._2 | |
495 | + | let cQ = cK(bG) | |
496 | + | let bA = cQ._1 | |
497 | + | let bB = cQ._2 | |
498 | + | let cR = bz(bA, bB, aY, cI) | |
499 | + | let cS = valueOrElse(getInteger(bV, cR), 0) | |
500 | + | cS | |
497 | 501 | } | |
498 | 502 | ||
499 | 503 | ||
500 | - | func | |
501 | - | let | |
502 | - | let | |
503 | - | if (( | |
504 | + | func cT (bG,bO) = { | |
505 | + | let cU = valueOrElse(getInteger(bR, bN(bO, bG)), 0) | |
506 | + | let cS = cO(bG, bO) | |
507 | + | if ((cU == 0)) | |
504 | 508 | then 0 | |
505 | - | else | |
509 | + | else cS | |
506 | 510 | } | |
507 | 511 | ||
508 | 512 | ||
509 | - | func | |
510 | - | let | |
511 | - | let | |
512 | - | let | |
513 | - | let | |
514 | - | let | |
515 | - | | |
513 | + | func cV (bG) = { | |
514 | + | let cW = cF() | |
515 | + | let cI = cW._1 | |
516 | + | let cJ = cW._2 | |
517 | + | let cX = valueOrElse(getInteger(bV, bF(bG, cI)), 0) | |
518 | + | let cY = valueOrElse(getInteger(this, bF(bG, cI)), cX) | |
519 | + | cY | |
516 | 520 | } | |
517 | 521 | ||
518 | 522 | ||
519 | - | func | |
520 | - | let | |
521 | - | let | |
522 | - | let | |
523 | - | let | |
524 | - | let | |
525 | - | let | |
526 | - | let | |
527 | - | let | |
528 | - | | |
523 | + | func cZ (bG) = { | |
524 | + | let da = cF() | |
525 | + | let cI = da._1 | |
526 | + | let cJ = da._2 | |
527 | + | let cY = cV(bG) | |
528 | + | let db = valueOrElse(getInteger(this, bH(bG, cI)), 0) | |
529 | + | let dc = valueOrElse(getInteger(this, bI(bG, cI)), cJ) | |
530 | + | let dd = (height - dc) | |
531 | + | let de = ((dd * cY) + db) | |
532 | + | de | |
529 | 533 | } | |
530 | 534 | ||
531 | 535 | ||
532 | - | func | |
533 | - | let | |
534 | - | let | |
535 | - | let | |
536 | - | let | |
537 | - | let | |
538 | - | let | |
539 | - | [IntegerEntry( | |
536 | + | func df (bG,dg) = { | |
537 | + | let dh = cF() | |
538 | + | let cI = dh._1 | |
539 | + | let cJ = dh._2 | |
540 | + | let cY = cV(bG) | |
541 | + | let di = (cY + dg) | |
542 | + | let de = cZ(bG) | |
543 | + | [IntegerEntry(bF(bG, cI), di), IntegerEntry(bI(bG, cI), height), IntegerEntry(bH(bG, cI), de)] | |
540 | 544 | } | |
541 | 545 | ||
542 | 546 | ||
543 | - | func | |
544 | - | let | |
545 | - | let | |
546 | - | let | |
547 | - | let | |
548 | - | let | |
549 | - | let | |
550 | - | let | |
551 | - | let | |
552 | - | let | |
553 | - | | |
547 | + | func dj (bG,bO) = { | |
548 | + | let dk = cF() | |
549 | + | let cI = dk._1 | |
550 | + | let cJ = dk._2 | |
551 | + | let aY = addressFromStringValue(bO) | |
552 | + | let dl = cT(bG, bO) | |
553 | + | let dm = valueOrElse(getInteger(this, bK(bG, aY, cI)), 0) | |
554 | + | let dn = valueOrElse(getInteger(this, bL(bG, aY, cI)), cJ) | |
555 | + | let do = (height - dn) | |
556 | + | let dp = ((do * dl) + dm) | |
557 | + | dp | |
554 | 558 | } | |
555 | 559 | ||
556 | 560 | ||
557 | - | func | |
558 | - | let | |
559 | - | let | |
560 | - | let | |
561 | - | let | |
562 | - | let | |
563 | - | let | |
561 | + | func dq (bG,bO,dr) = { | |
562 | + | let ds = cF() | |
563 | + | let cI = ds._1 | |
564 | + | let cJ = ds._2 | |
565 | + | let aY = addressFromStringValue(bO) | |
566 | + | let dt = cO(bG, bO) | |
567 | + | let du = if ((dt == 0)) | |
564 | 568 | then nil | |
565 | 569 | else { | |
566 | - | let | |
567 | - | then | |
568 | - | else -( | |
569 | - | let | |
570 | - | let | |
571 | - | let | |
572 | - | ( | |
570 | + | let dg = if (dr) | |
571 | + | then dt | |
572 | + | else -(dt) | |
573 | + | let dv = df(bG, dg) | |
574 | + | let dp = dj(bG, bO) | |
575 | + | let dw = [IntegerEntry(bL(bG, aY, cI), height), IntegerEntry(bK(bG, aY, cI), dp)] | |
576 | + | (dv ++ dw) | |
573 | 577 | } | |
574 | - | | |
578 | + | du | |
575 | 579 | } | |
576 | 580 | ||
577 | 581 | ||
578 | - | func dv (bE,bM) = { | |
579 | - | let dw = cD() | |
580 | - | let cG = dw._1 | |
581 | - | let cH = dw._2 | |
582 | - | let aW = addressFromStringValue(bM) | |
583 | - | let dx = bK(bE, aW, cG) | |
584 | - | let dy = valueOrElse(getInteger(this, dx), 0) | |
585 | - | let dz = bH(bE, aW, cG) | |
582 | + | func dx (bG,bO) = { | |
583 | + | let dy = cF() | |
584 | + | let cI = dy._1 | |
585 | + | let cJ = dy._2 | |
586 | + | let aY = addressFromStringValue(bO) | |
587 | + | let dz = bM(bG, aY, cI) | |
586 | 588 | let dA = valueOrElse(getInteger(this, dz), 0) | |
587 | - | let dn = dh(bE, bM) | |
588 | - | let dc = cX(bE) | |
589 | - | let dB = (dn - dy) | |
590 | - | let dC = (dc - dA) | |
591 | - | $Tuple3([IntegerEntry(dx, dn), IntegerEntry(dz, dc)], dB, dC) | |
589 | + | let dB = bJ(bG, aY, cI) | |
590 | + | let dC = valueOrElse(getInteger(this, dB), 0) | |
591 | + | let dp = dj(bG, bO) | |
592 | + | let de = cZ(bG) | |
593 | + | let dD = (dp - dA) | |
594 | + | let dE = (de - dC) | |
595 | + | $Tuple3([IntegerEntry(dz, dp), IntegerEntry(dB, de)], dD, dE) | |
592 | 596 | } | |
593 | 597 | ||
594 | 598 | ||
595 | - | func | |
596 | - | let | |
597 | - | let | |
598 | - | let | |
599 | - | let | |
600 | - | let | |
601 | - | then | |
599 | + | func dF () = { | |
600 | + | let dG = t(bQ, ai()) | |
601 | + | let dH = getInteger(this, al()) | |
602 | + | let dI = getInteger(this, am()) | |
603 | + | let dJ = t(bQ, ao()) | |
604 | + | let dK = if ((height > dJ)) | |
605 | + | then dJ | |
602 | 606 | else height | |
603 | - | let | |
604 | - | let | |
605 | - | if ($isInstanceOf( | |
607 | + | let dL = { | |
608 | + | let aJ = dH | |
609 | + | if ($isInstanceOf(aJ, "Int")) | |
606 | 610 | then { | |
607 | - | let | |
608 | - | max([( | |
611 | + | let dM = aJ | |
612 | + | max([(dK - dM), 0]) | |
609 | 613 | } | |
610 | - | else if ($isInstanceOf( | |
614 | + | else if ($isInstanceOf(aJ, "Unit")) | |
611 | 615 | then 0 | |
612 | 616 | else throw("Match error") | |
613 | 617 | } | |
614 | - | let | |
615 | - | let | |
616 | - | let | |
617 | - | $Tuple2([IntegerEntry(am(), | |
618 | + | let dN = ((dG * (bX - 1)) / bX) | |
619 | + | let dO = valueOrElse(dI, 0) | |
620 | + | let dP = ((dN * dL) + dO) | |
621 | + | $Tuple2([IntegerEntry(am(), dP), IntegerEntry(al(), height)], dP) | |
618 | 622 | } | |
619 | 623 | ||
620 | 624 | ||
621 | - | func | |
622 | - | let | |
623 | - | let | |
624 | - | if (( | |
625 | + | func dQ (bG,bO,dR) = { | |
626 | + | let aY = valueOrErrorMessage(addressFromString(bO), k("invalid user address")) | |
627 | + | let br = bZ(aY) | |
628 | + | if ((br == br)) | |
625 | 629 | then { | |
626 | - | let | |
627 | - | let | |
630 | + | let dS = "empty" | |
631 | + | let dT = if ((bG != dS)) | |
628 | 632 | then { | |
629 | - | let | |
630 | - | getIntegerValue( | |
633 | + | let dU = valueOrErrorMessage(getString(bP, R(bG)), k(("unsupported lp asset " + bG))) | |
634 | + | getIntegerValue(bP, T(dU)) | |
631 | 635 | } | |
632 | - | else if ( | |
636 | + | else if (dR) | |
633 | 637 | then 0 | |
634 | - | else m(("not readonly mode: unsupported lp asset " + | |
635 | - | let | |
636 | - | let | |
637 | - | let | |
638 | - | let | |
639 | - | let | |
640 | - | if ((0 > | |
638 | + | else m(("not readonly mode: unsupported lp asset " + bG)) | |
639 | + | let dV = bs(br, bG) | |
640 | + | let dW = bq(br) | |
641 | + | let dX = valueOrElse(getInteger(this, dV), q(this, dW)) | |
642 | + | let dP = dF()._2 | |
643 | + | let dY = (dP - dX) | |
644 | + | if ((0 > dY)) | |
641 | 645 | then m("wrong calculations") | |
642 | 646 | else { | |
643 | - | let | |
644 | - | let | |
645 | - | let | |
646 | - | let | |
647 | - | let | |
648 | - | let | |
647 | + | let dZ = dx(bG, bO) | |
648 | + | let ea = dZ._1 | |
649 | + | let eb = dZ._2 | |
650 | + | let ec = dZ._3 | |
651 | + | let ed = fraction(dY, dT, d) | |
652 | + | let ee = if ((ec == 0)) | |
649 | 653 | then 0 | |
650 | - | else fraction(eb, | |
651 | - | let | |
652 | - | let | |
653 | - | $Tuple3( | |
654 | + | else fraction(ed, eb, ec) | |
655 | + | let ef = ([IntegerEntry(dV, dP)] ++ ea) | |
656 | + | let eg = makeString([toString(dX), toString(dY), toString(dT), toString(eb), toString(ec)], ":") | |
657 | + | $Tuple3(ee, ef, eg) | |
654 | 658 | } | |
655 | 659 | } | |
656 | 660 | else throw("Strict value is not equal to itself.") | |
657 | 661 | } | |
658 | 662 | ||
659 | 663 | ||
660 | - | func | |
661 | - | let | |
662 | - | if (!(containsElement( | |
664 | + | func eh (aO,ei) = { | |
665 | + | let ej = [1, 3, 6, 12, 24, 48] | |
666 | + | if (!(containsElement(ej, ei))) | |
663 | 667 | then m("invalid duration") | |
664 | 668 | else { | |
665 | - | let | |
666 | - | let | |
667 | - | if ((size( | |
669 | + | let bg = (ei * j) | |
670 | + | let ek = toBase58String(aA) | |
671 | + | if ((size(aO.payments) != 1)) | |
668 | 672 | then m("invalid payment - exact one payment must be attached") | |
669 | 673 | else { | |
670 | - | let | |
671 | - | let | |
672 | - | if (( | |
673 | - | then m((("invalid asset is in payment - " + | |
674 | + | let cD = aO.payments[0] | |
675 | + | let el = cD.amount | |
676 | + | if ((aA != value(cD.assetId))) | |
677 | + | then m((("invalid asset is in payment - " + ek) + " is expected")) | |
674 | 678 | else { | |
675 | - | let | |
676 | - | let | |
677 | - | let | |
678 | - | let | |
679 | - | let | |
680 | - | then value(getString( | |
681 | - | else toString(t(this, | |
682 | - | let | |
683 | - | let | |
684 | - | if (if (( | |
685 | - | then ( | |
679 | + | let em = bj() | |
680 | + | let aY = aO.caller | |
681 | + | let bO = toString(aY) | |
682 | + | let en = isDefined(getString(bk(bO))) | |
683 | + | let eo = if (en) | |
684 | + | then value(getString(bk(bO))) | |
685 | + | else toString(t(this, em)) | |
686 | + | let br = parseIntValue(eo) | |
687 | + | let ck = height | |
688 | + | if (if ((aB > el)) | |
689 | + | then (aY != bT) | |
686 | 690 | else false) | |
687 | - | then m(("amount is less then minLockAmount=" + toString( | |
688 | - | else if (( | |
689 | - | then m(("passed duration is less then minLockDuration=" + toString( | |
690 | - | else if (( | |
691 | - | then m(("passed duration is greater then maxLockDuration=" + toString( | |
691 | + | then m(("amount is less then minLockAmount=" + toString(aB))) | |
692 | + | else if ((aC > bg)) | |
693 | + | then m(("passed duration is less then minLockDuration=" + toString(aC))) | |
694 | + | else if ((bg > aD)) | |
695 | + | then m(("passed duration is greater then maxLockDuration=" + toString(aD))) | |
692 | 696 | else { | |
693 | - | let | |
694 | - | let | |
695 | - | let | |
696 | - | let | |
697 | - | let | |
698 | - | let | |
699 | - | let | |
700 | - | if (( | |
697 | + | let ep = fraction(bg, c, aD) | |
698 | + | let eq = fraction(el, ep, c) | |
699 | + | let er = ca() | |
700 | + | let dW = bq(br) | |
701 | + | let dP = dF()._2 | |
702 | + | let es = cE(aY) | |
703 | + | let et = reentrantInvoke(bS, "refreshUserReward", [aY.bytes], nil) | |
704 | + | if ((et == et)) | |
701 | 705 | then { | |
702 | - | let | |
706 | + | let eu = if (en) | |
703 | 707 | then nil | |
704 | - | else [IntegerEntry( | |
705 | - | $Tuple2((((( | |
708 | + | else [IntegerEntry(em, (br + 1)), StringEntry(bk(bO), eo), StringEntry(bl(eo), bO)] | |
709 | + | $Tuple2(((((eu ++ cA(aY, aO.transactionId, el, ck, bg, eq, 0)) ++ cn(el, bg, 1, if (en) | |
706 | 710 | then 0 | |
707 | - | else 1)) :+ | |
711 | + | else 1)) :+ ch("lock", bO, el, ck, bg, eq, aO)) ++ [IntegerEntry(dW, dP), IntegerEntry(by(), (er + eq)), IntegerEntry(bc(aY), (es + eq))]), eq) | |
708 | 712 | } | |
709 | 713 | else throw("Strict value is not equal to itself.") | |
710 | 714 | } | |
714 | 718 | } | |
715 | 719 | ||
716 | 720 | ||
717 | - | func | |
718 | - | let | |
719 | - | let | |
720 | - | let | |
721 | - | let | |
722 | - | let | |
723 | - | let | |
724 | - | let | |
725 | - | let | |
726 | - | let | |
727 | - | let | |
728 | - | then ( | |
729 | - | else toInt(fraction(toBigInt( | |
730 | - | | |
721 | + | func ev (aY,ew) = { | |
722 | + | let ex = bb(aY, ew) | |
723 | + | let ey = parseIntValue(ex[aR]) | |
724 | + | let ck = parseIntValue(ex[aS]) | |
725 | + | let ez = parseIntValue(ex[aT]) | |
726 | + | let eA = (ck + ez) | |
727 | + | let bi = parseIntValue(ex[aW]) | |
728 | + | let bh = parseIntValue(ex[aV]) | |
729 | + | let eB = ((height - ck) / aF) | |
730 | + | let eC = fraction(toBigInt(eB), (toBigInt((8 * aF)) * h), toBigInt(ez)) | |
731 | + | let eD = if ((height > eA)) | |
732 | + | then (ey - bi) | |
733 | + | else toInt(fraction(toBigInt(ey), (h - pow(toBigInt(5), 1, eC, f, f, DOWN)), h)) | |
734 | + | eD | |
731 | 735 | } | |
732 | 736 | ||
733 | 737 | ||
734 | - | @Callable( | |
735 | - | func constructor ( | |
736 | - | let | |
737 | - | if (( | |
738 | - | then ([IntegerEntry( | |
738 | + | @Callable(aO) | |
739 | + | func constructor (eE,eF,aB,eG,eH,aE) = { | |
740 | + | let eI = aN(aO) | |
741 | + | if ((eI == eI)) | |
742 | + | then ([IntegerEntry(bj(), 0), StringEntry(ax(), aH(eF, aB, eG, eH, aE)), StringEntry(E(), eE)] ++ cn(0, 0, 0, 0)) | |
739 | 743 | else throw("Strict value is not equal to itself.") | |
740 | 744 | } | |
741 | 745 | ||
742 | 746 | ||
743 | 747 | ||
744 | - | @Callable( | |
745 | - | func lockRef ( | |
746 | - | let | |
747 | - | let | |
748 | - | let | |
749 | - | let | |
750 | - | let | |
748 | + | @Callable(aO) | |
749 | + | func lockRef (bg,eJ,eK) = { | |
750 | + | let eL = eh(aO, bg) | |
751 | + | let eM = eL._1 | |
752 | + | let eq = eL._2 | |
753 | + | let eN = toString(aO.caller) | |
754 | + | let eO = if (if ((eJ == "")) | |
751 | 755 | then true | |
752 | - | else ( | |
756 | + | else (eK == base58'')) | |
753 | 757 | then unit | |
754 | - | else invoke(A, "createPair", [D, | |
755 | - | if (( | |
758 | + | else invoke(A, "createPair", [D, eJ, eN, eK], nil) | |
759 | + | if ((eO == eO)) | |
756 | 760 | then { | |
757 | - | let | |
758 | - | if (( | |
759 | - | then $Tuple2( | |
761 | + | let eP = invoke(aE, "updateReferralActivity", [toString(aO.caller), eq], nil) | |
762 | + | if ((eP == eP)) | |
763 | + | then $Tuple2(eM, unit) | |
760 | 764 | else throw("Strict value is not equal to itself.") | |
761 | 765 | } | |
762 | 766 | else throw("Strict value is not equal to itself.") | |
764 | 768 | ||
765 | 769 | ||
766 | 770 | ||
767 | - | @Callable( | |
768 | - | func lock ( | |
769 | - | let | |
770 | - | let | |
771 | - | let | |
772 | - | let | |
773 | - | if (( | |
774 | - | then $Tuple2( | |
771 | + | @Callable(aO) | |
772 | + | func lock (bg) = { | |
773 | + | let eQ = eh(aO, bg) | |
774 | + | let eM = eQ._1 | |
775 | + | let eq = eQ._2 | |
776 | + | let eP = invoke(aE, "updateReferralActivity", [toString(aO.caller), eq], nil) | |
777 | + | if ((eP == eP)) | |
778 | + | then $Tuple2(eM, unit) | |
775 | 779 | else throw("Strict value is not equal to itself.") | |
776 | 780 | } | |
777 | 781 | ||
778 | 782 | ||
779 | 783 | ||
780 | - | @Callable( | |
781 | - | func claimWxBoost ( | |
784 | + | @Callable(aO) | |
785 | + | func claimWxBoost (bG,bO) = if ((bR != aO.caller)) | |
782 | 786 | then m("permissions denied") | |
783 | 787 | else { | |
784 | - | let | |
785 | - | let | |
786 | - | let | |
787 | - | let | |
788 | - | $Tuple2( | |
788 | + | let eR = dQ(bG, bO, false) | |
789 | + | let eS = eR._1 | |
790 | + | let ef = eR._2 | |
791 | + | let eg = eR._3 | |
792 | + | $Tuple2(ef, [eS]) | |
789 | 793 | } | |
790 | 794 | ||
791 | 795 | ||
792 | 796 | ||
793 | - | @Callable( | |
794 | - | func claimWxBoostREADONLY ( | |
795 | - | let | |
796 | - | let | |
797 | - | let | |
798 | - | let | |
799 | - | $Tuple2(nil, [ | |
797 | + | @Callable(aO) | |
798 | + | func claimWxBoostREADONLY (bG,bO) = { | |
799 | + | let eT = dQ(bG, bO, true) | |
800 | + | let eS = eT._1 | |
801 | + | let ef = eT._2 | |
802 | + | let eg = eT._3 | |
803 | + | $Tuple2(nil, [eS, eg]) | |
800 | 804 | } | |
801 | 805 | ||
802 | 806 | ||
803 | 807 | ||
804 | - | @Callable( | |
805 | - | func unlock ( | |
806 | - | let | |
807 | - | let | |
808 | - | let | |
809 | - | let | |
808 | + | @Callable(aO) | |
809 | + | func unlock (eU,be) = { | |
810 | + | let aY = aO.caller | |
811 | + | let bO = toString(aY) | |
812 | + | let aZ = fromBase58String(eU) | |
813 | + | let ex = bb(aY, if ((eU == "")) | |
810 | 814 | then unit | |
811 | - | else | |
812 | - | let | |
813 | - | let | |
814 | - | let | |
815 | - | let | |
816 | - | let | |
817 | - | let | |
818 | - | let | |
819 | - | let | |
815 | + | else aZ) | |
816 | + | let ey = parseIntValue(ex[aR]) | |
817 | + | let ck = parseIntValue(ex[aS]) | |
818 | + | let ez = parseIntValue(ex[aT]) | |
819 | + | let eA = (ck + ez) | |
820 | + | let bi = parseIntValue(ex[aW]) | |
821 | + | let bh = parseIntValue(ex[aV]) | |
822 | + | let eB = ((height - ck) / aF) | |
823 | + | let eD = ev(aY, if ((eU == "")) | |
820 | 824 | then unit | |
821 | - | else | |
822 | - | if (( | |
823 | - | then m(("maximum amount to unlock: " + toString( | |
825 | + | else aZ) | |
826 | + | if ((be > eD)) | |
827 | + | then m(("maximum amount to unlock: " + toString(eD))) | |
824 | 828 | else { | |
825 | - | let | |
826 | - | let | |
827 | - | let | |
828 | - | if (( | |
829 | - | then m(("locked gwx amount: " + toString( | |
830 | - | else if ((0 >= | |
829 | + | let eV = max([be, fraction((eB * aF), ey, aD)]) | |
830 | + | let eW = w((bh - eV), "gwxRemaining") | |
831 | + | let eX = cb(aY) | |
832 | + | if ((eX > eW)) | |
833 | + | then m(("locked gwx amount: " + toString(eX))) | |
834 | + | else if ((0 >= ey)) | |
831 | 835 | then m("nothing to unlock") | |
832 | 836 | else { | |
833 | - | let | |
834 | - | let | |
835 | - | let | |
836 | - | if (( | |
837 | - | then (((( | |
837 | + | let er = ca() | |
838 | + | let es = cE(aY) | |
839 | + | let et = reentrantInvoke(bS, "refreshUserReward", [aY.bytes], nil) | |
840 | + | if ((et == et)) | |
841 | + | then ((((cA(aY, aZ, ey, ck, ez, eW, (bi + be)) ++ cn(-(be), 0, 0, 0)) :+ ch("unlock", bO, be, ck, ez, eV, aO)) :+ ScriptTransfer(aY, be, aA)) ++ [IntegerEntry(by(), w((er - eV), "gwxTotal")), IntegerEntry(bc(aY), w((es - eV), "userGwxAmountTotal"))]) | |
838 | 842 | else throw("Strict value is not equal to itself.") | |
839 | 843 | } | |
840 | 844 | } | |
842 | 846 | ||
843 | 847 | ||
844 | 848 | ||
845 | - | @Callable( | |
846 | - | func gwxUserInfoREADONLY ( | |
847 | - | let | |
848 | - | let | |
849 | - | $Tuple2(nil, [ | |
849 | + | @Callable(aO) | |
850 | + | func gwxUserInfoREADONLY (bO) = { | |
851 | + | let aY = valueOrErrorMessage(addressFromString(bO), k("invalid user address")) | |
852 | + | let bh = cE(aY) | |
853 | + | $Tuple2(nil, [bh]) | |
850 | 854 | } | |
851 | 855 | ||
852 | 856 | ||
853 | 857 | ||
854 | - | @Callable( | |
855 | - | func userMaxDurationREADONLY ( | |
858 | + | @Callable(aO) | |
859 | + | func userMaxDurationREADONLY (bO) = $Tuple2(nil, $Tuple2("increaseLock", aD)) | |
856 | 860 | ||
857 | 861 | ||
858 | 862 | ||
859 | - | @Callable( | |
860 | - | func getUserGwxAmountAtHeightREADONLY ( | |
861 | - | let | |
862 | - | let | |
863 | - | $Tuple2(nil, | |
863 | + | @Callable(aO) | |
864 | + | func getUserGwxAmountAtHeightREADONLY (bO,eY) = { | |
865 | + | let aY = valueOrErrorMessage(addressFromString(bO), k("invalid user address")) | |
866 | + | let bh = cE(aY) | |
867 | + | $Tuple2(nil, bh) | |
864 | 868 | } | |
865 | 869 | ||
866 | 870 | ||
867 | 871 | ||
868 | - | @Callable( | |
869 | - | func getUserGwxAmount ( | |
870 | - | let | |
871 | - | let | |
872 | - | $Tuple2(nil, | |
872 | + | @Callable(aO) | |
873 | + | func getUserGwxAmount (bO) = { | |
874 | + | let aY = valueOrErrorMessage(addressFromString(bO), k("invalid user address")) | |
875 | + | let bh = cE(aY) | |
876 | + | $Tuple2(nil, bh) | |
873 | 877 | } | |
874 | 878 | ||
875 | 879 | ||
876 | 880 | ||
877 | - | @Callable( | |
878 | - | func getGwxTotalREADONLY () = $Tuple2(nil, | |
881 | + | @Callable(aO) | |
882 | + | func getGwxTotalREADONLY () = $Tuple2(nil, ca()) | |
879 | 883 | ||
880 | 884 | ||
881 | 885 | ||
882 | - | @Callable( | |
886 | + | @Callable(aO) | |
883 | 887 | func onBoostEmissionUpdate () = { | |
884 | - | let | |
888 | + | let eI = if ((aO.caller == bQ)) | |
885 | 889 | then true | |
886 | - | else | |
887 | - | if (( | |
888 | - | then | |
890 | + | else aN(aO) | |
891 | + | if ((eI == eI)) | |
892 | + | then dF() | |
889 | 893 | else throw("Strict value is not equal to itself.") | |
890 | 894 | } | |
891 | 895 | ||
892 | 896 | ||
893 | 897 | ||
894 | - | @Callable( | |
895 | - | func onStakedVoteUpdate ( | |
896 | - | let | |
898 | + | @Callable(aO) | |
899 | + | func onStakedVoteUpdate (bG,bO,dr) = { | |
900 | + | let eI = if ((aO.caller == bR)) | |
897 | 901 | then true | |
898 | - | else | |
899 | - | if (( | |
902 | + | else aN(aO) | |
903 | + | if ((eI == eI)) | |
900 | 904 | then { | |
901 | - | let | |
902 | - | $Tuple2( | |
905 | + | let du = dq(bG, bO, dr) | |
906 | + | $Tuple2(du, unit) | |
903 | 907 | } | |
904 | 908 | else throw("Strict value is not equal to itself.") | |
905 | 909 | } | |
906 | 910 | ||
907 | 911 | ||
908 | 912 | ||
909 | - | @Callable( | |
910 | - | func getVotingResultStakedREADONLY ( | |
913 | + | @Callable(aO) | |
914 | + | func getVotingResultStakedREADONLY (bG) = $Tuple2(nil, cV(bG)) | |
911 | 915 | ||
912 | 916 | ||
913 | 917 | ||
914 | - | @Callable( | |
915 | - | func getVotingResultStakedIntegralREADONLY ( | |
918 | + | @Callable(aO) | |
919 | + | func getVotingResultStakedIntegralREADONLY (bG) = $Tuple2(nil, cZ(bG)) | |
916 | 920 | ||
917 | 921 | ||
918 | 922 | ||
919 | - | @Callable( | |
920 | - | func getUserVoteFinalizedREADONLY ( | |
923 | + | @Callable(aO) | |
924 | + | func getUserVoteFinalizedREADONLY (bG,bO) = $Tuple2(nil, cO(bG, bO)) | |
921 | 925 | ||
922 | 926 | ||
923 | 927 | ||
924 | - | @Callable( | |
925 | - | func getUserVoteStakedIntegralREADONLY ( | |
928 | + | @Callable(aO) | |
929 | + | func getUserVoteStakedIntegralREADONLY (bG,bO) = $Tuple2(nil, dj(bG, bO)) | |
926 | 930 | ||
927 | 931 | ||
928 | - | @Verifier( | |
929 | - | func | |
930 | - | let | |
931 | - | let | |
932 | - | if ($isInstanceOf( | |
932 | + | @Verifier(eZ) | |
933 | + | func fa () = { | |
934 | + | let fb = { | |
935 | + | let aJ = aL() | |
936 | + | if ($isInstanceOf(aJ, "ByteVector")) | |
933 | 937 | then { | |
934 | - | let | |
935 | - | | |
938 | + | let aQ = aJ | |
939 | + | aQ | |
936 | 940 | } | |
937 | - | else if ($isInstanceOf( | |
938 | - | then | |
941 | + | else if ($isInstanceOf(aJ, "Unit")) | |
942 | + | then eZ.senderPublicKey | |
939 | 943 | else throw("Match error") | |
940 | 944 | } | |
941 | - | sigVerify( | |
945 | + | sigVerify(eZ.bodyBytes, eZ.proofs[0], fb) | |
942 | 946 | } | |
943 | 947 |
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 = 8 | |
7 | 7 | ||
8 | 8 | let c = 100000000 | |
9 | 9 | ||
10 | 10 | let d = c | |
11 | 11 | ||
12 | 12 | let e = "boosting.ride" | |
13 | 13 | ||
14 | 14 | let f = 18 | |
15 | 15 | ||
16 | 16 | let g = 1000000000000000000 | |
17 | 17 | ||
18 | 18 | let h = toBigInt(g) | |
19 | 19 | ||
20 | 20 | let i = 1440 | |
21 | 21 | ||
22 | 22 | let j = 43800 | |
23 | 23 | ||
24 | 24 | func k (l) = makeString([e, ": ", l], "") | |
25 | 25 | ||
26 | 26 | ||
27 | 27 | func m (l) = throw(k(l)) | |
28 | 28 | ||
29 | 29 | ||
30 | 30 | func n (o,p) = valueOrErrorMessage(getString(o, p), k((("mandatory this." + p) + " is not defined"))) | |
31 | 31 | ||
32 | 32 | ||
33 | 33 | func q (o,p) = valueOrElse(getInteger(o, p), 0) | |
34 | 34 | ||
35 | 35 | ||
36 | 36 | func r (o,p,s) = valueOrElse(getInteger(o, p), s) | |
37 | 37 | ||
38 | 38 | ||
39 | 39 | func t (o,p) = valueOrErrorMessage(getInteger(o, p), k((("mandatory this." + p) + " is not defined"))) | |
40 | 40 | ||
41 | 41 | ||
42 | 42 | func u (v) = if ((0 > v)) | |
43 | 43 | then -(v) | |
44 | 44 | else v | |
45 | 45 | ||
46 | 46 | ||
47 | 47 | func w (x,y) = if ((x >= 0)) | |
48 | 48 | then x | |
49 | 49 | else m((valueOrElse(y, "value") + " should be positive")) | |
50 | 50 | ||
51 | 51 | ||
52 | 52 | func z () = makeString(["%s%s", "config", "referralsContractAddress"], a) | |
53 | 53 | ||
54 | 54 | ||
55 | 55 | let A = addressFromStringValue(n(this, z())) | |
56 | 56 | ||
57 | 57 | let B = makeString(["%s%s", "referral", "programName"], a) | |
58 | 58 | ||
59 | 59 | let C = "wxlock" | |
60 | 60 | ||
61 | 61 | let D = valueOrElse(getString(this, B), C) | |
62 | 62 | ||
63 | 63 | func E () = "%s%s__config__factoryAddress" | |
64 | 64 | ||
65 | 65 | ||
66 | 66 | let F = 1 | |
67 | 67 | ||
68 | 68 | let G = 2 | |
69 | 69 | ||
70 | 70 | let H = 3 | |
71 | 71 | ||
72 | 72 | let I = 4 | |
73 | 73 | ||
74 | 74 | let J = 5 | |
75 | 75 | ||
76 | 76 | let K = 6 | |
77 | 77 | ||
78 | 78 | let L = 7 | |
79 | 79 | ||
80 | 80 | let M = 8 | |
81 | 81 | ||
82 | 82 | let N = 9 | |
83 | 83 | ||
84 | 84 | let O = 10 | |
85 | 85 | ||
86 | 86 | let P = 11 | |
87 | 87 | ||
88 | 88 | func Q () = "%s__factoryConfig" | |
89 | 89 | ||
90 | 90 | ||
91 | 91 | func R (S) = makeString(["%s%s%s", S, "mappings__lpAsset2PoolContract"], a) | |
92 | 92 | ||
93 | 93 | ||
94 | 94 | func T (U) = makeString(["%s%s", "poolWeight", U], a) | |
95 | 95 | ||
96 | 96 | ||
97 | 97 | func V (W,X) = ((("%s%s__poolWeight__" + W) + "__") + toString(X)) | |
98 | 98 | ||
99 | 99 | ||
100 | 100 | func Y () = addressFromStringValue(n(this, E())) | |
101 | 101 | ||
102 | 102 | ||
103 | 103 | func Z (aa) = split(n(aa, Q()), a) | |
104 | 104 | ||
105 | 105 | ||
106 | 106 | func ab (ac) = addressFromStringValue(ac[G]) | |
107 | 107 | ||
108 | 108 | ||
109 | 109 | func ad (ac) = addressFromStringValue(ac[J]) | |
110 | 110 | ||
111 | 111 | ||
112 | 112 | func ae (ac) = addressFromStringValue(ac[F]) | |
113 | 113 | ||
114 | 114 | ||
115 | 115 | func af (ac) = addressFromStringValue(ac[O]) | |
116 | 116 | ||
117 | 117 | ||
118 | 118 | func ag () = "%s__managerPublicKey" | |
119 | 119 | ||
120 | 120 | ||
121 | 121 | func ah () = "%s__managerVaultAddress" | |
122 | 122 | ||
123 | 123 | ||
124 | 124 | func ai () = "%s%s__ratePerBlock__current" | |
125 | 125 | ||
126 | 126 | ||
127 | 127 | func aj () = "%s%s__ratePerBlockMax__current" | |
128 | 128 | ||
129 | 129 | ||
130 | 130 | func ak () = "%s%s__emission__startBlock" | |
131 | 131 | ||
132 | 132 | ||
133 | 133 | func al () = "%s%s__boostingV2__startBlock" | |
134 | 134 | ||
135 | 135 | ||
136 | 136 | func am () = "%s%s__boostingV2__integral" | |
137 | 137 | ||
138 | 138 | ||
139 | 139 | func an () = "%s%s__emission__duration" | |
140 | 140 | ||
141 | 141 | ||
142 | 142 | func ao () = "%s%s__emission__endBlock" | |
143 | 143 | ||
144 | 144 | ||
145 | 145 | func ap () = "%s__nextPeriod" | |
146 | 146 | ||
147 | 147 | ||
148 | 148 | func aq () = "%s%s__gwxRewardEmissionPart__startHeight" | |
149 | 149 | ||
150 | 150 | ||
151 | 151 | let ar = 1 | |
152 | 152 | ||
153 | 153 | let as = 2 | |
154 | 154 | ||
155 | 155 | let at = 3 | |
156 | 156 | ||
157 | 157 | let au = 4 | |
158 | 158 | ||
159 | 159 | let av = 5 | |
160 | 160 | ||
161 | - | func aw () = "%s__config" | |
161 | + | let aw = 6 | |
162 | + | ||
163 | + | func ax () = "%s__config" | |
162 | 164 | ||
163 | 165 | ||
164 | - | func | |
166 | + | func ay () = split(n(this, ax()), a) | |
165 | 167 | ||
166 | 168 | ||
167 | - | let | |
169 | + | let az = ay() | |
168 | 170 | ||
169 | - | let | |
171 | + | let aA = fromBase58String(az[ar]) | |
170 | 172 | ||
171 | - | let | |
173 | + | let aB = valueOrErrorMessage(parseInt(az[as]), k("invalid min lock amount")) | |
172 | 174 | ||
173 | - | let | |
175 | + | let aC = valueOrErrorMessage(parseInt(az[at]), k("invalid min lock duration")) | |
174 | 176 | ||
175 | - | let | |
177 | + | let aD = valueOrErrorMessage(parseInt(az[au]), k("invalid max lock duration")) | |
176 | 178 | ||
177 | - | let | |
179 | + | let aE = valueOrErrorMessage(addressFromString(az[av]), k("invalid math contract address")) | |
178 | 180 | ||
179 | - | func aE (az,aA,aB,aC,aD) = makeString(["%s%d%d%d%s", az, aA, aB, aC, aD], a) | |
181 | + | let aF = valueOrErrorMessage(parseInt(az[aw]), k("invalid blocks in period")) | |
182 | + | ||
183 | + | func aG (aA,aB,aC,aD,aE) = makeString(["%s%d%d%d%s", aA, aB, aC, aD, aE], a) | |
180 | 184 | ||
181 | 185 | ||
182 | - | func | |
186 | + | func aH (aA,aB,aC,aD,aE) = aG(aA, toString(aB), toString(aC), toString(aD), aE) | |
183 | 187 | ||
184 | 188 | ||
185 | - | func | |
186 | - | let | |
187 | - | if ($isInstanceOf( | |
189 | + | func aI () = { | |
190 | + | let aJ = getString(ah()) | |
191 | + | if ($isInstanceOf(aJ, "String")) | |
188 | 192 | then { | |
189 | - | let | |
190 | - | addressFromStringValue( | |
193 | + | let aK = aJ | |
194 | + | addressFromStringValue(aK) | |
191 | 195 | } | |
192 | 196 | else this | |
193 | 197 | } | |
194 | 198 | ||
195 | 199 | ||
196 | - | func | |
197 | - | let | |
198 | - | let | |
199 | - | if ($isInstanceOf( | |
200 | + | func aL () = { | |
201 | + | let aM = aI() | |
202 | + | let aJ = getString(aM, ag()) | |
203 | + | if ($isInstanceOf(aJ, "String")) | |
200 | 204 | then { | |
201 | - | let | |
202 | - | fromBase58String( | |
205 | + | let aK = aJ | |
206 | + | fromBase58String(aK) | |
203 | 207 | } | |
204 | - | else if ($isInstanceOf( | |
208 | + | else if ($isInstanceOf(aJ, "Unit")) | |
205 | 209 | then unit | |
206 | 210 | else throw("Match error") | |
207 | 211 | } | |
208 | 212 | ||
209 | 213 | ||
210 | - | func | |
211 | - | let | |
212 | - | let | |
213 | - | if ($isInstanceOf( | |
214 | + | func aN (aO) = { | |
215 | + | let aP = m("Permission denied") | |
216 | + | let aJ = aL() | |
217 | + | if ($isInstanceOf(aJ, "ByteVector")) | |
214 | 218 | then { | |
215 | - | let | |
216 | - | if (( | |
219 | + | let aQ = aJ | |
220 | + | if ((aO.callerPublicKey == aQ)) | |
217 | 221 | then true | |
218 | - | else | |
222 | + | else aP | |
219 | 223 | } | |
220 | - | else if ($isInstanceOf( | |
221 | - | then if (( | |
224 | + | else if ($isInstanceOf(aJ, "Unit")) | |
225 | + | then if ((aO.caller == this)) | |
222 | 226 | then true | |
223 | - | else | |
227 | + | else aP | |
224 | 228 | else throw("Match error") | |
225 | 229 | } | |
226 | 230 | ||
227 | 231 | ||
228 | - | let | |
232 | + | let aR = 1 | |
229 | 233 | ||
230 | - | let | |
234 | + | let aS = 2 | |
231 | 235 | ||
232 | - | let | |
236 | + | let aT = 3 | |
233 | 237 | ||
234 | - | let | |
238 | + | let aU = 4 | |
235 | 239 | ||
236 | - | let | |
240 | + | let aV = 5 | |
237 | 241 | ||
238 | - | let | |
242 | + | let aW = 6 | |
239 | 243 | ||
240 | - | func | |
241 | - | let | |
242 | - | if ($isInstanceOf( | |
244 | + | func aX (aY,aZ) = makeString(["%s%s%s__lock", toString(aY), { | |
245 | + | let aJ = aZ | |
246 | + | if ($isInstanceOf(aJ, "ByteVector")) | |
243 | 247 | then { | |
244 | - | let | |
245 | - | toBase58String( | |
248 | + | let ba = aJ | |
249 | + | toBase58String(ba) | |
246 | 250 | } | |
247 | - | else if ($isInstanceOf( | |
251 | + | else if ($isInstanceOf(aJ, "Unit")) | |
248 | 252 | then "legacy" | |
249 | 253 | else throw("Match error") | |
250 | 254 | }], a) | |
251 | 255 | ||
252 | 256 | ||
253 | - | func | |
257 | + | func bb (aY,aZ) = split(n(this, aX(aY, aZ)), a) | |
254 | 258 | ||
255 | 259 | ||
256 | - | func | |
260 | + | func bc (aY) = makeString(["%s%s__gwxAmountTotal", toString(aY)], a) | |
257 | 261 | ||
258 | 262 | ||
259 | - | func | |
263 | + | func bd (be,bf,bg,bh,bi) = makeString(["%d%d%d%d%d%d%d", toString(be), toString(bf), toString(bg), toString(lastBlock.timestamp), toString(bh), toString(bi)], a) | |
260 | 264 | ||
261 | 265 | ||
262 | - | func | |
266 | + | func bj () = "%s__nextUserNum" | |
263 | 267 | ||
264 | 268 | ||
265 | - | func | |
269 | + | func bk (aY) = makeString(["%s%s%s__mapping__user2num", aY], a) | |
266 | 270 | ||
267 | 271 | ||
268 | - | func | |
272 | + | func bl (X) = makeString(["%s%s%s__mapping__num2user", X], a) | |
269 | 273 | ||
270 | 274 | ||
271 | - | func | |
275 | + | func bm () = "%s%s__stats__activeTotalLocked" | |
272 | 276 | ||
273 | 277 | ||
274 | - | func | |
278 | + | func bn () = "%s%s__stats__locksDurationSumInBlocks" | |
275 | 279 | ||
276 | 280 | ||
277 | - | func | |
281 | + | func bo () = "%s%s__stats__locksCount" | |
278 | 282 | ||
279 | 283 | ||
280 | - | func | |
284 | + | func bp () = "%s%s__stats__activeUsersCount" | |
281 | 285 | ||
282 | 286 | ||
283 | - | func | |
287 | + | func bq (br) = makeString(["%s%d__userBoostEmissionLastIntV2", toString(br)], a) | |
284 | 288 | ||
285 | 289 | ||
286 | - | func | |
290 | + | func bs (br,bt) = makeString(["%s%d__userBoostEmissionLastIntV2", toString(br), bt], a) | |
287 | 291 | ||
288 | 292 | ||
289 | - | func | |
293 | + | func bu (br) = makeString(["%s%d__maxBoostInt", toString(br)], a) | |
290 | 294 | ||
291 | 295 | ||
292 | - | func | |
296 | + | func bv () = "%s%s__maxBoostInt__total" | |
293 | 297 | ||
294 | 298 | ||
295 | - | func | |
299 | + | func bw (br) = makeString(["%s%d__userBoostAvaliableToClaimTotal", toString(br)], a) | |
296 | 300 | ||
297 | 301 | ||
298 | - | func | |
302 | + | func bx (br) = makeString(["%s%d__userBoostClaimed", toString(br)], a) | |
299 | 303 | ||
300 | 304 | ||
301 | - | func | |
305 | + | func by () = "%s%s__gwx__total" | |
302 | 306 | ||
303 | 307 | ||
304 | - | func | |
308 | + | func bz (bA,bB,o,bC) = makeString(["%s%s%s%s%d", "vote", bA, bB, toString(o), toString(bC)], a) | |
305 | 309 | ||
306 | 310 | ||
307 | - | func | |
311 | + | func bD (bC) = makeString(["%s%d", "startHeight", toString(bC)], a) | |
308 | 312 | ||
309 | 313 | ||
310 | - | func | |
314 | + | func bE () = makeString(["%s", "currentEpochUi"], a) | |
311 | 315 | ||
312 | 316 | ||
313 | - | func | |
317 | + | func bF (bG,bC) = makeString(["%s%s%d", "votingResultStaked", bG, toString(bC)], a) | |
314 | 318 | ||
315 | 319 | ||
316 | - | func | |
320 | + | func bH (bG,bC) = makeString(["%s%s%d", "votingResultStakedIntegral", bG, toString(bC)], a) | |
317 | 321 | ||
318 | 322 | ||
319 | - | func | |
323 | + | func bI (bG,bC) = makeString(["%s%s%d", "votingResultStakedIntegralLastUpdateHeight", bG, toString(bC)], a) | |
320 | 324 | ||
321 | 325 | ||
322 | - | func | |
326 | + | func bJ (bG,o,bC) = makeString(["%s%s%s%d", "votingResultStakedIntegralLast", bG, toString(o), toString(bC)], a) | |
323 | 327 | ||
324 | 328 | ||
325 | - | func | |
329 | + | func bK (bG,o,bC) = makeString(["%s%s%s%d", "voteStakedIntegral", bG, toString(o), toString(bC)], a) | |
326 | 330 | ||
327 | 331 | ||
328 | - | func | |
332 | + | func bL (bG,o,bC) = makeString(["%s%s%s%d", "voteStakedIntegralLastUpdateHeight", bG, toString(o), toString(bC)], a) | |
329 | 333 | ||
330 | 334 | ||
331 | - | func | |
335 | + | func bM (bG,o,bC) = makeString(["%s%s%s%d", "voteStakedIntegralLast", bG, toString(o), toString(bC)], a) | |
332 | 336 | ||
333 | 337 | ||
334 | - | func | |
338 | + | func bN (bO,bG) = makeString(["%s%s%s", "staked", bO, bG], a) | |
335 | 339 | ||
336 | 340 | ||
337 | - | let | |
341 | + | let bP = Y() | |
338 | 342 | ||
339 | - | let ac = Z( | |
343 | + | let ac = Z(bP) | |
340 | 344 | ||
341 | - | let | |
345 | + | let bQ = ad(ac) | |
342 | 346 | ||
343 | - | let | |
347 | + | let bR = ae(ac) | |
344 | 348 | ||
345 | - | let | |
349 | + | let bS = af(ac) | |
346 | 350 | ||
347 | - | let | |
351 | + | let bT = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(makeString(["%s", "lpStakingPoolsContract"], a)), k("lp_staking_pools contract address is undefined"))), k("invalid lp_staking_pools contract address")) | |
348 | 352 | ||
349 | - | let | |
353 | + | let bU = makeString(["%s", "votingEmissionContract"], a) | |
350 | 354 | ||
351 | - | let | |
355 | + | let bV = addressFromStringValue(getStringValue(bP, bU)) | |
352 | 356 | ||
353 | - | let | |
357 | + | let bW = makeString(["%s", "votingEmissionRateContract"], a) | |
354 | 358 | ||
355 | - | let | |
356 | - | let | |
357 | - | if ($isInstanceOf( | |
358 | - | then | |
359 | - | else throw(($getType( | |
359 | + | let bX = { | |
360 | + | let bY = invoke(bQ, "getBoostCoeffREADONLY", nil, nil) | |
361 | + | if ($isInstanceOf(bY, "Int")) | |
362 | + | then bY | |
363 | + | else throw(($getType(bY) + " couldn't be cast to Int")) | |
360 | 364 | } | |
361 | 365 | ||
362 | - | func | |
363 | - | let | |
364 | - | if ($isInstanceOf( | |
366 | + | func bZ (aY) = { | |
367 | + | let aJ = getString(this, bk(toString(aY))) | |
368 | + | if ($isInstanceOf(aJ, "String")) | |
365 | 369 | then { | |
366 | - | let | |
367 | - | valueOrErrorMessage(parseInt( | |
370 | + | let aK = aJ | |
371 | + | valueOrErrorMessage(parseInt(aK), k("invalid user number")) | |
368 | 372 | } | |
369 | - | else if ($isInstanceOf( | |
373 | + | else if ($isInstanceOf(aJ, "Unit")) | |
370 | 374 | then m("invalid user") | |
371 | 375 | else throw("Match error") | |
372 | 376 | } | |
373 | 377 | ||
374 | 378 | ||
375 | - | func | |
379 | + | func ca () = valueOrElse(getInteger(this, by()), 0) | |
376 | 380 | ||
377 | 381 | ||
378 | - | func | |
379 | - | let | |
380 | - | let | |
381 | - | let | |
382 | - | if ($isInstanceOf( | |
382 | + | func cb (aY) = { | |
383 | + | let cc = "getLockedGwxAmount" | |
384 | + | let cd = valueOrErrorMessage({ | |
385 | + | let aJ = getString(bV, bW) | |
386 | + | if ($isInstanceOf(aJ, "Unit")) | |
383 | 387 | then unit | |
384 | - | else if ($isInstanceOf( | |
388 | + | else if ($isInstanceOf(aJ, "String")) | |
385 | 389 | then { | |
386 | - | let | |
387 | - | addressFromString( | |
390 | + | let aK = aJ | |
391 | + | addressFromString(aK) | |
388 | 392 | } | |
389 | 393 | else throw("Match error") | |
390 | 394 | }, k("invalid voting emission rate address")) | |
391 | - | let | |
392 | - | let | |
393 | - | if ($isInstanceOf( | |
394 | - | then | |
395 | - | else throw(($getType( | |
395 | + | let ce = { | |
396 | + | let bY = invoke(bV, cc, [toString(aY)], nil) | |
397 | + | if ($isInstanceOf(bY, "Int")) | |
398 | + | then bY | |
399 | + | else throw(($getType(bY) + " couldn't be cast to Int")) | |
396 | 400 | } | |
397 | - | let | |
398 | - | let | |
399 | - | if ($isInstanceOf( | |
400 | - | then | |
401 | - | else throw(($getType( | |
401 | + | let cf = { | |
402 | + | let bY = invoke(cd, cc, [toString(aY)], nil) | |
403 | + | if ($isInstanceOf(bY, "Int")) | |
404 | + | then bY | |
405 | + | else throw(($getType(bY) + " couldn't be cast to Int")) | |
402 | 406 | } | |
403 | - | let | |
404 | - | | |
407 | + | let cg = max([ce, cf]) | |
408 | + | cg | |
405 | 409 | } | |
406 | 410 | ||
407 | 411 | ||
408 | - | func | |
409 | - | let | |
410 | - | let | |
411 | - | StringEntry( | |
412 | + | func ch (ci,cj,be,ck,bg,bh,aO) = { | |
413 | + | let cl = makeString(["%s%s%s%s__history", ci, cj, toBase58String(aO.transactionId)], a) | |
414 | + | let cm = makeString(["%d%d%d%d%d%d%d", toString(lastBlock.height), toString(lastBlock.timestamp), toString(be), toString(ck), toString(bg), toString(bh)], a) | |
415 | + | StringEntry(cl, cm) | |
412 | 416 | } | |
413 | 417 | ||
414 | 418 | ||
415 | - | func cl (cm,cn,co,cp) = { | |
416 | - | let cq = bl() | |
417 | - | let cr = bm() | |
419 | + | func cn (co,cp,cq,cr) = { | |
418 | 420 | let cs = bn() | |
419 | - | let ct = | |
420 | - | let cu = | |
421 | - | let cv = | |
421 | + | let ct = bo() | |
422 | + | let cu = bp() | |
423 | + | let cv = bm() | |
422 | 424 | let cw = q(this, cs) | |
423 | 425 | let cx = q(this, ct) | |
424 | - | [IntegerEntry(cq, (cu + cn)), IntegerEntry(cr, (cv + co)), IntegerEntry(cs, (cw + cp)), IntegerEntry(ct, (cx + cm))] | |
426 | + | let cy = q(this, cu) | |
427 | + | let cz = q(this, cv) | |
428 | + | [IntegerEntry(cs, (cw + cp)), IntegerEntry(ct, (cx + cq)), IntegerEntry(cu, (cy + cr)), IntegerEntry(cv, (cz + co))] | |
425 | 429 | } | |
426 | 430 | ||
427 | 431 | ||
428 | - | func | |
432 | + | func cA (aY,aZ,be,bf,bg,bh,bi) = [StringEntry(aX(aY, aZ), bd(be, bf, bg, bh, bi))] | |
429 | 433 | ||
430 | 434 | ||
431 | - | func | |
435 | + | func cB (aO,cC) = if ((size(aO.payments) > 1)) | |
432 | 436 | then m("only one payment is allowed") | |
433 | - | else if ((size( | |
437 | + | else if ((size(aO.payments) == 0)) | |
434 | 438 | then 0 | |
435 | 439 | else { | |
436 | - | let | |
437 | - | if ((value( | |
440 | + | let cD = aO.payments[0] | |
441 | + | if ((value(cD.assetId) != cC)) | |
438 | 442 | then m("invalid asset id in payment") | |
439 | - | else | |
443 | + | else cD.amount | |
440 | 444 | } | |
441 | 445 | ||
442 | 446 | ||
443 | - | func | |
447 | + | func cE (aY) = valueOrElse(getInteger(this, bc(aY)), 0) | |
444 | 448 | ||
445 | 449 | ||
446 | - | func | |
447 | - | let | |
448 | - | let | |
449 | - | let | |
450 | - | if ((0 > | |
450 | + | func cF () = { | |
451 | + | let cG = { | |
452 | + | let cH = value(getInteger(bV, bE())) | |
453 | + | let cI = (cH - 1) | |
454 | + | if ((0 > cI)) | |
451 | 455 | then m("invalid epoch") | |
452 | - | else $Tuple2( | |
456 | + | else $Tuple2(cH, cI) | |
453 | 457 | } | |
454 | - | let | |
455 | - | let | |
456 | - | let | |
457 | - | $Tuple2( | |
458 | + | let cH = cG._1 | |
459 | + | let cI = cG._2 | |
460 | + | let cJ = value(getInteger(bV, bD(cH))) | |
461 | + | $Tuple2(cI, cJ) | |
458 | 462 | } | |
459 | 463 | ||
460 | 464 | ||
461 | - | func | |
462 | - | let | |
463 | - | let | |
464 | - | let | |
465 | - | let | |
466 | - | if ($isInstanceOf( | |
467 | - | then | |
468 | - | else throw(($getType( | |
465 | + | func cK (bG) = { | |
466 | + | let cL = 4 | |
467 | + | let cM = 5 | |
468 | + | let cN = { | |
469 | + | let bY = invoke(bP, "getPoolConfigByLpAssetIdREADONLY", [bG], nil) | |
470 | + | if ($isInstanceOf(bY, "List[Any]")) | |
471 | + | then bY | |
472 | + | else throw(($getType(bY) + " couldn't be cast to List[Any]")) | |
469 | 473 | } | |
470 | - | let | |
471 | - | let | |
472 | - | if ($isInstanceOf( | |
473 | - | then | |
474 | - | else throw(($getType( | |
474 | + | let bA = { | |
475 | + | let bY = cN[cL] | |
476 | + | if ($isInstanceOf(bY, "String")) | |
477 | + | then bY | |
478 | + | else throw(($getType(bY) + " couldn't be cast to String")) | |
475 | 479 | } | |
476 | - | let | |
477 | - | let | |
478 | - | if ($isInstanceOf( | |
479 | - | then | |
480 | - | else throw(($getType( | |
480 | + | let bB = { | |
481 | + | let bY = cN[cM] | |
482 | + | if ($isInstanceOf(bY, "String")) | |
483 | + | then bY | |
484 | + | else throw(($getType(bY) + " couldn't be cast to String")) | |
481 | 485 | } | |
482 | - | $Tuple2( | |
486 | + | $Tuple2(bA, bB) | |
483 | 487 | } | |
484 | 488 | ||
485 | 489 | ||
486 | - | func | |
487 | - | let | |
488 | - | let | |
489 | - | let | |
490 | - | let | |
491 | - | let | |
492 | - | let | |
493 | - | let | |
494 | - | let | |
495 | - | let | |
496 | - | | |
490 | + | func cO (bG,bO) = { | |
491 | + | let aY = addressFromStringValue(bO) | |
492 | + | let cP = cF() | |
493 | + | let cI = cP._1 | |
494 | + | let cJ = cP._2 | |
495 | + | let cQ = cK(bG) | |
496 | + | let bA = cQ._1 | |
497 | + | let bB = cQ._2 | |
498 | + | let cR = bz(bA, bB, aY, cI) | |
499 | + | let cS = valueOrElse(getInteger(bV, cR), 0) | |
500 | + | cS | |
497 | 501 | } | |
498 | 502 | ||
499 | 503 | ||
500 | - | func | |
501 | - | let | |
502 | - | let | |
503 | - | if (( | |
504 | + | func cT (bG,bO) = { | |
505 | + | let cU = valueOrElse(getInteger(bR, bN(bO, bG)), 0) | |
506 | + | let cS = cO(bG, bO) | |
507 | + | if ((cU == 0)) | |
504 | 508 | then 0 | |
505 | - | else | |
509 | + | else cS | |
506 | 510 | } | |
507 | 511 | ||
508 | 512 | ||
509 | - | func | |
510 | - | let | |
511 | - | let | |
512 | - | let | |
513 | - | let | |
514 | - | let | |
515 | - | | |
513 | + | func cV (bG) = { | |
514 | + | let cW = cF() | |
515 | + | let cI = cW._1 | |
516 | + | let cJ = cW._2 | |
517 | + | let cX = valueOrElse(getInteger(bV, bF(bG, cI)), 0) | |
518 | + | let cY = valueOrElse(getInteger(this, bF(bG, cI)), cX) | |
519 | + | cY | |
516 | 520 | } | |
517 | 521 | ||
518 | 522 | ||
519 | - | func | |
520 | - | let | |
521 | - | let | |
522 | - | let | |
523 | - | let | |
524 | - | let | |
525 | - | let | |
526 | - | let | |
527 | - | let | |
528 | - | | |
523 | + | func cZ (bG) = { | |
524 | + | let da = cF() | |
525 | + | let cI = da._1 | |
526 | + | let cJ = da._2 | |
527 | + | let cY = cV(bG) | |
528 | + | let db = valueOrElse(getInteger(this, bH(bG, cI)), 0) | |
529 | + | let dc = valueOrElse(getInteger(this, bI(bG, cI)), cJ) | |
530 | + | let dd = (height - dc) | |
531 | + | let de = ((dd * cY) + db) | |
532 | + | de | |
529 | 533 | } | |
530 | 534 | ||
531 | 535 | ||
532 | - | func | |
533 | - | let | |
534 | - | let | |
535 | - | let | |
536 | - | let | |
537 | - | let | |
538 | - | let | |
539 | - | [IntegerEntry( | |
536 | + | func df (bG,dg) = { | |
537 | + | let dh = cF() | |
538 | + | let cI = dh._1 | |
539 | + | let cJ = dh._2 | |
540 | + | let cY = cV(bG) | |
541 | + | let di = (cY + dg) | |
542 | + | let de = cZ(bG) | |
543 | + | [IntegerEntry(bF(bG, cI), di), IntegerEntry(bI(bG, cI), height), IntegerEntry(bH(bG, cI), de)] | |
540 | 544 | } | |
541 | 545 | ||
542 | 546 | ||
543 | - | func | |
544 | - | let | |
545 | - | let | |
546 | - | let | |
547 | - | let | |
548 | - | let | |
549 | - | let | |
550 | - | let | |
551 | - | let | |
552 | - | let | |
553 | - | | |
547 | + | func dj (bG,bO) = { | |
548 | + | let dk = cF() | |
549 | + | let cI = dk._1 | |
550 | + | let cJ = dk._2 | |
551 | + | let aY = addressFromStringValue(bO) | |
552 | + | let dl = cT(bG, bO) | |
553 | + | let dm = valueOrElse(getInteger(this, bK(bG, aY, cI)), 0) | |
554 | + | let dn = valueOrElse(getInteger(this, bL(bG, aY, cI)), cJ) | |
555 | + | let do = (height - dn) | |
556 | + | let dp = ((do * dl) + dm) | |
557 | + | dp | |
554 | 558 | } | |
555 | 559 | ||
556 | 560 | ||
557 | - | func | |
558 | - | let | |
559 | - | let | |
560 | - | let | |
561 | - | let | |
562 | - | let | |
563 | - | let | |
561 | + | func dq (bG,bO,dr) = { | |
562 | + | let ds = cF() | |
563 | + | let cI = ds._1 | |
564 | + | let cJ = ds._2 | |
565 | + | let aY = addressFromStringValue(bO) | |
566 | + | let dt = cO(bG, bO) | |
567 | + | let du = if ((dt == 0)) | |
564 | 568 | then nil | |
565 | 569 | else { | |
566 | - | let | |
567 | - | then | |
568 | - | else -( | |
569 | - | let | |
570 | - | let | |
571 | - | let | |
572 | - | ( | |
570 | + | let dg = if (dr) | |
571 | + | then dt | |
572 | + | else -(dt) | |
573 | + | let dv = df(bG, dg) | |
574 | + | let dp = dj(bG, bO) | |
575 | + | let dw = [IntegerEntry(bL(bG, aY, cI), height), IntegerEntry(bK(bG, aY, cI), dp)] | |
576 | + | (dv ++ dw) | |
573 | 577 | } | |
574 | - | | |
578 | + | du | |
575 | 579 | } | |
576 | 580 | ||
577 | 581 | ||
578 | - | func dv (bE,bM) = { | |
579 | - | let dw = cD() | |
580 | - | let cG = dw._1 | |
581 | - | let cH = dw._2 | |
582 | - | let aW = addressFromStringValue(bM) | |
583 | - | let dx = bK(bE, aW, cG) | |
584 | - | let dy = valueOrElse(getInteger(this, dx), 0) | |
585 | - | let dz = bH(bE, aW, cG) | |
582 | + | func dx (bG,bO) = { | |
583 | + | let dy = cF() | |
584 | + | let cI = dy._1 | |
585 | + | let cJ = dy._2 | |
586 | + | let aY = addressFromStringValue(bO) | |
587 | + | let dz = bM(bG, aY, cI) | |
586 | 588 | let dA = valueOrElse(getInteger(this, dz), 0) | |
587 | - | let dn = dh(bE, bM) | |
588 | - | let dc = cX(bE) | |
589 | - | let dB = (dn - dy) | |
590 | - | let dC = (dc - dA) | |
591 | - | $Tuple3([IntegerEntry(dx, dn), IntegerEntry(dz, dc)], dB, dC) | |
589 | + | let dB = bJ(bG, aY, cI) | |
590 | + | let dC = valueOrElse(getInteger(this, dB), 0) | |
591 | + | let dp = dj(bG, bO) | |
592 | + | let de = cZ(bG) | |
593 | + | let dD = (dp - dA) | |
594 | + | let dE = (de - dC) | |
595 | + | $Tuple3([IntegerEntry(dz, dp), IntegerEntry(dB, de)], dD, dE) | |
592 | 596 | } | |
593 | 597 | ||
594 | 598 | ||
595 | - | func | |
596 | - | let | |
597 | - | let | |
598 | - | let | |
599 | - | let | |
600 | - | let | |
601 | - | then | |
599 | + | func dF () = { | |
600 | + | let dG = t(bQ, ai()) | |
601 | + | let dH = getInteger(this, al()) | |
602 | + | let dI = getInteger(this, am()) | |
603 | + | let dJ = t(bQ, ao()) | |
604 | + | let dK = if ((height > dJ)) | |
605 | + | then dJ | |
602 | 606 | else height | |
603 | - | let | |
604 | - | let | |
605 | - | if ($isInstanceOf( | |
607 | + | let dL = { | |
608 | + | let aJ = dH | |
609 | + | if ($isInstanceOf(aJ, "Int")) | |
606 | 610 | then { | |
607 | - | let | |
608 | - | max([( | |
611 | + | let dM = aJ | |
612 | + | max([(dK - dM), 0]) | |
609 | 613 | } | |
610 | - | else if ($isInstanceOf( | |
614 | + | else if ($isInstanceOf(aJ, "Unit")) | |
611 | 615 | then 0 | |
612 | 616 | else throw("Match error") | |
613 | 617 | } | |
614 | - | let | |
615 | - | let | |
616 | - | let | |
617 | - | $Tuple2([IntegerEntry(am(), | |
618 | + | let dN = ((dG * (bX - 1)) / bX) | |
619 | + | let dO = valueOrElse(dI, 0) | |
620 | + | let dP = ((dN * dL) + dO) | |
621 | + | $Tuple2([IntegerEntry(am(), dP), IntegerEntry(al(), height)], dP) | |
618 | 622 | } | |
619 | 623 | ||
620 | 624 | ||
621 | - | func | |
622 | - | let | |
623 | - | let | |
624 | - | if (( | |
625 | + | func dQ (bG,bO,dR) = { | |
626 | + | let aY = valueOrErrorMessage(addressFromString(bO), k("invalid user address")) | |
627 | + | let br = bZ(aY) | |
628 | + | if ((br == br)) | |
625 | 629 | then { | |
626 | - | let | |
627 | - | let | |
630 | + | let dS = "empty" | |
631 | + | let dT = if ((bG != dS)) | |
628 | 632 | then { | |
629 | - | let | |
630 | - | getIntegerValue( | |
633 | + | let dU = valueOrErrorMessage(getString(bP, R(bG)), k(("unsupported lp asset " + bG))) | |
634 | + | getIntegerValue(bP, T(dU)) | |
631 | 635 | } | |
632 | - | else if ( | |
636 | + | else if (dR) | |
633 | 637 | then 0 | |
634 | - | else m(("not readonly mode: unsupported lp asset " + | |
635 | - | let | |
636 | - | let | |
637 | - | let | |
638 | - | let | |
639 | - | let | |
640 | - | if ((0 > | |
638 | + | else m(("not readonly mode: unsupported lp asset " + bG)) | |
639 | + | let dV = bs(br, bG) | |
640 | + | let dW = bq(br) | |
641 | + | let dX = valueOrElse(getInteger(this, dV), q(this, dW)) | |
642 | + | let dP = dF()._2 | |
643 | + | let dY = (dP - dX) | |
644 | + | if ((0 > dY)) | |
641 | 645 | then m("wrong calculations") | |
642 | 646 | else { | |
643 | - | let | |
644 | - | let | |
645 | - | let | |
646 | - | let | |
647 | - | let | |
648 | - | let | |
647 | + | let dZ = dx(bG, bO) | |
648 | + | let ea = dZ._1 | |
649 | + | let eb = dZ._2 | |
650 | + | let ec = dZ._3 | |
651 | + | let ed = fraction(dY, dT, d) | |
652 | + | let ee = if ((ec == 0)) | |
649 | 653 | then 0 | |
650 | - | else fraction(eb, | |
651 | - | let | |
652 | - | let | |
653 | - | $Tuple3( | |
654 | + | else fraction(ed, eb, ec) | |
655 | + | let ef = ([IntegerEntry(dV, dP)] ++ ea) | |
656 | + | let eg = makeString([toString(dX), toString(dY), toString(dT), toString(eb), toString(ec)], ":") | |
657 | + | $Tuple3(ee, ef, eg) | |
654 | 658 | } | |
655 | 659 | } | |
656 | 660 | else throw("Strict value is not equal to itself.") | |
657 | 661 | } | |
658 | 662 | ||
659 | 663 | ||
660 | - | func | |
661 | - | let | |
662 | - | if (!(containsElement( | |
664 | + | func eh (aO,ei) = { | |
665 | + | let ej = [1, 3, 6, 12, 24, 48] | |
666 | + | if (!(containsElement(ej, ei))) | |
663 | 667 | then m("invalid duration") | |
664 | 668 | else { | |
665 | - | let | |
666 | - | let | |
667 | - | if ((size( | |
669 | + | let bg = (ei * j) | |
670 | + | let ek = toBase58String(aA) | |
671 | + | if ((size(aO.payments) != 1)) | |
668 | 672 | then m("invalid payment - exact one payment must be attached") | |
669 | 673 | else { | |
670 | - | let | |
671 | - | let | |
672 | - | if (( | |
673 | - | then m((("invalid asset is in payment - " + | |
674 | + | let cD = aO.payments[0] | |
675 | + | let el = cD.amount | |
676 | + | if ((aA != value(cD.assetId))) | |
677 | + | then m((("invalid asset is in payment - " + ek) + " is expected")) | |
674 | 678 | else { | |
675 | - | let | |
676 | - | let | |
677 | - | let | |
678 | - | let | |
679 | - | let | |
680 | - | then value(getString( | |
681 | - | else toString(t(this, | |
682 | - | let | |
683 | - | let | |
684 | - | if (if (( | |
685 | - | then ( | |
679 | + | let em = bj() | |
680 | + | let aY = aO.caller | |
681 | + | let bO = toString(aY) | |
682 | + | let en = isDefined(getString(bk(bO))) | |
683 | + | let eo = if (en) | |
684 | + | then value(getString(bk(bO))) | |
685 | + | else toString(t(this, em)) | |
686 | + | let br = parseIntValue(eo) | |
687 | + | let ck = height | |
688 | + | if (if ((aB > el)) | |
689 | + | then (aY != bT) | |
686 | 690 | else false) | |
687 | - | then m(("amount is less then minLockAmount=" + toString( | |
688 | - | else if (( | |
689 | - | then m(("passed duration is less then minLockDuration=" + toString( | |
690 | - | else if (( | |
691 | - | then m(("passed duration is greater then maxLockDuration=" + toString( | |
691 | + | then m(("amount is less then minLockAmount=" + toString(aB))) | |
692 | + | else if ((aC > bg)) | |
693 | + | then m(("passed duration is less then minLockDuration=" + toString(aC))) | |
694 | + | else if ((bg > aD)) | |
695 | + | then m(("passed duration is greater then maxLockDuration=" + toString(aD))) | |
692 | 696 | else { | |
693 | - | let | |
694 | - | let | |
695 | - | let | |
696 | - | let | |
697 | - | let | |
698 | - | let | |
699 | - | let | |
700 | - | if (( | |
697 | + | let ep = fraction(bg, c, aD) | |
698 | + | let eq = fraction(el, ep, c) | |
699 | + | let er = ca() | |
700 | + | let dW = bq(br) | |
701 | + | let dP = dF()._2 | |
702 | + | let es = cE(aY) | |
703 | + | let et = reentrantInvoke(bS, "refreshUserReward", [aY.bytes], nil) | |
704 | + | if ((et == et)) | |
701 | 705 | then { | |
702 | - | let | |
706 | + | let eu = if (en) | |
703 | 707 | then nil | |
704 | - | else [IntegerEntry( | |
705 | - | $Tuple2((((( | |
708 | + | else [IntegerEntry(em, (br + 1)), StringEntry(bk(bO), eo), StringEntry(bl(eo), bO)] | |
709 | + | $Tuple2(((((eu ++ cA(aY, aO.transactionId, el, ck, bg, eq, 0)) ++ cn(el, bg, 1, if (en) | |
706 | 710 | then 0 | |
707 | - | else 1)) :+ | |
711 | + | else 1)) :+ ch("lock", bO, el, ck, bg, eq, aO)) ++ [IntegerEntry(dW, dP), IntegerEntry(by(), (er + eq)), IntegerEntry(bc(aY), (es + eq))]), eq) | |
708 | 712 | } | |
709 | 713 | else throw("Strict value is not equal to itself.") | |
710 | 714 | } | |
711 | 715 | } | |
712 | 716 | } | |
713 | 717 | } | |
714 | 718 | } | |
715 | 719 | ||
716 | 720 | ||
717 | - | func | |
718 | - | let | |
719 | - | let | |
720 | - | let | |
721 | - | let | |
722 | - | let | |
723 | - | let | |
724 | - | let | |
725 | - | let | |
726 | - | let | |
727 | - | let | |
728 | - | then ( | |
729 | - | else toInt(fraction(toBigInt( | |
730 | - | | |
721 | + | func ev (aY,ew) = { | |
722 | + | let ex = bb(aY, ew) | |
723 | + | let ey = parseIntValue(ex[aR]) | |
724 | + | let ck = parseIntValue(ex[aS]) | |
725 | + | let ez = parseIntValue(ex[aT]) | |
726 | + | let eA = (ck + ez) | |
727 | + | let bi = parseIntValue(ex[aW]) | |
728 | + | let bh = parseIntValue(ex[aV]) | |
729 | + | let eB = ((height - ck) / aF) | |
730 | + | let eC = fraction(toBigInt(eB), (toBigInt((8 * aF)) * h), toBigInt(ez)) | |
731 | + | let eD = if ((height > eA)) | |
732 | + | then (ey - bi) | |
733 | + | else toInt(fraction(toBigInt(ey), (h - pow(toBigInt(5), 1, eC, f, f, DOWN)), h)) | |
734 | + | eD | |
731 | 735 | } | |
732 | 736 | ||
733 | 737 | ||
734 | - | @Callable( | |
735 | - | func constructor ( | |
736 | - | let | |
737 | - | if (( | |
738 | - | then ([IntegerEntry( | |
738 | + | @Callable(aO) | |
739 | + | func constructor (eE,eF,aB,eG,eH,aE) = { | |
740 | + | let eI = aN(aO) | |
741 | + | if ((eI == eI)) | |
742 | + | then ([IntegerEntry(bj(), 0), StringEntry(ax(), aH(eF, aB, eG, eH, aE)), StringEntry(E(), eE)] ++ cn(0, 0, 0, 0)) | |
739 | 743 | else throw("Strict value is not equal to itself.") | |
740 | 744 | } | |
741 | 745 | ||
742 | 746 | ||
743 | 747 | ||
744 | - | @Callable( | |
745 | - | func lockRef ( | |
746 | - | let | |
747 | - | let | |
748 | - | let | |
749 | - | let | |
750 | - | let | |
748 | + | @Callable(aO) | |
749 | + | func lockRef (bg,eJ,eK) = { | |
750 | + | let eL = eh(aO, bg) | |
751 | + | let eM = eL._1 | |
752 | + | let eq = eL._2 | |
753 | + | let eN = toString(aO.caller) | |
754 | + | let eO = if (if ((eJ == "")) | |
751 | 755 | then true | |
752 | - | else ( | |
756 | + | else (eK == base58'')) | |
753 | 757 | then unit | |
754 | - | else invoke(A, "createPair", [D, | |
755 | - | if (( | |
758 | + | else invoke(A, "createPair", [D, eJ, eN, eK], nil) | |
759 | + | if ((eO == eO)) | |
756 | 760 | then { | |
757 | - | let | |
758 | - | if (( | |
759 | - | then $Tuple2( | |
761 | + | let eP = invoke(aE, "updateReferralActivity", [toString(aO.caller), eq], nil) | |
762 | + | if ((eP == eP)) | |
763 | + | then $Tuple2(eM, unit) | |
760 | 764 | else throw("Strict value is not equal to itself.") | |
761 | 765 | } | |
762 | 766 | else throw("Strict value is not equal to itself.") | |
763 | 767 | } | |
764 | 768 | ||
765 | 769 | ||
766 | 770 | ||
767 | - | @Callable( | |
768 | - | func lock ( | |
769 | - | let | |
770 | - | let | |
771 | - | let | |
772 | - | let | |
773 | - | if (( | |
774 | - | then $Tuple2( | |
771 | + | @Callable(aO) | |
772 | + | func lock (bg) = { | |
773 | + | let eQ = eh(aO, bg) | |
774 | + | let eM = eQ._1 | |
775 | + | let eq = eQ._2 | |
776 | + | let eP = invoke(aE, "updateReferralActivity", [toString(aO.caller), eq], nil) | |
777 | + | if ((eP == eP)) | |
778 | + | then $Tuple2(eM, unit) | |
775 | 779 | else throw("Strict value is not equal to itself.") | |
776 | 780 | } | |
777 | 781 | ||
778 | 782 | ||
779 | 783 | ||
780 | - | @Callable( | |
781 | - | func claimWxBoost ( | |
784 | + | @Callable(aO) | |
785 | + | func claimWxBoost (bG,bO) = if ((bR != aO.caller)) | |
782 | 786 | then m("permissions denied") | |
783 | 787 | else { | |
784 | - | let | |
785 | - | let | |
786 | - | let | |
787 | - | let | |
788 | - | $Tuple2( | |
788 | + | let eR = dQ(bG, bO, false) | |
789 | + | let eS = eR._1 | |
790 | + | let ef = eR._2 | |
791 | + | let eg = eR._3 | |
792 | + | $Tuple2(ef, [eS]) | |
789 | 793 | } | |
790 | 794 | ||
791 | 795 | ||
792 | 796 | ||
793 | - | @Callable( | |
794 | - | func claimWxBoostREADONLY ( | |
795 | - | let | |
796 | - | let | |
797 | - | let | |
798 | - | let | |
799 | - | $Tuple2(nil, [ | |
797 | + | @Callable(aO) | |
798 | + | func claimWxBoostREADONLY (bG,bO) = { | |
799 | + | let eT = dQ(bG, bO, true) | |
800 | + | let eS = eT._1 | |
801 | + | let ef = eT._2 | |
802 | + | let eg = eT._3 | |
803 | + | $Tuple2(nil, [eS, eg]) | |
800 | 804 | } | |
801 | 805 | ||
802 | 806 | ||
803 | 807 | ||
804 | - | @Callable( | |
805 | - | func unlock ( | |
806 | - | let | |
807 | - | let | |
808 | - | let | |
809 | - | let | |
808 | + | @Callable(aO) | |
809 | + | func unlock (eU,be) = { | |
810 | + | let aY = aO.caller | |
811 | + | let bO = toString(aY) | |
812 | + | let aZ = fromBase58String(eU) | |
813 | + | let ex = bb(aY, if ((eU == "")) | |
810 | 814 | then unit | |
811 | - | else | |
812 | - | let | |
813 | - | let | |
814 | - | let | |
815 | - | let | |
816 | - | let | |
817 | - | let | |
818 | - | let | |
819 | - | let | |
815 | + | else aZ) | |
816 | + | let ey = parseIntValue(ex[aR]) | |
817 | + | let ck = parseIntValue(ex[aS]) | |
818 | + | let ez = parseIntValue(ex[aT]) | |
819 | + | let eA = (ck + ez) | |
820 | + | let bi = parseIntValue(ex[aW]) | |
821 | + | let bh = parseIntValue(ex[aV]) | |
822 | + | let eB = ((height - ck) / aF) | |
823 | + | let eD = ev(aY, if ((eU == "")) | |
820 | 824 | then unit | |
821 | - | else | |
822 | - | if (( | |
823 | - | then m(("maximum amount to unlock: " + toString( | |
825 | + | else aZ) | |
826 | + | if ((be > eD)) | |
827 | + | then m(("maximum amount to unlock: " + toString(eD))) | |
824 | 828 | else { | |
825 | - | let | |
826 | - | let | |
827 | - | let | |
828 | - | if (( | |
829 | - | then m(("locked gwx amount: " + toString( | |
830 | - | else if ((0 >= | |
829 | + | let eV = max([be, fraction((eB * aF), ey, aD)]) | |
830 | + | let eW = w((bh - eV), "gwxRemaining") | |
831 | + | let eX = cb(aY) | |
832 | + | if ((eX > eW)) | |
833 | + | then m(("locked gwx amount: " + toString(eX))) | |
834 | + | else if ((0 >= ey)) | |
831 | 835 | then m("nothing to unlock") | |
832 | 836 | else { | |
833 | - | let | |
834 | - | let | |
835 | - | let | |
836 | - | if (( | |
837 | - | then (((( | |
837 | + | let er = ca() | |
838 | + | let es = cE(aY) | |
839 | + | let et = reentrantInvoke(bS, "refreshUserReward", [aY.bytes], nil) | |
840 | + | if ((et == et)) | |
841 | + | then ((((cA(aY, aZ, ey, ck, ez, eW, (bi + be)) ++ cn(-(be), 0, 0, 0)) :+ ch("unlock", bO, be, ck, ez, eV, aO)) :+ ScriptTransfer(aY, be, aA)) ++ [IntegerEntry(by(), w((er - eV), "gwxTotal")), IntegerEntry(bc(aY), w((es - eV), "userGwxAmountTotal"))]) | |
838 | 842 | else throw("Strict value is not equal to itself.") | |
839 | 843 | } | |
840 | 844 | } | |
841 | 845 | } | |
842 | 846 | ||
843 | 847 | ||
844 | 848 | ||
845 | - | @Callable( | |
846 | - | func gwxUserInfoREADONLY ( | |
847 | - | let | |
848 | - | let | |
849 | - | $Tuple2(nil, [ | |
849 | + | @Callable(aO) | |
850 | + | func gwxUserInfoREADONLY (bO) = { | |
851 | + | let aY = valueOrErrorMessage(addressFromString(bO), k("invalid user address")) | |
852 | + | let bh = cE(aY) | |
853 | + | $Tuple2(nil, [bh]) | |
850 | 854 | } | |
851 | 855 | ||
852 | 856 | ||
853 | 857 | ||
854 | - | @Callable( | |
855 | - | func userMaxDurationREADONLY ( | |
858 | + | @Callable(aO) | |
859 | + | func userMaxDurationREADONLY (bO) = $Tuple2(nil, $Tuple2("increaseLock", aD)) | |
856 | 860 | ||
857 | 861 | ||
858 | 862 | ||
859 | - | @Callable( | |
860 | - | func getUserGwxAmountAtHeightREADONLY ( | |
861 | - | let | |
862 | - | let | |
863 | - | $Tuple2(nil, | |
863 | + | @Callable(aO) | |
864 | + | func getUserGwxAmountAtHeightREADONLY (bO,eY) = { | |
865 | + | let aY = valueOrErrorMessage(addressFromString(bO), k("invalid user address")) | |
866 | + | let bh = cE(aY) | |
867 | + | $Tuple2(nil, bh) | |
864 | 868 | } | |
865 | 869 | ||
866 | 870 | ||
867 | 871 | ||
868 | - | @Callable( | |
869 | - | func getUserGwxAmount ( | |
870 | - | let | |
871 | - | let | |
872 | - | $Tuple2(nil, | |
872 | + | @Callable(aO) | |
873 | + | func getUserGwxAmount (bO) = { | |
874 | + | let aY = valueOrErrorMessage(addressFromString(bO), k("invalid user address")) | |
875 | + | let bh = cE(aY) | |
876 | + | $Tuple2(nil, bh) | |
873 | 877 | } | |
874 | 878 | ||
875 | 879 | ||
876 | 880 | ||
877 | - | @Callable( | |
878 | - | func getGwxTotalREADONLY () = $Tuple2(nil, | |
881 | + | @Callable(aO) | |
882 | + | func getGwxTotalREADONLY () = $Tuple2(nil, ca()) | |
879 | 883 | ||
880 | 884 | ||
881 | 885 | ||
882 | - | @Callable( | |
886 | + | @Callable(aO) | |
883 | 887 | func onBoostEmissionUpdate () = { | |
884 | - | let | |
888 | + | let eI = if ((aO.caller == bQ)) | |
885 | 889 | then true | |
886 | - | else | |
887 | - | if (( | |
888 | - | then | |
890 | + | else aN(aO) | |
891 | + | if ((eI == eI)) | |
892 | + | then dF() | |
889 | 893 | else throw("Strict value is not equal to itself.") | |
890 | 894 | } | |
891 | 895 | ||
892 | 896 | ||
893 | 897 | ||
894 | - | @Callable( | |
895 | - | func onStakedVoteUpdate ( | |
896 | - | let | |
898 | + | @Callable(aO) | |
899 | + | func onStakedVoteUpdate (bG,bO,dr) = { | |
900 | + | let eI = if ((aO.caller == bR)) | |
897 | 901 | then true | |
898 | - | else | |
899 | - | if (( | |
902 | + | else aN(aO) | |
903 | + | if ((eI == eI)) | |
900 | 904 | then { | |
901 | - | let | |
902 | - | $Tuple2( | |
905 | + | let du = dq(bG, bO, dr) | |
906 | + | $Tuple2(du, unit) | |
903 | 907 | } | |
904 | 908 | else throw("Strict value is not equal to itself.") | |
905 | 909 | } | |
906 | 910 | ||
907 | 911 | ||
908 | 912 | ||
909 | - | @Callable( | |
910 | - | func getVotingResultStakedREADONLY ( | |
913 | + | @Callable(aO) | |
914 | + | func getVotingResultStakedREADONLY (bG) = $Tuple2(nil, cV(bG)) | |
911 | 915 | ||
912 | 916 | ||
913 | 917 | ||
914 | - | @Callable( | |
915 | - | func getVotingResultStakedIntegralREADONLY ( | |
918 | + | @Callable(aO) | |
919 | + | func getVotingResultStakedIntegralREADONLY (bG) = $Tuple2(nil, cZ(bG)) | |
916 | 920 | ||
917 | 921 | ||
918 | 922 | ||
919 | - | @Callable( | |
920 | - | func getUserVoteFinalizedREADONLY ( | |
923 | + | @Callable(aO) | |
924 | + | func getUserVoteFinalizedREADONLY (bG,bO) = $Tuple2(nil, cO(bG, bO)) | |
921 | 925 | ||
922 | 926 | ||
923 | 927 | ||
924 | - | @Callable( | |
925 | - | func getUserVoteStakedIntegralREADONLY ( | |
928 | + | @Callable(aO) | |
929 | + | func getUserVoteStakedIntegralREADONLY (bG,bO) = $Tuple2(nil, dj(bG, bO)) | |
926 | 930 | ||
927 | 931 | ||
928 | - | @Verifier( | |
929 | - | func | |
930 | - | let | |
931 | - | let | |
932 | - | if ($isInstanceOf( | |
932 | + | @Verifier(eZ) | |
933 | + | func fa () = { | |
934 | + | let fb = { | |
935 | + | let aJ = aL() | |
936 | + | if ($isInstanceOf(aJ, "ByteVector")) | |
933 | 937 | then { | |
934 | - | let | |
935 | - | | |
938 | + | let aQ = aJ | |
939 | + | aQ | |
936 | 940 | } | |
937 | - | else if ($isInstanceOf( | |
938 | - | then | |
941 | + | else if ($isInstanceOf(aJ, "Unit")) | |
942 | + | then eZ.senderPublicKey | |
939 | 943 | else throw("Match error") | |
940 | 944 | } | |
941 | - | sigVerify( | |
945 | + | sigVerify(eZ.bodyBytes, eZ.proofs[0], fb) | |
942 | 946 | } | |
943 | 947 |
github/deemru/w8io/169f3d6 382.73 ms ◑