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