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