tx · 8JLvF7R7AYc1EWJqf7nrnQeYGR8EjWWpNQV5cNorQStE 3MsdLkCCcsf1niGwjyQCMi8aC4CkNbm2Wy9: -0.04300000 Waves 2023.04.05 11:51 [2521028] smart account 3MsdLkCCcsf1niGwjyQCMi8aC4CkNbm2Wy9 > SELF 0.00000000 Waves
{ "type": 13, "id": "8JLvF7R7AYc1EWJqf7nrnQeYGR8EjWWpNQV5cNorQStE", "fee": 4300000, "feeAssetId": null, "timestamp": 1680684693601, "version": 2, "chainId": 84, "sender": "3MsdLkCCcsf1niGwjyQCMi8aC4CkNbm2Wy9", "senderPublicKey": "B4L9D9LnFwCPW8fFVc65SHyFNYjb1KJv6MUQXPGMPSTy", "proofs": [ "5nnR1hhQ7b8HEPHf8T7PCrGNoQYau7aVCyzqLLCDGekpuHvRA9tvJXFDoY4zBi6gkHhPmoUkSdruAvRZtyVQH8vM" ], "script": "base64:BgLENwgCEgASBQoDAQQBEgcKBQEEAQgBEgMKAQgSABIECgIBBBIDCgEBEgQKAgEEEgQKAggBEgQKAggBEgQKAggBEgUKAwEIARIAEgQKAgEBEgMKAQESBQoDAQEBEgQKAggIEgASABIDCgEIEgUKAwEBARIECgIBARIECgIIARIECgIICBILCgkIAQECAQIIBAQSBgoECAgBCBIAEgMKAQESAwoBARIECgIIASIKbFBkZWNpbWFscyIGc2NhbGU4IgxzY2FsZThCaWdJbnQiB3NjYWxlMTgiCnplcm9CaWdJbnQiBGJpZzAiBGJpZzEiBGJpZzIiC3dhdmVzU3RyaW5nIgNTRVAiClBvb2xBY3RpdmUiD1Bvb2xQdXREaXNhYmxlZCITUG9vbE1hdGNoZXJEaXNhYmxlZCIMUG9vbFNodXRkb3duIg5pZHhQb29sQWRkcmVzcyINaWR4UG9vbFN0YXR1cyIQaWR4UG9vbExQQXNzZXRJZCINaWR4QW10QXNzZXRJZCIPaWR4UHJpY2VBc3NldElkIg5pZHhBbXRBc3NldERjbSIQaWR4UHJpY2VBc3NldERjbSIOaWR4SUFtdEFzc2V0SWQiEGlkeElQcmljZUFzc2V0SWQiDWlkeExQQXNzZXREY20iEmlkeFBvb2xBbXRBc3NldEFtdCIUaWR4UG9vbFByaWNlQXNzZXRBbXQiEWlkeFBvb2xMUEFzc2V0QW10IhlpZHhGYWN0b3J5U3Rha2luZ0NvbnRyYWN0IhppZHhGYWN0b3J5U2xpcHBhZ2VDb250cmFjdCIFdG9YMTgiB29yaWdWYWwiDW9yaWdTY2FsZU11bHQiC3RvWDE4QmlnSW50Igdmcm9tWDE4IgN2YWwiD3Jlc3VsdFNjYWxlTXVsdCIMZnJvbVgxOFJvdW5kIgVyb3VuZCIHdG9TY2FsZSIDYW10IghyZXNTY2FsZSIIY3VyU2NhbGUiA2FicyIJYWJzQmlnSW50Igxzd2FwQ29udHJhY3QiAmZjIgNtcGsiBHBtcGsiAnBsIgJwaCIBaCIJdGltZXN0YW1wIgNwYXUiC3VzZXJBZGRyZXNzIgR0eElkIgNnYXUiAmFhIgJwYSIGa2V5RmVlIgpmZWVEZWZhdWx0IgNmZWUiBmtleUtMcCIVa2V5S0xwUmVmcmVzaGVkSGVpZ2h0IhJrZXlLTHBSZWZyZXNoRGVsYXkiFmtMcFJlZnJlc2hEZWxheURlZmF1bHQiD2tMcFJlZnJlc2hEZWxheSIQa2V5U1dhdmVzQXNzZXRJZCIVa2V5U1dhdmVzUHJveHlBZGRyZXNzIhRrZXlBZGRpdGlvbmFsQmFsYW5jZSIHYXNzZXRJZCIWa2V5U3Rha2luZ0Fzc2V0QmFsYW5jZSIaZ2V0QWRkaXRpb25hbEJhbGFuY2VPclplcm8iHGdldFN0YWtpbmdBc3NldEJhbGFuY2VPclplcm8iEGtleUZhY3RvcnlDb25maWciDWtleU1hdGNoZXJQdWIiKWtleU1hcHBpbmdQb29sQ29udHJhY3RBZGRyZXNzVG9Qb29sQXNzZXRzIhNwb29sQ29udHJhY3RBZGRyZXNzIg1rZXlQb29sQ29uZmlnIglpQW10QXNzZXQiC2lQcmljZUFzc2V0Ih9rZXlNYXBwaW5nc0Jhc2VBc3NldDJpbnRlcm5hbElkIgxiYXNlQXNzZXRTdHIiE2tleUFsbFBvb2xzU2h1dGRvd24iDWtleVBvb2xXZWlnaHQiD2NvbnRyYWN0QWRkcmVzcyIWa2V5QWxsb3dlZExwU2NyaXB0SGFzaCIWa2V5RmVlQ29sbGVjdG9yQWRkcmVzcyIPdGhyb3dPcmRlckVycm9yIgpvcmRlclZhbGlkIg5vcmRlclZhbGlkSW5mbyILc2VuZGVyVmFsaWQiDG1hdGNoZXJWYWxpZCIPZ2V0U3RyaW5nT3JGYWlsIgdhZGRyZXNzIgNrZXkiDGdldEludE9yRmFpbCIIdGhyb3dFcnIiA21zZyIGZm10RXJyIg9mYWN0b3J5Q29udHJhY3QiE2ZlZUNvbGxlY3RvckFkZHJlc3MiBWluRmVlIgFAIgZvdXRGZWUiCHNXYXZlc0lkIgtzV2F2ZXNQcm94eSIQaXNHbG9iYWxTaHV0ZG93biITZ2V0TWF0Y2hlclB1Yk9yRmFpbCINZ2V0UG9vbENvbmZpZyIIYW10QXNzZXQiCnByaWNlQXNzZXQiDHBhcnNlQXNzZXRJZCIFaW5wdXQiD2Fzc2V0SWRUb1N0cmluZyIPcGFyc2VQb29sQ29uZmlnIgpwb29sQ29uZmlnIhBwb29sQ29uZmlnUGFyc2VkIgskdDA5Mjk3OTQ2MyIOY2ZnUG9vbEFkZHJlc3MiDWNmZ1Bvb2xTdGF0dXMiDGNmZ0xwQXNzZXRJZCIQY2ZnQW1vdW50QXNzZXRJZCIPY2ZnUHJpY2VBc3NldElkIhZjZmdBbW91bnRBc3NldERlY2ltYWxzIhVjZmdQcmljZUFzc2V0RGVjaW1hbHMiEGdldEZhY3RvcnlDb25maWciD3N0YWtpbmdDb250cmFjdCIQc2xpcHBhZ2VDb250cmFjdCIRZGF0YVB1dEFjdGlvbkluZm8iDWluQW10QXNzZXRBbXQiD2luUHJpY2VBc3NldEFtdCIIb3V0THBBbXQiBXByaWNlIh1zbGlwcGFnZVRvbGVyYW5jZVBhc3NlZEJ5VXNlciIVc2xpcHBhZ2VUb2xlcmFuY2VSZWFsIgh0eEhlaWdodCILdHhUaW1lc3RhbXAiEnNsaXBhZ2VBbXRBc3NldEFtdCIUc2xpcGFnZVByaWNlQXNzZXRBbXQiEWRhdGFHZXRBY3Rpb25JbmZvIg5vdXRBbXRBc3NldEFtdCIQb3V0UHJpY2VBc3NldEFtdCIHaW5McEFtdCINZ2V0QWNjQmFsYW5jZSINYmFsYW5jZU9uUG9vbCIMdG90YWxCYWxhbmNlIg9jYWxjUHJpY2VCaWdJbnQiCHByQW10WDE4IghhbUFtdFgxOCIUY2FsY1ByaWNlQmlnSW50Um91bmQiB2dldFJhdGUiBXByb3h5IgNpbnYiByRtYXRjaDAiAXIiB2RlcG9zaXQiBmFtb3VudCIOc3Rha2luZ0Fzc2V0SWQiGGN1cnJlbnRBZGRpdGlvbmFsQmFsYW5jZSIaY3VycmVudFN0YWtpbmdBc3NldEJhbGFuY2UiBWFzc2V0Ig1kZXBvc2l0SW52b2tlIhRyZWNlaXZlZFN0YWtpbmdBc3NldCIUbmV3QWRkaXRpb25hbEJhbGFuY2UiFm5ld1N0YWtpbmdBc3NldEJhbGFuY2UiCHdpdGhkcmF3Igxwcm94eVJhdGVNdWwiDXByb2ZpdEFkZHJlc3MiEGN1cnJlbnRQcm94eVJhdGUiB29sZFJhdGUiDHN0YWtpbmdBc3NldCIUb2xkU2VuZFN0YWtpbmdBbW91bnQiFnNlbmRTdGFraW5nQXNzZXRBbW91bnQiDHByb2ZpdEFtb3VudCIOd2l0aGRyYXdJbnZva2UiDnJlY2VpdmVkQXNzZXRzIhNnZXRMZWFzZVByb3h5Q29uZmlnIhFyZWJhbGFuY2VJbnRlcm5hbCILdGFyZ2V0UmF0aW8iCm1pbkJhbGFuY2UiEGF2YWlsYWJsZUJhbGFuY2UiAWIiAXUiDHdob2xlQmFsYW5jZSIXdGFyZ2V0QWRkaXRpb25hbEJhbGFuY2UiBGRpZmYiD3NlbmRBc3NldEFtb3VudCIOZ2V0QXNzZXRBbW91bnQiDnJlYmFsYW5jZUFzc2V0IgFhIg0kdDAxNTgxNDE1OTIzIgppc0xlYXNhYmxlIgtsZWFzZWRSYXRpbyIMcHJveHlBZGRyZXNzIgxwcm94eUFzc2V0SWQiFHN0YWtpbmdQcm9maXRBZGRyZXNzIhVnZXRXaXRoZHJhd0Fzc2V0U3RhdGUiCWdldEFtb3VudCINJHQwMTY1MTYxNjYyNSITbmV3VG90YWxDYWxjQmFsYW5jZSIOd2l0aGRyYXdBbW91bnQiEHByaXZhdGVDYWxjUHJpY2UiCmFtQXNzZXREY20iCnByQXNzZXREY20iBWFtQW10IgVwckFtdCIOYW10QXNzZXRBbXRYMTgiEHByaWNlQXNzZXRBbXRYMTgiCmNhbGNQcmljZXMiBWxwQW10IgNjZmciC2FtdEFzc2V0RGNtIg1wcmljZUFzc2V0RGNtIghwcmljZVgxOCIIbHBBbXRYMTgiE2xwUHJpY2VJbkFtQXNzZXRYMTgiE2xwUHJpY2VJblByQXNzZXRYMTgiD2NhbGN1bGF0ZVByaWNlcyIGcHJpY2VzIhRlc3RpbWF0ZUdldE9wZXJhdGlvbiIGdHhJZDU4IgpwbXRBc3NldElkIghwbXRMcEFtdCIJbHBBc3NldElkIglhbUFzc2V0SWQiCXByQXNzZXRJZCIKcG9vbFN0YXR1cyIKbHBFbWlzc2lvbiIJYW1CYWxhbmNlIgxhbUJhbGFuY2VYMTgiCXByQmFsYW5jZSIMcHJCYWxhbmNlWDE4IgtjdXJQcmljZVgxOCIIY3VyUHJpY2UiC3BtdExwQW10WDE4Ig1scEVtaXNzaW9uWDE4IgtvdXRBbUFtdFgxOCILb3V0UHJBbXRYMTgiCG91dEFtQW10IghvdXRQckFtdCISQW1BbXRXaXRoZHJhd1N0YXRlIhJQckFtdFdpdGhkcmF3U3RhdGUiBXN0YXRlIhRlc3RpbWF0ZVB1dE9wZXJhdGlvbiIRc2xpcHBhZ2VUb2xlcmFuY2UiDGluQW1Bc3NldEFtdCILaW5BbUFzc2V0SWQiDGluUHJBc3NldEFtdCILaW5QckFzc2V0SWQiCmlzRXZhbHVhdGUiBmVtaXRMcCIMYW1Bc3NldElkU3RyIgxwckFzc2V0SWRTdHIiC2lBbXRBc3NldElkIg1pUHJpY2VBc3NldElkIg5pbkFtQXNzZXRJZFN0ciIOaW5QckFzc2V0SWRTdHIiD2luQW1Bc3NldEFtdFgxOCIPaW5QckFzc2V0QW10WDE4Igx1c2VyUHJpY2VYMTgiA3JlcyILc2xpcHBhZ2VYMTgiFHNsaXBwYWdlVG9sZXJhbmNlWDE4IgpwclZpYUFtWDE4IgphbVZpYVByWDE4IgxleHBlY3RlZEFtdHMiEWV4cEFtdEFzc2V0QW10WDE4IhNleHBQcmljZUFzc2V0QW10WDE4IgljYWxjTHBBbXQiDmNhbGNBbUFzc2V0UG10Ig5jYWxjUHJBc3NldFBtdCIMc2xpcHBhZ2VDYWxjIgllbWl0THBBbXQiBmFtRGlmZiIGcHJEaWZmIgtjb21tb25TdGF0ZSIHY2FsY0tMcCINYW1vdW50QmFsYW5jZSIMcHJpY2VCYWxhbmNlIhBhbW91bnRCYWxhbmNlWDE4Ig9wcmljZUJhbGFuY2VYMTgiCnVwZGF0ZWRLTHAiDmNhbGNDdXJyZW50S0xwIhBhbW91bnRBc3NldERlbHRhIg9wcmljZUFzc2V0RGVsdGEiFGxwQXNzZXRFbWlzc2lvbkRlbHRhIhJhbW91bnRBc3NldEJhbGFuY2UiEXByaWNlQXNzZXRCYWxhbmNlIg9scEFzc2V0RW1pc3Npb24iCmN1cnJlbnRLTHAiEnJlZnJlc2hLTHBJbnRlcm5hbCIXYW1vdW50QXNzZXRCYWxhbmNlRGVsdGEiFnByaWNlQXNzZXRCYWxhbmNlRGVsdGEiB2FjdGlvbnMiEnZhbGlkYXRlVXBkYXRlZEtMcCIGb2xkS0xwIht2YWxpZGF0ZU1hdGNoZXJPcmRlckFsbG93ZWQiBW9yZGVyIhFhbW91bnRBc3NldEFtb3VudCIQcHJpY2VBc3NldEFtb3VudCINJHQwMjg3MDcyODkxOSIDa0xwIg0kdDAyOTM1OTI5NDU5Ig11bnVzZWRBY3Rpb25zIgZrTHBOZXciDGlzT3JkZXJWYWxpZCIEaW5mbyIJY29tbW9uR2V0IgFpIgNwbXQiBnBtdEFtdCIJY29tbW9uUHV0IgphbUFzc2V0UG10IgpwckFzc2V0UG10IgZlc3RQdXQiBGVtaXQiB2VtaXRJbnYiDWVtaXRJbnZMZWdhY3kiFWxlZ2FjeUZhY3RvcnlDb250cmFjdCIHdGFrZUZlZSIJZmVlQW1vdW50Ig9jYWxjUHV0T25lVG9rZW4iEHBheW1lbnRBbW91bnRSYXciDnBheW1lbnRBc3NldElkIgZpc0V2YWwiEGFtb3VudEJhbGFuY2VSYXciD3ByaWNlQmFsYW5jZVJhdyIUcGF5bWVudEluQW1vdW50QXNzZXQiDSR0MDMyNTcyMzI4NjUiEGFtb3VudEJhbGFuY2VPbGQiD3ByaWNlQmFsYW5jZU9sZCINJHQwMzI4NjkzMzAxOCIUYW1vdW50QXNzZXRBbW91bnRSYXciE3ByaWNlQXNzZXRBbW91bnRSYXciDSR0MDMzMTUwMzMyMTQiDXBheW1lbnRBbW91bnQiEGFtb3VudEJhbGFuY2VOZXciD3ByaWNlQmFsYW5jZU5ldyILcHJpY2VOZXdYMTgiCHByaWNlTmV3Ig5wYXltZW50QmFsYW5jZSIUcGF5bWVudEJhbGFuY2VCaWdJbnQiDHN1cHBseUJpZ0ludCILY2hlY2hTdXBwbHkiDWRlcG9zaXRCaWdJbnQiC2lzc3VlQW1vdW50IgtwcmljZU9sZFgxOCIIcHJpY2VPbGQiBGxvc3MiDSR0MDM0ODk1MzUwNjIiB2JhbGFuY2UiD2lzc3VlQW1vdW50Qm90aCIPY2FsY0dldE9uZVRva2VuIgpvdXRBc3NldElkIgZjaGVja3MiEG91dEluQW1vdW50QXNzZXQiDWJhbGFuY2VCaWdJbnQiGG91dEluQW1vdW50QXNzZXREZWNpbWFscyIMYW1CYWxhbmNlT2xkIgxwckJhbGFuY2VPbGQiCm91dEJhbGFuY2UiEG91dEJhbGFuY2VCaWdJbnQiDnJlZGVlbWVkQmlnSW50IglhbW91bnRSYXciDSR0MDM3MTQwMzcxOTYiC3RvdGFsQW1vdW50Ig0kdDAzNzIwMDM3NDI2IgtvdXRBbUFtb3VudCILb3V0UHJBbW91bnQiDGFtQmFsYW5jZU5ldyIMcHJCYWxhbmNlTmV3IhhhbW91bnRCb3RoSW5QYXltZW50QXNzZXQiFm1hbmFnZXJQdWJsaWNLZXlPclVuaXQiAXMiHXBlbmRpbmdNYW5hZ2VyUHVibGljS2V5T3JVbml0Iglpc01hbmFnZXIiAnBrIgttdXN0TWFuYWdlciICcGQiDWNsZWFuQW1vdW50SW4iCWlzUmV2ZXJzZSINZmVlUG9vbEFtb3VudCINJHQwMzkzMTIzOTYxNyIIYXNzZXRPdXQiB2Fzc2V0SW4iEnBvb2xBc3NldEluQmFsYW5jZSITcG9vbEFzc2V0T3V0QmFsYW5jZSIJYW1vdW50T3V0IgRvbGRLIgRuZXdLIgZjaGVja0siDGFtb3VudE91dE1pbiIJYWRkcmVzc1RvIgtzd2FwQ29udGFjdCIIY2hlY2tNaW4iBmxzQ29uZiINd2l0aGRyYXdTdGF0ZSIXcGVuZGluZ01hbmFnZXJQdWJsaWNLZXkiC2NoZWNrQ2FsbGVyIhVjaGVja01hbmFnZXJQdWJsaWNLZXkiAnBtIgVoYXNQTSIHY2hlY2tQTSIPc2hvdWxkQXV0b1N0YWtlIgRhbUlkIgRwcklkIgxzbGlwcGFnZUFJbnYiDHNsaXBwYWdlUEludiIKbHBUcmFuc2ZlciILc2xwU3Rha2VJbnYiDSR0MDQ0NzcwNDUyMzIiEXJlZnJlc2hLTHBBY3Rpb25zIhFpc1VwZGF0ZWRLTHBWYWxpZCIDcmViIgttYXhTbGlwcGFnZSINJHQwNDU4NDQ0NTkwOSIMbWluT3V0QW1vdW50IglhdXRvU3Rha2UiIGlzUG9vbE9uZVRva2VuT3BlcmF0aW9uc0Rpc2FibGVkIg1pc1B1dERpc2FibGVkIgdwYXltZW50Ig0kdDA0NzA5NzQ3MjQ5IgVib251cyITZW1pdEFtb3VudEVzdGltYXRlZCIKZW1pdEFtb3VudCIIc3Rha2VJbnYiB3NlbmRGZWUiDSR0MDQ3ODM1NDgwMzIiDSR0MDQ4MDM1NDgxNDMiDSR0MDQ4NDk4NDg2NTUiDW91dEFzc2V0SWRTdHIiDWlzR2V0RGlzYWJsZWQiDSR0MDQ5NTQwNDk2OTMiD2Ftb3VudEVzdGltYXRlZCIHYnVybkludiINYXNzZXRUcmFuc2ZlciINJHQwNTA0NDk1MDY5NiIQZmVlQW1vdW50Rm9yQ2FsYyINJHQwNTA2OTk1MDgwNyINJHQwNTEwODU1MTI0MSINdW5zdGFrZUFtb3VudCIKdW5zdGFrZUludiINJHQwNTIxNDY1MjI5NyINJHQwNTI4NjI1MzEwOSINJHQwNTMxMTI1MzIyMCIJb3V0QW10QW10IhRidXJuTFBBc3NldE9uRmFjdG9yeSINJHQwNTQxODc1NDI2OSISbm9MZXNzVGhlbkFtdEFzc2V0IhRub0xlc3NUaGVuUHJpY2VBc3NldCINJHQwNTUyMTg1NTI5OSINY2hlY2tQYXltZW50cyIPY2hlY2tQb29sU3RhdHVzIg0kdDA1NjQyNTU2NTA2IhVub0xlc3NUaGVuQW1vdW50QXNzZXQiDGNoZWNrQW1vdW50cyINJHQwNTc4MDE1Nzg4MiILYW10QXNzZXRTdHIiDXByaWNlQXNzZXRTdHIiGGxhc3RSZWZyZXNoZWRCbG9ja0hlaWdodCIdY2hlY2tMYXN0UmVmcmVzaGVkQmxvY2tIZWlnaHQiDSR0MDU5MDY5NTkxMzMiEGtMcFVwZGF0ZUFjdGlvbnMiCmFtdEFzc2V0SWQiDHByaWNlQXNzZXRJZCINcG9vbExQQmFsYW5jZSISYWNjQW10QXNzZXRCYWxhbmNlIhRhY2NQcmljZUFzc2V0QmFsYW5jZSIKcHJpY2VzTGlzdCIPbHBBbXRBc3NldFNoYXJlIhFscFByaWNlQXNzZXRTaGFyZSIKcG9vbFdlaWdodCIMY3VyUHJpY2VDYWxjIgxhbUJhbGFuY2VSYXciDHByQmFsYW5jZVJhdyIPYW1CYWxhbmNlUmF3WDE4Ig9wckJhbGFuY2VSYXdYMTgiEHBheW1lbnRMcEFzc2V0SWQiDHBheW1lbnRMcEFtdCICdHgiBnZlcmlmeSIPdGFyZ2V0UHVibGljS2V5IgptYXRjaGVyUHViIg0kdDA2Nzc5NTY3ODY0IgduZXdIYXNoIgthbGxvd2VkSGFzaCILY3VycmVudEhhc2iCAQABYQAIAAFiAIDC1y8AAWMJALYCAQCAwtcvAAFkCQC2AgEAgICQu7rWrfANAAFlCQC2AgEAAAABZgkAtgIBAAAAAWcJALYCAQABAAFoCQC2AgEAAgABaQIFV0FWRVMAAWoCAl9fAAFrAAEAAWwAAgABbQADAAFuAAQAAW8AAQABcAACAAFxAAMAAXIABAABcwAFAAF0AAYAAXUABwABdgAIAAF3AAkAAXgACgABeQABAAF6AAIAAUEAAwABQgABAAFDAAcBAUQCAUUBRgkAvAIDCQC2AgEFAUUFAWQJALYCAQUBRgEBRwIBRQFGCQC8AgMFAUUFAWQFAUYBAUgCAUkBSgkAoAMBCQC8AgMFAUkJALYCAQUBSgUBZAEBSwMBSQFKAUwJAKADAQkAvQIEBQFJCQC2AgEFAUoFAWQFAUwBAU0DAU4BTwFQCQBrAwUBTgUBTwUBUAEBUQEBSQMJAGYCAAAFAUkJAQEtAQUBSQUBSQEBUgEBSQMJAL8CAgUBZQUBSQkAvgIBBQFJBQFJAQFTAAIQJXNfX3N3YXBDb250cmFjdAEBVAACEyVzX19mYWN0b3J5Q29udHJhY3QBAVUAAhQlc19fbWFuYWdlclB1YmxpY0tleQEBVgACGyVzX19wZW5kaW5nTWFuYWdlclB1YmxpY0tleQEBVwACESVzJXNfX3ByaWNlX19sYXN0AQFYAgFZAVoJALkJAgkAzAgCAhglcyVzJWQlZF9fcHJpY2VfX2hpc3RvcnkJAMwIAgkApAMBBQFZCQDMCAIJAKQDAQUBWgUDbmlsBQFqAQJhYQICYWICYWMJAKwCAgkArAICCQCsAgICCyVzJXMlc19fUF9fBQJhYgICX18FAmFjAQJhZAICYWICYWMJAKwCAgkArAICCQCsAgICCyVzJXMlc19fR19fBQJhYgICX18FAmFjAQJhZQACDyVzX19hbW91bnRBc3NldAECYWYAAg4lc19fcHJpY2VBc3NldAACYWcCByVzX19mZWUAAmFoCQBrAwAKBQFiAJBOAAJhaQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQJhZwUCYWgAAmFqCQC5CQIJAMwIAgICJXMJAMwIAgIDa0xwBQNuaWwFAWoAAmFrCQC5CQIJAMwIAgICJXMJAMwIAgISa0xwUmVmcmVzaGVkSGVpZ2h0BQNuaWwFAWoAAmFsCQC5CQIJAMwIAgICJXMJAMwIAgIPcmVmcmVzaEtMcERlbGF5BQNuaWwFAWoAAmFtAB4AAmFuCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFAmFsBQJhbQECYW8AAhElc19fc1dhdmVzQXNzZXRJZAECYXAAAhYlc19fc1dhdmVzUHJveHlBZGRyZXNzAQJhcQECYXIJALkJAgkAzAgCAgQlcyVzCQDMCAICEWFkZGl0aW9uYWxCYWxhbmNlCQDMCAIFAmFyBQNuaWwFAWoBAmFzAQJhcgkAuQkCCQDMCAICBCVzJXMJAMwIAgITc3Rha2luZ0Fzc2V0QmFsYW5jZQkAzAgCBQJhcgUDbmlsBQFqAQJhdAECYXIJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBAmFxAQUCYXIAAAECYXUBAmFyCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQJhcwEFAmFyAAABAmF2AAIRJXNfX2ZhY3RvcnlDb25maWcBAmF3AAIYJXMlc19fbWF0Y2hlcl9fcHVibGljS2V5AQJheAECYXkJAKwCAgkArAICAgglcyVzJXNfXwUCYXkCIF9fbWFwcGluZ3NfX3Bvb2xDb250cmFjdDJMcEFzc2V0AQJhegICYUECYUIJAKwCAgkArAICCQCsAgIJAKwCAgIIJWQlZCVzX18FAmFBAgJfXwUCYUICCF9fY29uZmlnAQJhQwECYUQJAKwCAgIoJXMlcyVzX19tYXBwaW5nc19fYmFzZUFzc2V0MmludGVybmFsSWRfXwUCYUQBAmFFAAIMJXNfX3NodXRkb3duAQJhRgECYUcJAKwCAgISJXMlc19fcG9vbFdlaWdodF9fBQJhRwECYUgAAhclc19fYWxsb3dlZExwU2NyaXB0SGFzaAACYUkCFyVzX19mZWVDb2xsZWN0b3JBZGRyZXNzAQJhSgQCYUsCYUwCYU0CYU4JAAIBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIkb3JkZXIgdmFsaWRhdGlvbiBmYWlsZWQ6IG9yZGVyVmFsaWQ9CQClAwEFAmFLAgIgKAUCYUwCASkCDSBzZW5kZXJWYWxpZD0JAKUDAQUCYU0CDiBtYXRjaGVyVmFsaWQ9CQClAwEFAmFOAQJhTwICYVACYVEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQJhUAUCYVEJALkJAgkAzAgCAgptYW5kYXRvcnkgCQDMCAIJAKUIAQUCYVAJAMwIAgIBLgkAzAgCBQJhUQkAzAgCAg8gaXMgbm90IGRlZmluZWQFA25pbAIAAQJhUgICYVACYVEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQJhUAUCYVEJALkJAgkAzAgCAgptYW5kYXRvcnkgCQDMCAIJAKUIAQUCYVAJAMwIAgIBLgkAzAgCBQJhUQkAzAgCAg8gaXMgbm90IGRlZmluZWQFA25pbAIAAQJhUwECYVQJAAIBCQC5CQIJAMwIAgIIbHAucmlkZToJAMwIAgUCYVQFA25pbAIBIAECYVUBAmFUCQC5CQIJAMwIAgIIbHAucmlkZToJAMwIAgUCYVQFA25pbAIBIAACYVYJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQJhTwIFBHRoaXMJAQFUAAACYVcJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQJhTwIFAmFWBQJhSQACYVgKAAJhWQkA/AcEBQJhVgIQZ2V0SW5GZWVSRUFET05MWQkAzAgCCQClCAEFBHRoaXMFA25pbAUDbmlsAwkAAQIFAmFZAgNJbnQFAmFZCQACAQkArAICCQADAQUCYVkCGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAACYVoKAAJhWQkA/AcEBQJhVgIRZ2V0T3V0RmVlUkVBRE9OTFkJAMwIAgkApQgBBQR0aGlzBQNuaWwFA25pbAMJAAECBQJhWQIDSW50BQJhWQkAAgEJAKwCAgkAAwEFAmFZAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQBAmJhAAkBAmFPAgUCYVYJAQJhbwABAmJiAAkBAmFPAgUCYVYJAQJhcAABAmJjAAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQJhVgkBAmFFAAcBAmJkAAkA2QQBCQECYU8CBQJhVgkBAmF3AAECYmUABAJiZgkBAmFPAgUEdGhpcwkBAmFlAAQCYmcJAQJhTwIFBHRoaXMJAQJhZgAEAmFCCQECYVICBQJhVgkBAmFDAQUCYmcEAmFBCQECYVICBQJhVgkBAmFDAQUCYmYJALUJAgkBAmFPAgUCYVYJAQJhegIJAKQDAQUCYUEJAKQDAQUCYUIFAWoBAmJoAQJiaQMJAAACBQJiaQUBaQUEdW5pdAkA2QQBBQJiaQECYmoBAmJpAwkAAAIFAmJpBQR1bml0BQFpCQDYBAEJAQV2YWx1ZQEFAmJpAQJiawECYmwJAJkKBwkBEUBleHRyTmF0aXZlKDEwNjIpAQkAkQMCBQJibAUBbwkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmJsBQFwCQDZBAEJAJEDAgUCYmwFAXEJAQJiaAEJAJEDAgUCYmwFAXIJAQJiaAEJAJEDAgUCYmwFAXMJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJibAUBdAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmJsBQF1AAJibQkBAmJrAQkBAmJlAAACYm4FAmJtAAJibwgFAmJuAl8xAAJicAgFAmJuAl8yAAJicQgFAmJuAl8zAAJicggFAmJuAl80AAJicwgFAmJuAl81AAJidAgFAmJuAl82AAJidQgFAmJuAl83AQJidgAJALUJAgkBAmFPAgUCYVYJAQJhdgAFAWoAAmJ3CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkAkQMCCQECYnYABQFCAhlpbmNvcnJlY3Qgc3Rha2luZyBhZGRyZXNzAAJieAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJAJEDAgkBAmJ2AAUBQwIZaW5jb3JyZWN0IHN0YWtpbmcgYWRkcmVzcwECYnkKAmJ6AmJBAmJCAmJDAmJEAmJFAmJGAmJHAmJIAmJJCQC5CQIJAMwIAgIUJWQlZCVkJWQlZCVkJWQlZCVkJWQJAMwIAgkApAMBBQJiegkAzAgCCQCkAwEFAmJBCQDMCAIJAKQDAQUCYkIJAMwIAgkApAMBBQJiQwkAzAgCCQCkAwEFAmJECQDMCAIJAKQDAQUCYkUJAMwIAgkApAMBBQJiRgkAzAgCCQCkAwEFAmJHCQDMCAIJAKQDAQUCYkgJAMwIAgkApAMBBQJiSQUDbmlsBQFqAQJiSgYCYksCYkwCYk0CYkMCYkYCYkcJALkJAgkAzAgCAgwlZCVkJWQlZCVkJWQJAMwIAgkApAMBBQJiSwkAzAgCCQCkAwEFAmJMCQDMCAIJAKQDAQUCYk0JAMwIAgkApAMBBQJiQwkAzAgCCQCkAwEFAmJGCQDMCAIJAKQDAQUCYkcFA25pbAUBagECYk4BAmFyBAJiTwMJAAACBQJhcgIFV0FWRVMICQDvBwEFBHRoaXMJYXZhaWxhYmxlCQDwBwIFBHRoaXMJANkEAQUCYXIEAmJQCQBlAgkAZAIFAmJPCQECYXQBBQJhcgkBAmF1AQUCYXIJAJYDAQkAzAgCAAAJAMwIAgUCYlAFA25pbAECYlECAmJSAmJTCQC8AgMFAmJSBQFkBQJiUwECYlQDAmJSAmJTAUwJAL0CBAUCYlIFAWQFAmJTBQFMAQJiVQECYlYEAmJXCQD8BwQFAmJWAgdnZXRSYXRlBQNuaWwFA25pbAMJAAACBQJiVwUCYlcEAmJYBQJiVwMJAAECBQJiWAIDSW50BAJiWQUCYlgFAmJZCQECYVMBAiBwcm94eS5nZXRSYXRlKCkgdW5leHBlY3RlZCB2YWx1ZQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgECYloEAmFyAmNhAmNiAmJWBAJjYwkBAmF0AQUCYXIDCQAAAgUCY2MFAmNjBAJjZAkBAmF1AQUCY2IDCQAAAgUCY2QFAmNkBAJjZQkBAmJoAQUCYXIDCQBmAgUCY2EAAAQCY2YJAPwHBAUCYlYCB2RlcG9zaXQFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUCY2UFAmNhBQNuaWwDCQAAAgUCY2YFAmNmBAJiWAUCY2YDCQABAgUCYlgCA0ludAQCY2cFAmJYBAJjaAkAZAIFAmNjBQJjYQQCY2kJAGQCBQJjZAUCY2cJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJhcQEFAmFyBQJjaAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAmFzAQUCY2IFAmNpBQNuaWwFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJjagYCYXICY2ECY2ICYlYCY2sCY2wEAmNjCQECYXQBBQJhcgMJAAACBQJjYwUCY2MEAmNkCQECYXUBBQJjYgMJAAACBQJjZAUCY2QEAmNtCQECYlUBBQJiVgMJAAACBQJjbQUCY20EAmNuCQBrAwUCY2sFAmNjBQJjZAQCY28JAQJiaAEFAmNiBAJjcAkAawMFAmNrBQJjYQUCY24EAmNxCQBrAwUCY2sFAmNhBQJjbQQCY3IJAJYDAQkAzAgCAAAJAMwIAgkAZQIFAmNwBQJjcQUDbmlsAwkAZgIFAmNxAAAEAmNzCQD8BwQFAmJWAgh3aXRoZHJhdwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQJjbwUCY3EFA25pbAMJAAACBQJjcwUCY3MEAmJYBQJjcwMJAAECBQJiWAIDSW50BAJjdAUCYlgEAmNoCQBlAgUCY2MFAmN0BAJjaQkAZQIJAGUCBQJjZAUCY3EFAmNyCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYXEBBQJhcgUCY2gJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJhcwEFAmNiBQJjaQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQJjbAUCY3IJAQJiaAEFAmNiBQNuaWwFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJjdQECYXIJAPwHBAUCYVYCGmdldFBvb2xMZWFzZUNvbmZpZ1JFQURPTkxZCQDMCAIJAKUIAQUEdGhpcwkAzAgCBQJhcgUDbmlsBQNuaWwBAmN2BwJjdwJhcgJjYgJjeAJiVgJjawJjbAQCY2MJAQJhdAEFAmFyAwkAAAIFAmNjBQJjYwQCY2QJAQJhdQEFAmNiAwkAAAIFAmNkBQJjZAQCY3kEAmJYCQECYmgBBQJhcgMJAAECBQJiWAIKQnl0ZVZlY3RvcgQCY3oFAmJYCQDwBwIFBHRoaXMFAmN6AwkAAQIFAmJYAgRVbml0BAJjQQUCYlgICQDvBwEFBHRoaXMJYXZhaWxhYmxlCQACAQILTWF0Y2ggZXJyb3IDCQAAAgUCY3kFAmN5BAJjQgkAlgMBCQDMCAIAAAkAzAgCCQBlAgkAZAIFAmN5BQJjYwUCY3gFA25pbAQCY0MJAGsDBQJjdwUCY0IAZAQCY0QJAGUCBQJjYwUCY0MDCQAAAgUCY0QAAAUDbmlsAwkAZgIAAAUCY0QEAmNFCQEBLQEFAmNECQECYloEBQJhcgUCY0UFAmNiBQJiVgQCY0YFAmNECQECY2oGBQJhcgUCY0YFAmNiBQJiVgUCY2sFAmNsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJjRwECYXIEAmJYCQECY3UBBQJhcgMJAAECBQJiWAIwKEJvb2xlYW4sIEludCwgSW50LCBTdHJpbmcsIFN0cmluZywgSW50LCBTdHJpbmcpBAJjSAUCYlgEAmNJBQJjSAQCY0oIBQJjSQJfMQQCY0sIBQJjSQJfMgQCY3gIBQJjSQJfMwQCY0wIBQJjSQJfNAQCY00IBQJjSQJfNQQCY2sIBQJjSQJfNgQCY04IBQJjSQJfNwMFAmNKCQECY3YHBQJjSwUCYXIFAmNNBQJjeAkBEUBleHRyTmF0aXZlKDEwNjIpAQUCY0wFAmNrCQERQGV4dHJOYXRpdmUoMTA2MikBBQJjTgUDbmlsCQECYVMBCQCsAgIJAKwCAgIBWwUCYXICEV0gUmViYWxhbmNlIGVycm9yAQJjTwICYXICY1AEAmJYCQECY3UBBQJhcgMJAAECBQJiWAIwKEJvb2xlYW4sIEludCwgSW50LCBTdHJpbmcsIFN0cmluZywgSW50LCBTdHJpbmcpBAJjSAUCYlgEAmNRBQJjSAQCY0oIBQJjUQJfMQQCY0sIBQJjUQJfMgQCY3gIBQJjUQJfMwQCY0wIBQJjUQJfNAQCY00IBQJjUQJfNQQCY2sIBQJjUQJfNgQCY04IBQJjUQJfNwMFAmNKBAJjUgkAlgMBCQDMCAIAAAkAzAgCCQBlAgkAZQIJAQJiTgEFAmFyBQJjUAUCY3gFA25pbAMJAAACBQJjUgUCY1IEAmNoCQBrAwUCY0sFAmNSAGQDCQAAAgUCY2gFAmNoBAJjUwkAlgMBCQDMCAIAAAkAzAgCCQBlAgkBAmF0AQUCYXIFAmNoBQNuaWwDCQAAAgUCY1MFAmNTCQECY2oGBQJhcgUCY1MFAmNNCQERQGV4dHJOYXRpdmUoMTA2MikBBQJjTAUCY2sJARFAZXh0ck5hdGl2ZSgxMDYyKQEFAmNOCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuBQNuaWwJAQJhUwEJAKwCAgkArAICAgFbBQJhcgIfXSBnZXRXaXRoZHJhd0Fzc2V0U3RhdGUoKSBlcnJvcgECY1QEAmNVAmNWAmNXAmNYBAJjWQkBAUQCBQJjVwUCY1UEAmNaCQEBRAIFAmNYBQJjVgkBAmJRAgUCY1oFAmNZAQJkYQMCY1cCY1gCZGIEAmRjCQECYmUABAJkZAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmRjBQF0BAJkZQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmRjBQF1BAJkZgkBAmNUBAUCZGQFAmRlBQJjVwUCY1gEAmJTCQEBRAIFAmNXBQJkZAQCYlIJAQFEAgUCY1gFAmRlBAJkZwkBAUQCBQJkYgUBYgQCZGgJAQJiUQIFAmJTBQJkZwQCZGkJAQJiUQIFAmJSBQJkZwkAzAgCBQJkZgkAzAgCBQJkaAkAzAgCBQJkaQUDbmlsAQJkagMCY1cCY1gCZGIEAmRrCQECZGEDBQJjVwUCY1gFAmRiCQDMCAIJAQFIAgkAkQMCBQJkawAABQFiCQDMCAIJAQFIAgkAkQMCBQJkawABBQFiCQDMCAIJAQFIAgkAkQMCBQJkawACBQFiBQNuaWwBAmRsBAJkbQJkbgJkbwJhYgQCZGMJAQJiZQAEAmRwCQCRAwIFAmRjBQFxBAJkcQkAkQMCBQJkYwUBcgQCZHIJAJEDAgUCZGMFAXMEAmNVCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCZGMFAXQEAmNWCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCZGMFAXUEAmRzCQCRAwIFAmRjBQFwBAJkdAgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBCQDZBAEFAmRwCQCsAgIJAKwCAgIGQXNzZXQgBQJkcAIOIGRvZXNuJ3QgZXhpc3QIcXVhbnRpdHkDCQECIT0CBQJkcAUCZG4JAAIBAhVJbnZhbGlkIGFzc2V0IHBhc3NlZC4EAmR1CQECYk4BBQJkcQQCZHYJAQFEAgUCZHUFAmNVBAJkdwkBAmJOAQUCZHIEAmR4CQEBRAIFAmR3BQJjVgQCZHkJAQJiUQIFAmR4BQJkdgQCZHoJAQFIAgUCZHkFAWIEAmRBCQEBRAIFAmRvBQFiBAJkQgkBAUQCBQJkdAUBYgQCZEMJALwCAwUCZHYFAmRBBQJkQgQCZEQJALwCAwUCZHgFAmRBBQJkQgQCZEUJAQFLAwUCZEMFAmNVBQVGTE9PUgQCZEYJAQFLAwUCZEQFAmNWBQVGTE9PUgQCZEcJAQJjTwIFAmRxBQJkRQMJAAACBQJkRwUCZEcEAmRICQECY08CBQJkcgUCZEYDCQAAAgUCZEgFAmRIBAJkSQMJAAACBQJkbQIABQNuaWwJAM4IAgkAzggCBQJkRwUCZEgJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUCYWIFAmRFAwkAAAIFAmRxAgVXQVZFUwUEdW5pdAkA2QQBBQJkcQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQJhYgUCZEYDCQAAAgUCZHICBVdBVkVTBQR1bml0CQDZBAEFAmRyCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhZAIJAKUIAQUCYWIFAmRtCQECYkoGBQJkRQUCZEYFAmRvBQJkegUGaGVpZ2h0CAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAVcABQJkegkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAVgCBQZoZWlnaHQIBQlsYXN0QmxvY2sJdGltZXN0YW1wBQJkegUDbmlsCQCcCgoFAmRFBQJkRgUCZHEFAmRyBQJkdQUCZHcFAmR0BQJkeQUCZHMFAmRJCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJkSgkCZG0CZEsCZEwCZE0CZE4CZE8CYWICZFACZFEEAmRjCQECYmUABAJkcAkA2QQBCQCRAwIFAmRjBQFxBAJkUgkAkQMCBQJkYwUBcgQCZFMJAJEDAgUCZGMFAXMEAmRUCQCRAwIFAmRjBQF2BAJkVQkAkQMCBQJkYwUBdwQCZGQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJkYwUBdAQCZGUJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJkYwUBdQQCZHMJAJEDAgUCZGMFAXAEAmR0CAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQDsBwEFAmRwCQCsAgIJAKwCAgIGQXNzZXQgCQDYBAEFAmRwAg4gZG9lc24ndCBleGlzdAhxdWFudGl0eQQCZFYJANgEAQkBC3ZhbHVlT3JFbHNlAgUCZE0JANkEAQIFV0FWRVMEAmRXCQDYBAEJAQt2YWx1ZU9yRWxzZQIFAmRPCQDZBAECBVdBVkVTAwMJAQIhPQIFAmRSBQJkVgYJAQIhPQIFAmRTBQJkVwkAAgECIkludmFsaWQgYW10IG9yIHByaWNlIGFzc2V0IHBhc3NlZC4EAmR1AwUCZFAJAQJiTgEFAmRSCQBlAgkBAmJOAQUCZFIFAmRMBAJkdwMFAmRQCQECYk4BBQJkUwkAZQIJAQJiTgEFAmRTBQJkTgQCZFgJAQFEAgUCZEwFAmRkBAJkWQkBAUQCBQJkTgUCZGUEAmRaCQECYlECBQJkWQUCZFgEAmR2CQEBRAIFAmR1BQJkZAQCZHgJAQFEAgUCZHcFAmRlBAJlYQMJAAACBQJkdAAABAJkeQUBZQQCZWIFAWUEAmRnCQB2BgkAuQICBQJkWAUCZFkAAAkAtgIBAAUAAQAABQRET1dOCQCXCgUJAQFIAgUCZGcFAWIJAQFIAgUCZFgFAmRkCQEBSAIFAmRZBQJkZQkBAmJRAgkAtwICBQJkeAUCZFkJALcCAgUCZHYFAmRYBQJlYgQCZHkJAQJiUQIFAmR4BQJkdgQCZWIJALwCAwkBAVIBCQC4AgIFAmR5BQJkWgUBZAUCZHkEAmVjCQEBRAIFAmRLBQFiAwMJAQIhPQIFAmR5BQFlCQC/AgIFAmViBQJlYwcJAAIBCQCsAgIJAKwCAgkArAICAg9QcmljZSBzbGlwcGFnZSAJAKYDAQUCZWICHiBleGNlZWRlZCB0aGUgcGFzc2VkIGxpbWl0IG9mIAkApgMBBQJlYwQCZEIJAQFEAgUCZHQFAWIEAmVkCQC9AgQFAmRYCQECYlQDBQJkeAUCZHYFB0NFSUxJTkcFAWQFB0NFSUxJTkcEAmVlCQC9AgQFAmRZBQFkCQECYlQDBQJkeAUCZHYFBUZMT09SBQdDRUlMSU5HBAJlZgMJAL8CAgUCZWQFAmRZCQCUCgIFAmVlBQJkWQkAlAoCBQJkWAUCZWQEAmVnCAUCZWYCXzEEAmVoCAUCZWYCXzIEAmRnCQC9AgQFAmRCBQJlaAUCZHgFBUZMT09SCQCXCgUJAQFLAwUCZGcFAWIFBUZMT09SCQEBSwMFAmVnBQJkZAUHQ0VJTElORwkBAUsDBQJlaAUCZGUFB0NFSUxJTkcFAmR5BQJlYgQCZWkIBQJlYQJfMQQCZWoIBQJlYQJfMgQCZWsIBQJlYQJfMwQCZHoJAQFIAggFAmVhAl80BQFiBAJlbAkBAUgCCAUCZWECXzUFAWIDCQBnAgAABQJlaQkAAgECNkludmFsaWQgY2FsY3VsYXRpb25zLiBMUCBjYWxjdWxhdGVkIGlzIGxlc3MgdGhhbiB6ZXJvLgQCZW0DCQEBIQEFAmRRAAAFAmVpBAJlbgkAZQIFAmRMBQJlagQCZW8JAGUCBQJkTgUCZWsEAmVwCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBVwAFAmR6CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBWAIFBmhlaWdodAgFCWxhc3RCbG9jawl0aW1lc3RhbXAFAmR6CQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhYQIFAmFiBQJkbQkBAmJ5CgUCZWoFAmVrBQJlbQUCZHoFAmRLBQJlbAUGaGVpZ2h0CAUJbGFzdEJsb2NrCXRpbWVzdGFtcAUCZW4FAmVvBQNuaWwJAJ8KDQUCZWkFAmVtBQJkegUCZHUFAmR3BQJkdAUCZHAFAmRzBQJlcAUCZW4FAmVvBQJkTQUCZE8BAmVxAwJlcgJlcwJkdAQCZXQJAQFHAgUCZXIJALYCAQUCYnQEAmV1CQEBRwIFAmVzCQC2AgEFAmJ1BAJldgkAvAIDCQB2BgkAuQICBQJldAUCZXUAAAkAtgIBAAUAAQASBQRET1dOBQFnBQJkdAMJAAACBQJkdAUBZgUBZgUCZXYBAmV3AwJleAJleQJlegQCZUEJALgCAgkAtgIBCQECYk4BCQECYmoBBQJicgUCZXgEAmVCCQC4AgIJALYCAQkBAmJOAQkBAmJqAQUCYnMFAmV5BAJlQwkAuAICCQC2AgEICQEFdmFsdWUBCQDsBwEFAmJxCHF1YW50aXR5BQJlegQCZUQJAQJlcQMFAmVBBQJlQgUCZUMFAmVEAQJlRQMCZUYCZUcCZXoEAmVBCQBkAgkBAmJOAQkBAmJqAQUCYnIFAmVGBAJlQgkAZAIJAQJiTgEJAQJiagEFAmJzBQJlRwQCZUMJAGQCCAkBBXZhbHVlAQkA7AcBBQJicQhxdWFudGl0eQUCZXoEAmV2CQECZXEDCQC2AgEFAmVBCQC2AgEFAmVCCQC2AgEFAmVDBAJlSAkAzAgCCQEMSW50ZWdlckVudHJ5AgUCYWsFBmhlaWdodAkAzAgCCQELU3RyaW5nRW50cnkCBQJhagkApgMBBQJldgUDbmlsCQCUCgIFAmVIBQJldgECZUkCAmVKAmV2AwkAwAICBQJldgUCZUoGCQECYVMBCQC5CQIJAMwIAgIidXBkYXRlZCBLTHAgbG93ZXIgdGhhbiBjdXJyZW50IEtMcAkAzAgCCQCmAwEFAmVKCQDMCAIJAKYDAQUCZXYFA25pbAIBIAECZUsBAmVMBAJlQQkBAmJOAQkBAmJqAQUCYnIEAmVCCQECYk4BCQECYmoBBQJicwQCZU0IBQJlTAZhbW91bnQEAmVOCQBuBAgFAmVMBmFtb3VudAgFAmVMBXByaWNlBQFiBQVGTE9PUgQCZU8DCQAAAggFAmVMCW9yZGVyVHlwZQUDQnV5CQCUCgIFAmVNCQEBLQEFAmVOCQCUCgIJAQEtAQUCZU0FAmVOBAJlRggFAmVPAl8xBAJlRwgFAmVPAl8yAwMDCQECYmMABgkAAAIFAmJwBQFtBgkAAAIFAmJwBQFuCQACAQIcRXhjaGFuZ2Ugb3BlcmF0aW9ucyBkaXNhYmxlZAMDCQECIT0CCAgFAmVMCWFzc2V0UGFpcgthbW91bnRBc3NldAUCYnIGCQECIT0CCAgFAmVMCWFzc2V0UGFpcgpwcmljZUFzc2V0BQJicwkAAgECE1dyb25nIG9yZGVyIGFzc2V0cy4EAmVQCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKgDAQkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzBQJhagIBMAkBAmFVAQILaW52YWxpZCBrTHAEAmVRCQECZUUDBQJlRgUCZUcAAAQCZVIIBQJlUQJfMQQCZVMIBQJlUQJfMgQCZVQJAMACAgUCZVMFAmVQBAJlVQkAuQkCCQDMCAICBGtMcD0JAMwIAgkApgMBBQJlUAkAzAgCAggga0xwTmV3PQkAzAgCCQCmAwEFAmVTCQDMCAICFCBhbW91bnRBc3NldEJhbGFuY2U9CQDMCAIJAKQDAQUCZUEJAMwIAgITIHByaWNlQXNzZXRCYWxhbmNlPQkAzAgCCQCkAwEFAmVCCQDMCAICGSBhbW91bnRBc3NldEJhbGFuY2VEZWx0YT0JAMwIAgkApAMBBQJlRgkAzAgCAhggcHJpY2VBc3NldEJhbGFuY2VEZWx0YT0JAMwIAgkApAMBBQJlRwkAzAgCAgggaGVpZ2h0PQkAzAgCCQCkAwEFBmhlaWdodAUDbmlsAgAJAJQKAgUCZVQFAmVVAQJlVgECZVcDCQECIT0CCQCQAwEIBQJlVwhwYXltZW50cwABCQACAQIdZXhhY3RseSAxIHBheW1lbnQgaXMgZXhwZWN0ZWQEAmVYCQEFdmFsdWUBCQCRAwIIBQJlVwhwYXltZW50cwAABAJkbgkBBXZhbHVlAQgFAmVYB2Fzc2V0SWQEAmVZCAUCZVgGYW1vdW50BAJlYQkBAmRsBAkA2AQBCAUCZVcNdHJhbnNhY3Rpb25JZAkA2AQBBQJkbgUCZVkIBQJlVwZjYWxsZXIEAmRFCAUCZWECXzEEAmRGCAUCZWECXzIEAmRzCQENcGFyc2VJbnRWYWx1ZQEIBQJlYQJfOQQCZEkIBQJlYQNfMTADAwkBAmJjAAYJAAACBQJkcwUBbgkAAgEJAKwCAgIsR2V0IG9wZXJhdGlvbiBpcyBibG9ja2VkIGJ5IGFkbWluLiBTdGF0dXMgPSAJAKQDAQUCZHMJAJcKBQUCZEUFAmRGBQJlWQUCZG4FAmRJAQJlWgMCZVcCZEsCZFEDCQECIT0CCQCQAwEIBQJlVwhwYXltZW50cwACCQACAQIfZXhhY3RseSAyIHBheW1lbnRzIGFyZSBleHBlY3RlZAQCZmEJAQV2YWx1ZQEJAJEDAggFAmVXCHBheW1lbnRzAAAEAmZiCQEFdmFsdWUBCQCRAwIIBQJlVwhwYXltZW50cwABBAJmYwkBAmRKCQkA2AQBCAUCZVcNdHJhbnNhY3Rpb25JZAUCZEsIBQJmYQZhbW91bnQIBQJmYQdhc3NldElkCAUCZmIGYW1vdW50CAUCZmIHYXNzZXRJZAkApQgBCAUCZVcGY2FsbGVyBwUCZFEEAmRzCQENcGFyc2VJbnRWYWx1ZQEIBQJmYwJfOAMDAwkBAmJjAAYJAAACBQJkcwUBbAYJAAACBQJkcwUBbgkAAgEJAKwCAgIsUHV0IG9wZXJhdGlvbiBpcyBibG9ja2VkIGJ5IGFkbWluLiBTdGF0dXMgPSAJAKQDAQUCZHMFAmZjAQJmZAECY2EEAmZlCQD8BwQFAmFWAgRlbWl0CQDMCAIFAmNhBQNuaWwFA25pbAMJAAACBQJmZQUCZmUEAmZmBAJiWAUCZmUDCQABAgUCYlgCB0FkZHJlc3MEAmZnBQJiWAkA/AcEBQJmZwIEZW1pdAkAzAgCBQJjYQUDbmlsBQNuaWwFBHVuaXQDCQAAAgUCZmYFAmZmBQJjYQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgECZmgCAmNhAmFpBAJmaQMJAAACBQJhaQAAAAAJAGsDBQJjYQUCYWkFAWIJAJQKAgkAZQIFAmNhBQJmaQUCZmkBAmZqBAJmawJmbAJhYgJhYwQCZm0JAAACBQJhYwUEdW5pdAQCZm4JAQJiTgEJAQJiagEFAmJyBAJmbwkBAmJOAQkBAmJqAQUCYnMEAmZwAwkAAAIFAmZsBQJicgYDCQAAAgUCZmwFAmJzBwkBAmFTAQINaW52YWxpZCBhc3NldAQCZnEDBQJmbQkAlAoCBQJmbgUCZm8DBQJmcAkAlAoCCQBlAgUCZm4FAmZrBQJmbwkAlAoCBQJmbgkAZQIFAmZvBQJmawQCZnIIBQJmcQJfMQQCZnMIBQJmcQJfMgQCZnQDBQJmcAkAlAoCBQJmawAACQCUCgIAAAUCZmsEAmZ1CAUCZnQCXzEEAmZ2CAUCZnQCXzIEAmVNCAkBAmZoAgUCZnUFAmFYAl8xBAJlTggJAQJmaAIFAmZ2BQJhWAJfMQQCZncJAQJmaAIFAmZrBQJhWAQCZngIBQJmdwJfMQQCZmkIBQJmdwJfMgQCZnkJAGQCBQJmcgUCZU0EAmZ6CQBkAgUCZnMFAmVOBAJmQQkBAmJRAgkBAUQCBQJmegUCYnUJAQFEAgUCZnkFAmJ0BAJmQgkBAUgCBQJmQQUBYgQCZkMDBQJmcAUCZnIFAmZzBAJmRAkAtgIBBQJmQwQCZkUJALYCAQgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBBQJicQkArAICCQCsAgICBmFzc2V0IAkA2AQBBQJicQIOIGRvZXNuJ3QgZXhpc3QIcXVhbnRpdHkEAmZGAwkAvwICBQJmRQUBZgYJAQJhUwECImluaXRpYWwgZGVwb3NpdCByZXF1aXJlcyBhbGwgY29pbnMDCQAAAgUCZkYFAmZGBAJmRwkAtgIBBQJmeAQCZkgJAJYDAQkAzAgCAAAJAMwIAgkAoAMBCQC6AgIJALkCAgUCZkUJALgCAgkBCnNxcnRCaWdJbnQECQC3AgIFAWQJALoCAgkAuQICBQJmRwUBZAUCZkQAEgASBQRET1dOBQFkBQFkBQNuaWwEAmVwAwUCZm0FA25pbAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAVcABQJmQgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAVgCBQZoZWlnaHQIBQlsYXN0QmxvY2sJdGltZXN0YW1wBQJmQgkAzAgCCQELU3RyaW5nRW50cnkCCQECYWECCQClCAEJAQV2YWx1ZQEFAmFiCQDYBAEJAQV2YWx1ZQEFAmFjCQECYnkKBQJmdQUCZnYFAmZIBQJmQgAAAAAFBmhlaWdodAgFCWxhc3RCbG9jawl0aW1lc3RhbXAAAAAABQNuaWwEAmZJCQECYlECCQEBRAIFAmZzBQJidQkBAUQCBQJmcgUCYnQEAmZKCQEBSAIFAmZJBQFiBAJmSwQCZkwDBQJmcAkAlAoCBQJmdQUCZnIJAJQKAgUCZnYFAmZzBAJjYQgFAmZMAl8xBAJmTQgFAmZMAl8yBAJmTgkAoAMBCQC8AgMFAmZFCQC2AgEJAGkCBQJjYQACCQC2AgEFAmZNCQBrAwkAZQIFAmZIBQJmTgUBYgUCZk4JAJcKBQUCZkgFAmVwBQJmaQUCZksFAmZwCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJmTwUCZlACZngCZmwCYWICYWMEAmZtCQAAAgUCYWMFBHVuaXQEAmRjCQECYmUABAJkZAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmRjBQF0BAJkZQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmRjBQF1BAJmUQkAzAgCAwkAAAIFAmZsBQJicQYJAQJhUwECEGludmFsaWQgbHAgYXNzZXQFA25pbAMJAAACBQJmUQUCZlEEAmZSAwkAAAIFAmZQBQJicgYDCQAAAgUCZlAFAmJzBwkBAmFTAQINaW52YWxpZCBhc3NldAQCZlMDBQJmUgkAtgIBCQECYk4BCQECYmoBBQJicgkAtgIBCQECYk4BCQECYmoBBQJicwQCZlQDBQJmUgUCZGQFAmRlBAJmVQkBAmJOAQkBAmJqAQUCYnIEAmZWCQECYk4BCQECYmoBBQJicwQCZlcDBQJmUgUCZlUFAmZWBAJmWAkAtgIBBQJmVwQCZkUJALYCAQgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBBQJicQkArAICCQCsAgICBmFzc2V0IAkA2AQBBQJicQIOIGRvZXNuJ3QgZXhpc3QIcXVhbnRpdHkEAmZZCQC2AgEFAmZ4BAJmWgkAlgMBCQDMCAIAAAkAzAgCCQCgAwEJALoCAgkAuQICBQJmUwkAuAICBQFkCQB2BgkAuAICBQFkCQC6AgIJALkCAgUCZlkFAWQFAmZFABIFAWgAAAASBQRET1dOBQFkBQNuaWwEAmdhCQECZmgCBQJmWgUCYVoEAmdiCAUCZ2ECXzEEAmZpCAUCZ2ECXzIEAmdjAwUCZlIJAJYKBAUCZ2IAAAkAZQIFAmZVBQJmWgUCZlYJAJYKBAAABQJnYgUCZlUJAGUCBQJmVgUCZloEAmdkCAUCZ2MCXzEEAmdlCAUCZ2MCXzIEAmdmCAUCZ2MCXzMEAmdnCAUCZ2MCXzQEAmZBCQECYlECCQEBRAIFAmdnBQJidQkBAUQCBQJnZgUCYnQEAmZCCQEBSAIFAmZBBQFiBAJlcAMFAmZtBQNuaWwJAMwIAgkBC1N0cmluZ0VudHJ5AgkBAmFkAgkApQgBCQEFdmFsdWUBBQJhYgkA2AQBCQEFdmFsdWUBBQJhYwkBAmJKBgUCZ2QFAmdlBQJmeAUCZkIFBmhlaWdodAgFCWxhc3RCbG9jawl0aW1lc3RhbXAJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFXAAUCZkIJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFYAgUGaGVpZ2h0CAUJbGFzdEJsb2NrCXRpbWVzdGFtcAUCZkIFA25pbAQCZkkJAQJiUQIJAQFEAgUCZlYFAmJ1CQEBRAIFAmZVBQJidAQCZkoJAQFIAgUCZkkFAWIEAmZLBAJnaAkAaAIJAKADAQkAvAIDBQJmUwUCZlkFAmZFAAIJAGsDCQBlAgUCZ2IFAmdoBQFiBQJnaAkAlwoFBQJnYgUCZXAFAmZpBQJmSwUCZlIJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAmdpAAQCYlgJAKIIAQkBAVUAAwkAAQIFAmJYAgZTdHJpbmcEAmdqBQJiWAkA2QQBBQJnagMJAAECBQJiWAIEVW5pdAUEdW5pdAkAAgECC01hdGNoIGVycm9yAQJnawAEAmJYCQCiCAEJAQFWAAMJAAECBQJiWAIGU3RyaW5nBAJnagUCYlgJANkEAQUCZ2oDCQABAgUCYlgCBFVuaXQFBHVuaXQJAAIBAgtNYXRjaCBlcnJvcgECZ2wBAmVXBAJiWAkBAmdpAAMJAAECBQJiWAIKQnl0ZVZlY3RvcgQCZ20FAmJYCQAAAggFAmVXD2NhbGxlclB1YmxpY0tleQUCZ20DCQABAgUCYlgCBFVuaXQJAAACCAUCZVcGY2FsbGVyBQR0aGlzCQACAQILTWF0Y2ggZXJyb3IBAmduAQJlVwQCZ28JAAIBAhFQZXJtaXNzaW9uIGRlbmllZAQCYlgJAQJnaQADCQABAgUCYlgCCkJ5dGVWZWN0b3IEAmdtBQJiWAMJAAACCAUCZVcPY2FsbGVyUHVibGljS2V5BQJnbQYFAmdvAwkAAQIFAmJYAgRVbml0AwkAAAIIBQJlVwZjYWxsZXIFBHRoaXMGBQJnbwkAAgECC01hdGNoIGVycm9yHgJlVwEJcmViYWxhbmNlAAkAzggCCQECY0cBCQECYU8CBQR0aGlzCQECYWUACQECY0cBCQECYU8CBQR0aGlzCQECYWYAAmVXASFjYWxjdWxhdGVBbW91bnRPdXRGb3JTd2FwUkVBRE9OTFkDAmdwAmdxAmdyBAJncwMJAAACBQJncQcEAmd0CQECYU8CBQR0aGlzCQECYWYABAJndQkBAmFPAgUEdGhpcwkBAmFlAAkAlAoCBQJndAUCZ3UEAmd0CQECYU8CBQR0aGlzCQECYWUABAJndQkBAmFPAgUEdGhpcwkBAmFmAAkAlAoCBQJndAUCZ3UEAmd0CAUCZ3MCXzEEAmd1CAUCZ3MCXzIEAmd2CQECYk4BBQJndQQCZ3cJAQJiTgEFAmd0BAJneAkAawMFAmd3BQJncAkAZAIFAmd2BQJncAQCZ3kJALkCAgkAtgIBBQJndgkAtgIBBQJndwQCZ3oJALkCAgkAtwICCQC3AgIJALYCAQkBAmJOAQUCZ3UJALYCAQUCZ3AJALYCAQUCZ3IJALgCAgkAtgIBCQECYk4BBQJndAkAtgIBBQJneAQCZ0EDCQDAAgIFAmd6BQJneQYJAAIBAhRuZXcgSyBpcyBmZXdlciBlcnJvcgMJAAACBQJnQQUCZ0EJAJQKAgUDbmlsBQJneAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJlVwEmY2FsY3VsYXRlQW1vdW50T3V0Rm9yU3dhcEFuZFNlbmRUb2tlbnMFAmdwAmdxAmdCAmdDAmdyBAJnRAoAAmFZCQD8BwQFAmFWAhdnZXRTd2FwQ29udHJhY3RSRUFET05MWQUDbmlsBQNuaWwDCQABAgUCYVkCBlN0cmluZwUCYVkJAAIBCQCsAgIJAAMBBQJhWQIbIGNvdWxkbid0IGJlIGNhc3QgdG8gU3RyaW5nBAJmUQkAzAgCAwkAZwIICQEFdmFsdWUBCQCRAwIIBQJlVwhwYXltZW50cwAABmFtb3VudAUCZ3AGCQECYVMBAgxXcm9uZyBhbW91bnQJAMwIAgMJAAACCAUCZVcGY2FsbGVyCQERQGV4dHJOYXRpdmUoMTA2MikBBQJnRAYJAQJhUwECEVBlcm1pc3Npb24gZGVuaWVkBQNuaWwDCQAAAgUCZlEFAmZRBAJlWAkBBXZhbHVlAQkAkQMCCAUCZVcIcGF5bWVudHMAAAQCZ3UJAQJiagEIBQJlWAdhc3NldElkBAJndAMJAAACBQJncQcJAQJhTwIFBHRoaXMJAQJhZgAJAQJhTwIFBHRoaXMJAQJhZQAEAmd2CQBlAgkBAmJOAQUCZ3UICQEFdmFsdWUBCQCRAwIIBQJlVwhwYXltZW50cwAABmFtb3VudAQCZ3cJAQJiTgEFAmd0BAJneAkAawMFAmd3BQJncAkAZAIFAmd2BQJncAQCZ3kJALkCAgkAtgIBBQJndgkAtgIBBQJndwQCZ3oJALkCAgkAtwICCQC2AgEJAQJiTgEFAmd1CQC2AgEFAmdyCQC4AgIJALYCAQkBAmJOAQUCZ3QJALYCAQUCZ3gEAmdBAwkAwAICBQJnegUCZ3kGCQACAQIUbmV3IEsgaXMgZmV3ZXIgZXJyb3IDCQAAAgUCZ0EFAmdBBAJnRQMJAGcCBQJneAUCZ0IGCQACAQIsRXhjaGFuZ2UgcmVzdWx0IGlzIGZld2VyIGNvaW5zIHRoYW4gZXhwZWN0ZWQDCQAAAgUCZ0UFAmdFBAJnRgQCYlgJAQJjdQEFAmd0AwkAAQIFAmJYAjAoQm9vbGVhbiwgSW50LCBJbnQsIFN0cmluZywgU3RyaW5nLCBJbnQsIFN0cmluZykEAmNIBQJiWAUCY0gJAAIBAhJlcnJvciBsZWFzZSBjb25maWcEAmdHCQECY08CBQJndAUCZ3gDCQAAAgUCZ0cFAmdHCQCUCgIJAM4IAgUCZ0cJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBEUBleHRyTmF0aXZlKDEwNjIpAQUCZ0MFAmd4CQECYmgBBQJndAUDbmlsBQJneAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJlVwEKc2V0TWFuYWdlcgECZ0gEAmdJCQECZ24BBQJlVwMJAAACBQJnSQUCZ0kEAmdKCQDZBAEFAmdIAwkAAAIFAmdKBQJnSgkAzAgCCQELU3RyaW5nRW50cnkCCQEBVgAFAmdIBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CZVcBDmNvbmZpcm1NYW5hZ2VyAAQCZ0sJAQJnawAEAmdMAwkBCWlzRGVmaW5lZAEFAmdLBgkAAgECEk5vIHBlbmRpbmcgbWFuYWdlcgMJAAACBQJnTAUCZ0wEAmdNAwkAAAIIBQJlVw9jYWxsZXJQdWJsaWNLZXkJAQV2YWx1ZQEFAmdLBgkAAgECG1lvdSBhcmUgbm90IHBlbmRpbmcgbWFuYWdlcgMJAAACBQJnTQUCZ00JAMwIAgkBC1N0cmluZ0VudHJ5AgkBAVUACQDYBAEJAQV2YWx1ZQEFAmdLCQDMCAIJAQtEZWxldGVFbnRyeQEJAQFWAAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmVXAQNwdXQCAmRLAmdOAwkAZgIAAAUCZEsJAAIBAiBJbnZhbGlkIHNsaXBwYWdlVG9sZXJhbmNlIHBhc3NlZAQCZmMJAQJlWgMFAmVXBQJkSwYEAmVtCAUCZmMCXzIEAmRwCAUCZmMCXzcEAmRJCAUCZmMCXzkEAmVuCAUCZmMDXzEwBAJlbwgFAmZjA18xMQQCZ08IBQJmYwNfMTIEAmdQCAUCZmMDXzEzBAJmYQkAtgIBCAkBBXZhbHVlAQkAkQMCCAUCZVcIcGF5bWVudHMAAAZhbW91bnQEAmZiCQC2AgEICQEFdmFsdWUBCQCRAwIIBQJlVwhwYXltZW50cwABBmFtb3VudAQCZUQJAQJldwMFAmZhBQJmYgkAtgIBAAADCQAAAgUCZUQFAmVEBAJmZQkA/AcEBQJhVgIEZW1pdAkAzAgCBQJlbQUDbmlsBQNuaWwDCQAAAgUCZmUFAmZlBAJmZgQCYlgFAmZlAwkAAQIFAmJYAgdBZGRyZXNzBAJmZwUCYlgJAPwHBAUCZmcCBGVtaXQJAMwIAgUCZW0FA25pbAUDbmlsBQR1bml0AwkAAAIFAmZmBQJmZgQCZ1EDCQBmAgUCZW4AAAkA/AcEBQJieAIDcHV0BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFAmdPBQJlbgUDbmlsBQNuaWwDCQAAAgUCZ1EFAmdRBAJnUgMJAGYCBQJlbwAACQD8BwQFAmJ4AgNwdXQFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUCZ1AFAmVvBQNuaWwFA25pbAMJAAACBQJnUgUCZ1IEAmdTAwUCZ04EAmdUCQD8BwQFAmJ3AgVzdGFrZQUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQJkcAUCZW0FA25pbAMJAAACBQJnVAUCZ1QFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUCZVcGY2FsbGVyBQJlbQUCZHAFA25pbAQCZ1UJAQJlRQMAAAAAAAADCQAAAgUCZ1UFAmdVBAJldggFAmdVAl8yBAJnVggFAmdVAl8xBAJnVwkBAmVJAgUCZUQFAmV2AwkAAAIFAmdXBQJnVwQCZ1gJAPwHBAUEdGhpcwIJcmViYWxhbmNlBQNuaWwFA25pbAMJAAACBQJnWAUCZ1gJAM4IAgkAzggCBQJkSQUCZ1MFAmdWCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmVXAQpwdXRGb3JGcmVlAQJnWQMJAGYCAAAFAmdZCQACAQIUSW52YWxpZCB2YWx1ZSBwYXNzZWQEAmZjCQECZVoDBQJlVwUCZ1kHBAJkSQgFAmZjAl85BAJmYQkAtgIBCAkBBXZhbHVlAQkAkQMCCAUCZVcIcGF5bWVudHMAAAZhbW91bnQEAmZiCQC2AgEICQEFdmFsdWUBCQCRAwIIBQJlVwhwYXltZW50cwABBmFtb3VudAQCZUQJAQJldwMFAmZhBQJmYgkAtgIBAAADCQAAAgUCZUQFAmVEBAJnWgkBAmVFAwAAAAAAAAQCZ1YIBQJnWgJfMQQCZXYIBQJnWgJfMgQCZ1cJAQJlSQIFAmVEBQJldgMJAAACBQJnVwUCZ1cJAM4IAgUCZEkFAmdWCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmVXAQlwdXRPbmVUa24CAmhhAmhiBAJoYwoAAmFZCQD8BwQFAmFWAihpc1Bvb2xPbmVUb2tlbk9wZXJhdGlvbnNEaXNhYmxlZFJFQURPTkxZCQDMCAIJAKUIAQUEdGhpcwUDbmlsBQNuaWwDCQABAgUCYVkCB0Jvb2xlYW4FAmFZCQACAQkArAICCQADAQUCYVkCHCBjb3VsZG4ndCBiZSBjYXN0IHRvIEJvb2xlYW4EAmhkAwMDCQECYmMABgkAAAIFAmJwBQFsBgkAAAIFAmJwBQFuBgUCaGMEAmZRCQDMCAIDAwkBASEBBQJoZAYJAQJnbAEFAmVXBgkBAmFTAQIhcHV0IG9wZXJhdGlvbiBpcyBibG9ja2VkIGJ5IGFkbWluCQDMCAIDCQAAAgkAkAMBCAUCZVcIcGF5bWVudHMAAQYJAQJhUwECHmV4YWN0bHkgMSBwYXltZW50IGFyZSBleHBlY3RlZAUDbmlsAwkAAAIFAmZRBQJmUQQCaGUJAJEDAggFAmVXCHBheW1lbnRzAAAEAmZsCAUCaGUHYXNzZXRJZAQCZmsIBQJoZQZhbW91bnQEAmVEAwkAAAIFAmZsBQJicgkBAmV3AwkAtgIBBQJmawkAtgIBAAAJALYCAQAAAwkAAAIFAmZsBQJicwkBAmV3AwkAtgIBAAAJALYCAQUCZmsJALYCAQAACQECYVMBAh5wYXltZW50IGFzc2V0IGlzIG5vdCBzdXBwb3J0ZWQDCQAAAgUCZUQFAmVEBAJhYggFAmVXBmNhbGxlcgQCYWMIBQJlVw10cmFuc2FjdGlvbklkBAJoZgkBAmZqBAUCZmsFAmZsBQJhYgUCYWMDCQAAAgUCaGYFAmhmBAJmcAgFAmhmAl81BAJoZwgFAmhmAl80BAJmaQgFAmhmAl8zBAJlcAgFAmhmAl8yBAJoaAgFAmhmAl8xBAJoaQMDCQBmAgUCaGEAAAkAZgIFAmhhBQJoaAcJAQJhUwEJALkJAgkAzAgCAh9hbW91bnQgdG8gcmVjZWl2ZSBpcyBsZXNzIHRoYW4gCQDMCAIJAKQDAQUCaGEFA25pbAIABQJoaAQCZmUJAQJmZAEFAmhpAwkAAAIFAmZlBQJmZQQCZ1MDBQJoYgQCaGoJAPwHBAUCYncCBXN0YWtlBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFAmJxBQJoaQUDbmlsAwkAAAIFAmhqBQJoagUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQJlVwZjYWxsZXIFAmhpBQJicQUDbmlsBAJoawMJAGYCBQJmaQAACQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFAmFXBQJmaQUCZmwFA25pbAUDbmlsBAJobAMJAAACBQR0aGlzBQJhVwkAlAoCAAAAAAMFAmZwCQCUCgIJAQEtAQUCZmkAAAkAlAoCAAAJAQEtAQUCZmkEAmVGCAUCaGwCXzEEAmVHCAUCaGwCXzIEAmhtCQECZUUDBQJlRgUCZUcAAAQCZ1YIBQJobQJfMQQCZXYIBQJobQJfMgQCZVAJAQV2YWx1ZQEJAKIIAQUCYWoEAmdXCQECZUkCBQJlRAUCZXYDCQAAAgUCZ1cFAmdXBAJnWAkA/AcEBQR0aGlzAglyZWJhbGFuY2UFA25pbAUDbmlsAwkAAAIFAmdYBQJnWAkAlAoCCQDOCAIJAM4IAgkAzggCBQJlcAUCZ1MFAmhrBQJnVgUCaGkJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CZVcBEXB1dE9uZVRrblJFQURPTkxZAgJmbAJmawQCaG4JAQJmagQFAmZrCQECYmgBBQJmbAUEdW5pdAUEdW5pdAQCaGgIBQJobgJfMQQCZXAIBQJobgJfMgQCZmkIBQJobgJfMwQCaGcIBQJobgJfNAQCZnAIBQJobgJfNQkAlAoCBQNuaWwJAJUKAwUCaGgFAmZpBQJoZwJlVwEJZ2V0T25lVGtuAgJobwJoYQQCaGMKAAJhWQkA/AcEBQJhVgIoaXNQb29sT25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWRSRUFET05MWQkAzAgCCQClCAEFBHRoaXMFA25pbAUDbmlsAwkAAQIFAmFZAgdCb29sZWFuBQJhWQkAAgEJAKwCAgkAAwEFAmFZAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuBAJocAMDCQECYmMABgkAAAIFAmJwBQFuBgUCaGMEAmZRCQDMCAIDAwkBASEBBQJocAYJAQJnbAEFAmVXBgkBAmFTAQIhZ2V0IG9wZXJhdGlvbiBpcyBibG9ja2VkIGJ5IGFkbWluCQDMCAIDCQAAAgkAkAMBCAUCZVcIcGF5bWVudHMAAQYJAQJhUwECHmV4YWN0bHkgMSBwYXltZW50IGFyZSBleHBlY3RlZAUDbmlsAwkAAAIFAmZRBQJmUQQCZlAJAQJiaAEFAmhvBAJoZQkAkQMCCAUCZVcIcGF5bWVudHMAAAQCZmwIBQJoZQdhc3NldElkBAJmeAgFAmhlBmFtb3VudAQCZUQJAQJldwMJALYCAQAACQC2AgEAAAkAtgIBAAADCQAAAgUCZUQFAmVEBAJhYggFAmVXBmNhbGxlcgQCYWMIBQJlVw10cmFuc2FjdGlvbklkBAJocQkBAmZPBQUCZlAFAmZ4BQJmbAUCYWIFAmFjAwkAAAIFAmhxBQJocQQCZlIIBQJocQJfNQQCaGcIBQJocQJfNAQCZmkIBQJocQJfMwQCZXAIBQJocQJfMgQCaHIIBQJocQJfMQQCY2EDAwkAZgIFAmhhAAAJAGYCBQJoYQUCaHIHCQECYVMBCQC5CQIJAMwIAgIfYW1vdW50IHRvIHJlY2VpdmUgaXMgbGVzcyB0aGFuIAkAzAgCCQCkAwEFAmhhBQNuaWwCAAUCaHIEAmdGBAJiWAkBAmN1AQUCaG8DCQABAgUCYlgCMChCb29sZWFuLCBJbnQsIEludCwgU3RyaW5nLCBTdHJpbmcsIEludCwgU3RyaW5nKQQCY0gFAmJYBQJjSAkAAgECEmVycm9yIGxlYXNlIGNvbmZpZwQCaHMJAPwHBAUCYVYCBGJ1cm4JAMwIAgUCZngFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUCZmwFAmZ4BQNuaWwDCQAAAgUCaHMFAmhzBAJnRwkBAmNPAgUCaG8FAmNhAwkAAAIFAmdHBQJnRwQCaHQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUCYWIFAmNhBQJmUAUDbmlsBAJoawMJAGYCBQJmaQAACQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFAmFXBQJmaQUCZlAFA25pbAUDbmlsBAJodQQCaHYDCQAAAgUEdGhpcwUCYVcAAAUCZmkDBQJmUgkAlAoCCQEBLQEJAGQCBQJjYQUCaHYAAAkAlAoCAAAJAQEtAQkAZAIFAmNhBQJodgQCZUYIBQJodQJfMQQCZUcIBQJodQJfMgQCaHcJAQJlRQMFAmVGBQJlRwAABAJnVggFAmh3Al8xBAJldggFAmh3Al8yBAJnVwkBAmVJAgUCZUQFAmV2AwkAAAIFAmdXBQJnVwkAlAoCCQDOCAIJAM4IAgkAzggCCQDOCAIFAmVwBQJnRwUCaHQFAmhrBQJnVgUCY2EJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CZVcBEWdldE9uZVRrblJFQURPTkxZAgJmUAJmeAQCaHgJAQJmTwUJAQJiaAEFAmZQBQJmeAUCYnEFBHVuaXQFBHVuaXQEAmhyCAUCaHgCXzEEAmVwCAUCaHgCXzIEAmZpCAUCaHgCXzMEAmhnCAUCaHgCXzQEAmZSCAUCaHgCXzUJAJQKAgUDbmlsCQCVCgMFAmhyBQJmaQUCaGcCZVcBE3Vuc3Rha2VBbmRHZXRPbmVUa24DAmh5AmhvAmhhBAJoYwoAAmFZCQD8BwQFAmFWAihpc1Bvb2xPbmVUb2tlbk9wZXJhdGlvbnNEaXNhYmxlZFJFQURPTkxZCQDMCAIJAKUIAQUEdGhpcwUDbmlsBQNuaWwDCQABAgUCYVkCB0Jvb2xlYW4FAmFZCQACAQkArAICCQADAQUCYVkCHCBjb3VsZG4ndCBiZSBjYXN0IHRvIEJvb2xlYW4EAmhwAwMJAQJiYwAGCQAAAgUCYnAFAW4GBQJoYwQCZlEJAMwIAgMDCQEBIQEFAmhwBgkBAmdsAQUCZVcGCQECYVMBAiFnZXQgb3BlcmF0aW9uIGlzIGJsb2NrZWQgYnkgYWRtaW4JAMwIAgMJAAACCQCQAwEIBQJlVwhwYXltZW50cwAABgkBAmFTAQIYbm8gcGF5bWVudHMgYXJlIGV4cGVjdGVkBQNuaWwDCQAAAgUCZlEFAmZRBAJmUAkBAmJoAQUCaG8EAmFiCAUCZVcGY2FsbGVyBAJhYwgFAmVXDXRyYW5zYWN0aW9uSWQEAmVECQECZXcDCQC2AgEAAAkAtgIBAAAJALYCAQAAAwkAAAIFAmVEBQJlRAQCaHoJAPwHBAUCYncCB3Vuc3Rha2UJAMwIAgkA2AQBBQJicQkAzAgCBQJoeQUDbmlsBQNuaWwDCQAAAgUCaHoFAmh6BAJoQQkBAmZPBQUCZlAFAmh5BQJicQUCYWIFAmFjAwkAAAIFAmhBBQJoQQQCZlIIBQJoQQJfNQQCaGcIBQJoQQJfNAQCZmkIBQJoQQJfMwQCZXAIBQJoQQJfMgQCaHIIBQJoQQJfMQQCY2EDAwkAZgIFAmhhAAAJAGYCBQJoYQUCaHIHCQECYVMBCQC5CQIJAMwIAgIfYW1vdW50IHRvIHJlY2VpdmUgaXMgbGVzcyB0aGFuIAkAzAgCCQCkAwEFAmhhBQNuaWwCAAUCaHIEAmhzCQD8BwQFAmFWAgRidXJuCQDMCAIFAmh5BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFAmJxBQJoeQUDbmlsAwkAAAIFAmhzBQJocwQCZ0cJAQJjTwIFAmhvBQJjYQMJAAACBQJnRwUCZ0cEAmh0CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQJlVwZjYWxsZXIFAmNhBQJmUAUDbmlsBAJoawMJAGYCBQJmaQAACQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFAmFXBQJmaQUCZlAFA25pbAUDbmlsBAJoQgQCaHYDCQAAAgUEdGhpcwUCYVcAAAUCZmkDBQJmUgkAlAoCCQEBLQEJAGQCBQJjYQUCaHYAAAkAlAoCAAAJAQEtAQkAZAIFAmNhBQJodgQCZUYIBQJoQgJfMQQCZUcIBQJoQgJfMgQCaEMJAQJlRQMFAmVGBQJlRwAABAJnVggFAmhDAl8xBAJldggFAmhDAl8yBAJnVwkBAmVJAgUCZUQFAmV2AwkAAAIFAmdXBQJnVwkAlAoCCQDOCAIJAM4IAgkAzggCCQDOCAIFAmVwBQJnRwUCaHQFAmhrBQJnVgUCY2EJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CZVcBA2dldAAEAmVhCQECZVYBBQJlVwQCaEQIBQJlYQJfMQQCZEYIBQJlYQJfMgQCZVkIBQJlYQJfMwQCZG4IBQJlYQJfNAQCZEkIBQJlYQJfNQQCZUQJAQJldwMJALYCAQAACQC2AgEAAAkAtgIBAAADCQAAAgUCZUQFAmVEBAJoRQkA/AcEBQJhVgIEYnVybgkAzAgCBQJlWQUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQJkbgUCZVkFA25pbAMJAAACBQJoRQUCaEUEAmhGCQECZUUDCQEBLQEFAmhECQEBLQEFAmRGAAAEAmdWCAUCaEYCXzEEAmV2CAUCaEYCXzIEAmdXCQECZUkCBQJlRAUCZXYDCQAAAgUCZ1cFAmdXCQDOCAIFAmRJBQJnVgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJlVwEJZ2V0Tm9MZXNzAgJoRwJoSAQCZWEJAQJlVgEFAmVXBAJkRQgFAmVhAl8xBAJkRggFAmVhAl8yBAJlWQgFAmVhAl8zBAJkbggFAmVhAl80BAJkSQgFAmVhAl81AwkAZgIFAmhHBQJkRQkAAgEJAKwCAgkArAICCQCsAgICHG5vTGVzc1RoZW5BbXRBc3NldCBmYWlsZWQ6ICAJAKQDAQUCZEUCAyA8IAkApAMBBQJoRwMJAGYCBQJoSAUCZEYJAAIBCQCsAgIJAKwCAgkArAICAh1ub0xlc3NUaGVuUHJpY2VBc3NldCBmYWlsZWQ6IAkApAMBBQJkRgIDIDwgCQCkAwEFAmhIBAJlRAkBAmV3AwkAtgIBAAAJALYCAQAACQC2AgEAAAMJAAACBQJlRAUCZUQEAmhFCQD8BwQFAmFWAgRidXJuCQDMCAIFAmVZBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFAmRuBQJlWQUDbmlsAwkAAAIFAmhFBQJoRQQCaEkJAQJlRQMJAQEtAQUCZEUJAQEtAQUCZEYAAAQCZ1YIBQJoSQJfMQQCZXYIBQJoSQJfMgQCZ1cJAQJlSQIFAmVEBQJldgMJAAACBQJnVwUCZ1cJAM4IAgUCZEkFAmdWCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmVXAQ11bnN0YWtlQW5kR2V0AQJjYQQCaEoDCQECIT0CCQCQAwEIBQJlVwhwYXltZW50cwAACQACAQIYTm8gcGF5bWVudHMgYXJlIGV4cGVjdGVkBgMJAAACBQJoSgUCaEoEAmRjCQECYmUABAJkcAkA2QQBCQCRAwIFAmRjBQFxBAJlRAkBAmV3AwkAtgIBAAAJALYCAQAACQC2AgEAAAMJAAACBQJlRAUCZUQEAmh6CQD8BwQFAmJ3Agd1bnN0YWtlCQDMCAIJANgEAQUCZHAJAMwIAgUCY2EFA25pbAUDbmlsAwkAAAIFAmh6BQJoegQCZWEJAQJkbAQJANgEAQgFAmVXDXRyYW5zYWN0aW9uSWQJANgEAQUCZHAFAmNhCAUCZVcGY2FsbGVyBAJkRQgFAmVhAl8xBAJkRggFAmVhAl8yBAJkcwkBDXBhcnNlSW50VmFsdWUBCAUCZWECXzkEAmRJCAUCZWEDXzEwBAJoSwMDCQECYmMABgkAAAIFAmRzBQFuCQACAQkArAICAixHZXQgb3BlcmF0aW9uIGlzIGJsb2NrZWQgYnkgYWRtaW4uIFN0YXR1cyA9IAkApAMBBQJkcwYDCQAAAgUCaEsFAmhLBAJoRQkA/AcEBQJhVgIEYnVybgkAzAgCBQJjYQUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQJkcAUCY2EFA25pbAMJAAACBQJoRQUCaEUEAmhMCQECZUUDCQEBLQEFAmRFCQEBLQEFAmRGAAAEAmdWCAUCaEwCXzEEAmV2CAUCaEwCXzIEAmdXCQECZUkCBQJlRAUCZXYDCQAAAgUCZ1cFAmdXCQDOCAIFAmRJBQJnVgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJlVwETdW5zdGFrZUFuZEdldE5vTGVzcwMCaHkCaE0CaEgEAmhwAwkBAmJjAAYJAAACBQJicAUBbgQCZlEJAMwIAgMJAQEhAQUCaHAGCQACAQIhZ2V0IG9wZXJhdGlvbiBpcyBibG9ja2VkIGJ5IGFkbWluCQDMCAIDCQAAAgkAkAMBCAUCZVcIcGF5bWVudHMAAAYJAAIBAhhubyBwYXltZW50cyBhcmUgZXhwZWN0ZWQFA25pbAMJAAACBQJmUQUCZlEEAmVECQECZXcDCQC2AgEAAAkAtgIBAAAJALYCAQAAAwkAAAIFAmVEBQJlRAQCaHoJAPwHBAUCYncCB3Vuc3Rha2UJAMwIAgkA2AQBBQJicQkAzAgCBQJoeQUDbmlsBQNuaWwDCQAAAgUCaHoFAmh6BAJlYQkBAmRsBAkA2AQBCAUCZVcNdHJhbnNhY3Rpb25JZAkA2AQBBQJicQUCaHkIBQJlVwZjYWxsZXIEAmRFCAUCZWECXzEEAmRGCAUCZWECXzIEAmRJCAUCZWEDXzEwBAJoTgkAzAgCAwkAZwIFAmRFBQJoTQYJAAIBCQC5CQIJAMwIAgIsYW1vdW50IGFzc2V0IGFtb3VudCB0byByZWNlaXZlIGlzIGxlc3MgdGhhbiAJAMwIAgkApAMBBQJoTQUDbmlsAgAJAMwIAgMJAGcCBQJkRgUCaEgGCQACAQkAuQkCCQDMCAICK3ByaWNlIGFzc2V0IGFtb3VudCB0byByZWNlaXZlIGlzIGxlc3MgdGhhbiAJAMwIAgkApAMBBQJoSAUDbmlsAgAFA25pbAMJAAACBQJoTgUCaE4EAmhFCQD8BwQFAmFWAgRidXJuCQDMCAIFAmh5BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFAmJxBQJoeQUDbmlsAwkAAAIFAmhFBQJoRQQCaE8JAQJlRQMJAQEtAQUCZEUJAQEtAQUCZEYAAAQCZ1YIBQJoTwJfMQQCZXYIBQJoTwJfMgQCZ1cJAQJlSQIFAmVEBQJldgMJAAACBQJnVwUCZ1cJAM4IAgUCZEkFAmdWCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmVXAQhhY3RpdmF0ZQICaFACaFEDCQECIT0CCQClCAEIBQJlVwZjYWxsZXIJAKUIAQUCYVYJAAIBAhJwZXJtaXNzaW9ucyBkZW5pZWQJAJQKAgkAzAgCCQELU3RyaW5nRW50cnkCCQECYWUABQJoUAkAzAgCCQELU3RyaW5nRW50cnkCCQECYWYABQJoUQUDbmlsAgdzdWNjZXNzAmVXAQpyZWZyZXNoS0xwAAQCaFIJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUCYWsAAAQCaFMDCQBnAgkAZQIFBmhlaWdodAUCaFIFAmFuBQR1bml0CQECYVMBCQC5CQIJAMwIAgkApAMBBQJhbgkAzAgCAi8gYmxvY2tzIGhhdmUgbm90IHBhc3NlZCBzaW5jZSB0aGUgcHJldmlvdXMgY2FsbAUDbmlsAgADCQAAAgUCaFMFAmhTBAJlUAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCoAwEJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwUCYWoCATAJAQJhVQECC2ludmFsaWQga0xwBAJoVAkBAmVFAwAAAAAAAAQCaFUIBQJoVAJfMQQCZXYIBQJoVAJfMgQCZUgDCQECIT0CBQJlUAUCZXYFAmhVCQECYVMBAhJub3RoaW5nIHRvIHJlZnJlc2gJAJQKAgUCZUgJAKYDAQUCZXYJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CZVcBHGdldFBvb2xDb25maWdXcmFwcGVyUkVBRE9OTFkACQCUCgIFA25pbAkBAmJlAAJlVwEcZ2V0QWNjQmFsYW5jZVdyYXBwZXJSRUFET05MWQECYXIJAJQKAgUDbmlsCQECYk4BBQJhcgJlVwEZY2FsY1ByaWNlc1dyYXBwZXJSRUFET05MWQMCY1cCY1gCZGIEAmRrCQECZGEDBQJjVwUCY1gFAmRiCQCUCgIFA25pbAkAzAgCCQCmAwEJAJEDAgUCZGsAAAkAzAgCCQCmAwEJAJEDAgUCZGsAAQkAzAgCCQCmAwEJAJEDAgUCZGsAAgUDbmlsAmVXARR0b1gxOFdyYXBwZXJSRUFET05MWQIBRQFGCQCUCgIFA25pbAkApgMBCQEBRAIFAUUFAUYCZVcBFmZyb21YMThXcmFwcGVyUkVBRE9OTFkCAUkBSgkAlAoCBQNuaWwJAQFIAgkApwMBBQFJBQFKAmVXAR5jYWxjUHJpY2VCaWdJbnRXcmFwcGVyUkVBRE9OTFkCAmJSAmJTCQCUCgIFA25pbAkApgMBCQECYlECCQCnAwEFAmJSCQCnAwEFAmJTAmVXASNlc3RpbWF0ZVB1dE9wZXJhdGlvbldyYXBwZXJSRUFET05MWQkCZG0CZEsCZEwCZE0CZE4CZE8CYWICZFACZFEJAJQKAgUDbmlsCQECZEoJBQJkbQUCZEsFAmRMBQJkTQUCZE4FAmRPBQJhYgUCZFAFAmRRAmVXASNlc3RpbWF0ZUdldE9wZXJhdGlvbldyYXBwZXJSRUFET05MWQQCZG0CZG4CZG8CYWIEAmVhCQECZGwEBQJkbQUCZG4FAmRvCQERQGV4dHJOYXRpdmUoMTA2MikBBQJhYgkAlAoCBQNuaWwJAJwKCggFAmVhAl8xCAUCZWECXzIIBQJlYQJfMwgFAmVhAl80CAUCZWECXzUIBQJlYQJfNggFAmVhAl83CQCmAwEIBQJlYQJfOAgFAmVhAl85CAUCZWEDXzEwAmVXAQ1zdGF0c1JFQURPTkxZAAQCZGMJAQJiZQAEAmRwCQDZBAEJAJEDAgUCZGMFAXEEAmhWCQCRAwIFAmRjBQFyBAJoVwkAkQMCBQJkYwUBcwQCZFQJAJEDAgUCZGMFAXYEAmRVCQCRAwIFAmRjBQF3BAJkZAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmRjBQF0BAJkZQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmRjBQF1BAJoWAgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBBQJkcAkArAICCQCsAgICBkFzc2V0IAkA2AQBBQJkcAIOIGRvZXNuJ3QgZXhpc3QIcXVhbnRpdHkEAmhZCQECYk4BBQJoVgQCaFoJAQJiTgEFAmhXBAJpYQMJAAACBQJoWAAACQDMCAIFAWUJAMwIAgUBZQkAzAgCBQFlBQNuaWwJAQJkYQMFAmhZBQJoWgUCaFgEAmR6AAAEAmliCQEBSAIJAJEDAgUCaWEAAQUBYgQCaWMJAQFIAgkAkQMCBQJpYQACBQFiBAJpZAkBBXZhbHVlAQkAmggCBQJhVgkBAmFGAQkApQgBBQR0aGlzCQCUCgIFA25pbAkAuQkCCQDMCAICDiVkJWQlZCVkJWQlZCVkCQDMCAIJAKQDAQUCaFkJAMwIAgkApAMBBQJoWgkAzAgCCQCkAwEFAmhYCQDMCAIJAKQDAQUCZHoJAMwIAgkApAMBBQJpYgkAzAgCCQCkAwEFAmljCQDMCAIJAKQDAQUCaWQFA25pbAUBagJlVwEgZXZhbHVhdGVQdXRCeUFtb3VudEFzc2V0UkVBRE9OTFkBAmRMBAJkYwkBAmJlAAQCZHAJANkEAQkAkQMCBQJkYwUBcQQCZFIJAJEDAgUCZGMFAXIEAmRxCQDZBAEFAmRSBAJkUwkAkQMCBQJkYwUBcwQCZHIJANkEAQUCZFMEAmRkCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCZGMFAXQEAmRlCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCZGMFAXUEAmRzCQCRAwIFAmRjBQFwBAJoWAgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBBQJkcAkArAICCQCsAgICBkFzc2V0IAkA2AQBBQJkcAIOIGRvZXNuJ3QgZXhpc3QIcXVhbnRpdHkEAmhZCQECYk4BBQJkUgQCaFoJAQJiTgEFAmRTBAJjWQkBAUQCBQJoWQUCZGQEAmNaCQEBRAIFAmhaBQJkZQQCZHkDCQAAAgUCaFgAAAUBZQkBAmJRAgUCY1oFAmNZBAJkWAkBAUQCBQJkTAUCZGQEAmRZCQC8AgMFAmRYBQJkeQUBZAQCZE4JAQFIAgUCZFkFAmRlBAJmYwkBAmRKCQIAAKDCHgUCZEwFAmRxBQJkTgUCZHICAAYHBAJlaQgFAmZjAl8xBAJpZQgFAmZjAl8zBAJkdQgFAmZjAl80BAJkdwgFAmZjAl81BAJkdAgFAmZjAl82CQCUCgIFA25pbAkAuQkCCQDMCAICECVkJWQlZCVkJWQlZCVkJWQJAMwIAgkApAMBBQJlaQkAzAgCCQCkAwEJAQFIAgUCZHkFAWIJAMwIAgkApAMBBQJkdQkAzAgCCQCkAwEFAmR3CQDMCAIJAKQDAQUCZHQJAMwIAgUCZHMJAMwIAgkApAMBBQJkTAkAzAgCCQCkAwEFAmROBQNuaWwFAWoCZVcBH2V2YWx1YXRlUHV0QnlQcmljZUFzc2V0UkVBRE9OTFkBAmROBAJkYwkBAmJlAAQCZHAJANkEAQkAkQMCBQJkYwUBcQQCZFIJAJEDAgUCZGMFAXIEAmRxCQDZBAEFAmRSBAJkUwkAkQMCBQJkYwUBcwQCZHIJANkEAQUCZFMEAmRkCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCZGMFAXQEAmRlCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCZGMFAXUEAmRzCQCRAwIFAmRjBQFwBAJoWAgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBBQJkcAkArAICCQCsAgICBkFzc2V0IAkA2AQBBQJkcAIOIGRvZXNuJ3QgZXhpc3QIcXVhbnRpdHkEAmlmCQECYk4BBQJkUgQCaWcJAQJiTgEFAmRTBAJpaAkBAUQCBQJpZgUCZGQEAmlpCQEBRAIFAmlnBQJkZQQCZHkDCQAAAgUCaFgAAAUBZQkBAmJRAgUCaWkFAmloBAJkWQkBAUQCBQJkTgUCZGUEAmRYCQC8AgMFAmRZBQFkBQJkeQQCZEwJAQFIAgUCZFgFAmRkBAJmYwkBAmRKCQIAAKDCHgUCZEwFAmRxBQJkTgUCZHICAAYHBAJlaQgFAmZjAl8xBAJpZQgFAmZjAl8zBAJkdQgFAmZjAl80BAJkdwgFAmZjAl81BAJkdAgFAmZjAl82CQCUCgIFA25pbAkAuQkCCQDMCAICECVkJWQlZCVkJWQlZCVkJWQJAMwIAgkApAMBBQJlaQkAzAgCCQCkAwEJAQFIAgUCZHkFAWIJAMwIAgkApAMBBQJkdQkAzAgCCQCkAwEFAmR3CQDMCAIJAKQDAQUCZHQJAMwIAgUCZHMJAMwIAgkApAMBBQJkTAkAzAgCCQCkAwEFAmROBQNuaWwFAWoCZVcBE2V2YWx1YXRlR2V0UkVBRE9OTFkCAmlqAmlrBAJlYQkBAmRsBAIABQJpagUCaWsFBHRoaXMEAmRFCAUCZWECXzEEAmRGCAUCZWECXzIEAmR1CAUCZWECXzUEAmR3CAUCZWECXzYEAmR0CAUCZWECXzcEAmR6CAUCZWECXzgEAmRzCQENcGFyc2VJbnRWYWx1ZQEIBQJlYQJfOQkAlAoCBQNuaWwJALkJAgkAzAgCAg4lZCVkJWQlZCVkJWQlZAkAzAgCCQCkAwEFAmRFCQDMCAIJAKQDAQUCZEYJAMwIAgkApAMBBQJkdQkAzAgCCQCkAwEFAmR3CQDMCAIJAKQDAQUCZHQJAMwIAgkApgMBBQJkegkAzAgCCQCkAwEFAmRzBQNuaWwFAWoBAmlsAQJpbQAEAmluBAJiWAkBAmdpAAMJAAECBQJiWAIKQnl0ZVZlY3RvcgQCZ20FAmJYBQJnbQMJAAECBQJiWAIEVW5pdAgFAmlsD3NlbmRlclB1YmxpY0tleQkAAgECC01hdGNoIGVycm9yBAJiWAUCaWwDCQABAgUCYlgCBU9yZGVyBAJlTAUCYlgEAmlvCQECYmQABAJpcAkBAmVLAQUCZUwEAmFLCAUCaXACXzEEAmFMCAUCaXACXzIEAmFNCQD0AwMIBQJlTAlib2R5Qnl0ZXMJAJEDAggFAmVMBnByb29mcwAACAUCZUwPc2VuZGVyUHVibGljS2V5BAJhTgkA9AMDCAUCZUwJYm9keUJ5dGVzCQCRAwIIBQJlTAZwcm9vZnMAAQUCaW8DAwMFAmFLBQJhTQcFAmFOBwYJAQJhSgQFAmFLBQJhTAUCYU0FAmFOAwkAAQIFAmJYAhRTZXRTY3JpcHRUcmFuc2FjdGlvbgQCZ2oFAmJYAwkA9AMDCAUCaWwJYm9keUJ5dGVzCQCRAwIIBQJpbAZwcm9vZnMAAAUCaW4GBAJpcQkA9gMBCQEFdmFsdWUBCAUCZ2oGc2NyaXB0BAJpcgkA2wQBCQEFdmFsdWUBCQCdCAIFAmFWCQECYUgABAJpcwkA8QcBBQR0aGlzAwkAAAIFAmlyBQJpcQkBAiE9AgUCaXMFAmlxBwkA9AMDCAUCaWwJYm9keUJ5dGVzCQCRAwIIBQJpbAZwcm9vZnMAAAUCaW4Trefl", "height": 2521028, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: FWHttZYRJev3zvgfbsguUzUScz9PT91b5SCSTgU7H5t1 Next: CkpjTGjm98L1e3GmUofCgmC8XqtKD2En7YfCku2fWJhx Diff:
Old | New | Differences | |
---|---|---|---|
448 | 448 | } | |
449 | 449 | ||
450 | 450 | ||
451 | - | func cO (ar, | |
451 | + | func cO (ar,cP) = { | |
452 | 452 | let bX = cu(ar) | |
453 | 453 | if ($isInstanceOf(bX, "(Boolean, Int, Int, String, String, Int, String)")) | |
454 | 454 | then { | |
455 | 455 | let cH = bX | |
456 | - | let | |
457 | - | let cJ = | |
458 | - | let cK = | |
459 | - | let cx = | |
460 | - | let cL = | |
461 | - | let cM = | |
462 | - | let ck = | |
463 | - | let cN = | |
456 | + | let cQ = cH | |
457 | + | let cJ = cQ._1 | |
458 | + | let cK = cQ._2 | |
459 | + | let cx = cQ._3 | |
460 | + | let cL = cQ._4 | |
461 | + | let cM = cQ._5 | |
462 | + | let ck = cQ._6 | |
463 | + | let cN = cQ._7 | |
464 | 464 | if (cJ) | |
465 | - | then cj(ar, ca, cM, addressFromStringValue(cL), ck, addressFromStringValue(cN)) | |
465 | + | then { | |
466 | + | let cR = max([0, ((bN(ar) - cP) - cx)]) | |
467 | + | if ((cR == cR)) | |
468 | + | then { | |
469 | + | let ch = fraction(cK, cR, 100) | |
470 | + | if ((ch == ch)) | |
471 | + | then { | |
472 | + | let cS = max([0, (at(ar) - ch)]) | |
473 | + | if ((cS == cS)) | |
474 | + | then cj(ar, cS, cM, addressFromStringValue(cL), ck, addressFromStringValue(cN)) | |
475 | + | else throw("Strict value is not equal to itself.") | |
476 | + | } | |
477 | + | else throw("Strict value is not equal to itself.") | |
478 | + | } | |
479 | + | else throw("Strict value is not equal to itself.") | |
480 | + | } | |
466 | 481 | else nil | |
467 | 482 | } | |
468 | - | else aS((("[" + ar) + "] | |
483 | + | else aS((("[" + ar) + "] getWithdrawAssetState() error")) | |
469 | 484 | } | |
470 | 485 | ||
471 | 486 | ||
472 | - | func cQ (ar,ca) = { | |
473 | - | let cR = { | |
474 | - | let bX = bh(ar) | |
475 | - | if ($isInstanceOf(bX, "ByteVector")) | |
476 | - | then { | |
477 | - | let cz = bX | |
478 | - | assetBalance(this, cz) | |
479 | - | } | |
480 | - | else if ($isInstanceOf(bX, "Unit")) | |
481 | - | then { | |
482 | - | let cS = bX | |
483 | - | wavesBalance(this).available | |
484 | - | } | |
485 | - | else throw("Match error") | |
486 | - | } | |
487 | - | if ((ca > cR)) | |
488 | - | then { | |
489 | - | let cT = (ca - cR) | |
490 | - | cO(ar, cT) | |
491 | - | } | |
492 | - | else nil | |
487 | + | func cT (cU,cV,cW,cX) = { | |
488 | + | let cY = D(cW, cU) | |
489 | + | let cZ = D(cX, cV) | |
490 | + | bQ(cZ, cY) | |
493 | 491 | } | |
494 | 492 | ||
495 | 493 | ||
496 | - | func cU (cV,cW,cX,cY) = { | |
497 | - | let cZ = D(cX, cV) | |
498 | - | let da = D(cY, cW) | |
499 | - | bQ(da, cZ) | |
494 | + | func da (cW,cX,db) = { | |
495 | + | let dc = be() | |
496 | + | let dd = parseIntValue(dc[t]) | |
497 | + | let de = parseIntValue(dc[u]) | |
498 | + | let df = cT(dd, de, cW, cX) | |
499 | + | let bS = D(cW, dd) | |
500 | + | let bR = D(cX, de) | |
501 | + | let dg = D(db, b) | |
502 | + | let dh = bQ(bS, dg) | |
503 | + | let di = bQ(bR, dg) | |
504 | + | [df, dh, di] | |
500 | 505 | } | |
501 | 506 | ||
502 | 507 | ||
503 | - | func db (cX,cY,dc) = { | |
504 | - | let dd = be() | |
505 | - | let de = parseIntValue(dd[t]) | |
506 | - | let df = parseIntValue(dd[u]) | |
507 | - | let dg = cU(de, df, cX, cY) | |
508 | - | let bS = D(cX, de) | |
509 | - | let bR = D(cY, df) | |
510 | - | let dh = D(dc, b) | |
511 | - | let di = bQ(bS, dh) | |
512 | - | let dj = bQ(bR, dh) | |
513 | - | [dg, di, dj] | |
508 | + | func dj (cW,cX,db) = { | |
509 | + | let dk = da(cW, cX, db) | |
510 | + | [H(dk[0], b), H(dk[1], b), H(dk[2], b)] | |
514 | 511 | } | |
515 | 512 | ||
516 | 513 | ||
517 | - | func dk (cX,cY,dc) = { | |
518 | - | let dl = db(cX, cY, dc) | |
519 | - | [H(dl[0], b), H(dl[1], b), H(dl[2], b)] | |
520 | - | } | |
521 | - | ||
522 | - | ||
523 | - | func dm (dn,do,dp,ab) = { | |
524 | - | let dd = be() | |
525 | - | let dq = dd[q] | |
526 | - | let dr = dd[r] | |
527 | - | let ds = dd[s] | |
528 | - | let cV = parseIntValue(dd[t]) | |
529 | - | let cW = parseIntValue(dd[u]) | |
530 | - | let dt = dd[p] | |
531 | - | let du = valueOrErrorMessage(assetInfo(fromBase58String(dq)), (("Asset " + dq) + " doesn't exist")).quantity | |
532 | - | if ((dq != do)) | |
514 | + | func dl (dm,dn,do,ab) = { | |
515 | + | let dc = be() | |
516 | + | let dp = dc[q] | |
517 | + | let dq = dc[r] | |
518 | + | let dr = dc[s] | |
519 | + | let cU = parseIntValue(dc[t]) | |
520 | + | let cV = parseIntValue(dc[u]) | |
521 | + | let ds = dc[p] | |
522 | + | let dt = valueOrErrorMessage(assetInfo(fromBase58String(dp)), (("Asset " + dp) + " doesn't exist")).quantity | |
523 | + | if ((dp != dn)) | |
533 | 524 | then throw("Invalid asset passed.") | |
534 | 525 | else { | |
535 | - | let dv = bN(dr) | |
536 | - | let dw = D(dv, cV) | |
537 | - | let dx = bN(ds) | |
538 | - | let dy = D(dx, cW) | |
539 | - | let dz = bQ(dy, dw) | |
540 | - | let dA = H(dz, b) | |
541 | - | let dB = D(dp, b) | |
542 | - | let dC = D(du, b) | |
543 | - | let dD = fraction(dw, dB, dC) | |
544 | - | let dE = fraction(dy, dB, dC) | |
526 | + | let du = bN(dq) | |
527 | + | let dv = D(du, cU) | |
528 | + | let dw = bN(dr) | |
529 | + | let dx = D(dw, cV) | |
530 | + | let dy = bQ(dx, dv) | |
531 | + | let dz = H(dy, b) | |
532 | + | let dA = D(do, b) | |
533 | + | let dB = D(dt, b) | |
534 | + | let dC = fraction(dv, dA, dB) | |
535 | + | let dD = fraction(dx, dA, dB) | |
536 | + | let dE = K(dC, cU, FLOOR) | |
545 | 537 | let dF = K(dD, cV, FLOOR) | |
546 | - | let dG = K(dE, cW, FLOOR) | |
547 | - | let dH = cQ(dr, dF) | |
548 | - | if ((dH == dH)) | |
538 | + | let dG = cO(dq, dE) | |
539 | + | if ((dG == dG)) | |
549 | 540 | then { | |
550 | - | let | |
551 | - | if (( | |
541 | + | let dH = cO(dr, dF) | |
542 | + | if ((dH == dH)) | |
552 | 543 | then { | |
553 | - | let dJ = invoke(this, "rebalance", nil, nil) | |
554 | - | if ((dJ == dJ)) | |
555 | - | then { | |
556 | - | let dK = if ((dn == "")) | |
557 | - | then nil | |
558 | - | else ((dH ++ dI) ++ [ScriptTransfer(ab, dF, if ((dr == "WAVES")) | |
559 | - | then unit | |
560 | - | else fromBase58String(dr)), ScriptTransfer(ab, dG, if ((ds == "WAVES")) | |
561 | - | then unit | |
562 | - | else fromBase58String(ds)), StringEntry(ad(toString(ab), dn), bJ(dF, dG, dp, dA, height, lastBlock.timestamp)), IntegerEntry(W(), dA), IntegerEntry(X(height, lastBlock.timestamp), dA)]) | |
563 | - | $Tuple10(dF, dG, dr, ds, dv, dx, du, dz, dt, dK) | |
564 | - | } | |
565 | - | else throw("Strict value is not equal to itself.") | |
544 | + | let dI = if ((dm == "")) | |
545 | + | then nil | |
546 | + | else ((dG ++ dH) ++ [ScriptTransfer(ab, dE, if ((dq == "WAVES")) | |
547 | + | then unit | |
548 | + | else fromBase58String(dq)), ScriptTransfer(ab, dF, if ((dr == "WAVES")) | |
549 | + | then unit | |
550 | + | else fromBase58String(dr)), StringEntry(ad(toString(ab), dm), bJ(dE, dF, do, dz, height, lastBlock.timestamp)), IntegerEntry(W(), dz), IntegerEntry(X(height, lastBlock.timestamp), dz)]) | |
551 | + | $Tuple10(dE, dF, dq, dr, du, dw, dt, dy, ds, dI) | |
566 | 552 | } | |
567 | 553 | else throw("Strict value is not equal to itself.") | |
568 | 554 | } | |
571 | 557 | } | |
572 | 558 | ||
573 | 559 | ||
574 | - | func | |
575 | - | let | |
576 | - | let | |
577 | - | let | |
578 | - | let | |
579 | - | let | |
580 | - | let | |
581 | - | let | |
582 | - | let | |
583 | - | let | |
584 | - | let | |
585 | - | let | |
586 | - | let | |
587 | - | if (if (( | |
560 | + | func dJ (dm,dK,dL,dM,dN,dO,ab,dP,dQ) = { | |
561 | + | let dc = be() | |
562 | + | let dp = fromBase58String(dc[q]) | |
563 | + | let dR = dc[r] | |
564 | + | let dS = dc[s] | |
565 | + | let dT = dc[v] | |
566 | + | let dU = dc[w] | |
567 | + | let dd = parseIntValue(dc[t]) | |
568 | + | let de = parseIntValue(dc[u]) | |
569 | + | let ds = dc[p] | |
570 | + | let dt = valueOrErrorMessage(assetInfo(dp), (("Asset " + toBase58String(dp)) + " doesn't exist")).quantity | |
571 | + | let dV = toBase58String(valueOrElse(dM, fromBase58String("WAVES"))) | |
572 | + | let dW = toBase58String(valueOrElse(dO, fromBase58String("WAVES"))) | |
573 | + | if (if ((dR != dV)) | |
588 | 574 | then true | |
589 | - | else ( | |
575 | + | else (dS != dW)) | |
590 | 576 | then throw("Invalid amt or price asset passed.") | |
591 | 577 | else { | |
592 | - | let | |
593 | - | then bN( | |
594 | - | else (bN( | |
595 | - | let | |
596 | - | then bN( | |
597 | - | else (bN( | |
598 | - | let | |
599 | - | let | |
600 | - | let | |
601 | - | let | |
602 | - | let | |
603 | - | let | |
578 | + | let du = if (dP) | |
579 | + | then bN(dR) | |
580 | + | else (bN(dR) - dL) | |
581 | + | let dw = if (dP) | |
582 | + | then bN(dS) | |
583 | + | else (bN(dS) - dN) | |
584 | + | let dX = D(dL, dd) | |
585 | + | let dY = D(dN, de) | |
586 | + | let dZ = bQ(dY, dX) | |
587 | + | let dv = D(du, dd) | |
588 | + | let dx = D(dw, de) | |
589 | + | let ea = if ((dt == 0)) | |
604 | 590 | then { | |
605 | - | let | |
606 | - | let | |
607 | - | let | |
608 | - | $Tuple5(H( | |
591 | + | let dy = e | |
592 | + | let eb = e | |
593 | + | let dg = pow((dX * dY), 0, toBigInt(5), 1, 0, DOWN) | |
594 | + | $Tuple5(H(dg, b), H(dX, dd), H(dY, de), bQ((dx + dY), (dv + dX)), eb) | |
609 | 595 | } | |
610 | 596 | else { | |
611 | - | let | |
612 | - | let | |
613 | - | let | |
614 | - | if (if (( | |
615 | - | then ( | |
597 | + | let dy = bQ(dx, dv) | |
598 | + | let eb = fraction(R((dy - dZ)), d, dy) | |
599 | + | let ec = D(dK, b) | |
600 | + | if (if ((dy != e)) | |
601 | + | then (eb > ec) | |
616 | 602 | else false) | |
617 | - | then throw(((("Price slippage " + toString( | |
603 | + | then throw(((("Price slippage " + toString(eb)) + " exceeded the passed limit of ") + toString(ec))) | |
618 | 604 | else { | |
619 | - | let | |
620 | - | let | |
621 | - | let | |
622 | - | let | |
623 | - | then $Tuple2( | |
624 | - | else $Tuple2( | |
625 | - | let | |
626 | - | let | |
627 | - | let | |
628 | - | $Tuple5(K( | |
605 | + | let dB = D(dt, b) | |
606 | + | let ed = fraction(dX, bT(dx, dv, CEILING), d, CEILING) | |
607 | + | let ee = fraction(dY, d, bT(dx, dv, FLOOR), CEILING) | |
608 | + | let ef = if ((ed > dY)) | |
609 | + | then $Tuple2(ee, dY) | |
610 | + | else $Tuple2(dX, ed) | |
611 | + | let eg = ef._1 | |
612 | + | let eh = ef._2 | |
613 | + | let dg = fraction(dB, eh, dx, FLOOR) | |
614 | + | $Tuple5(K(dg, b, FLOOR), K(eg, dd, CEILING), K(eh, de, CEILING), dy, eb) | |
629 | 615 | } | |
630 | 616 | } | |
631 | - | let | |
632 | - | let | |
633 | - | let | |
634 | - | let | |
635 | - | let | |
636 | - | if ((0 >= | |
617 | + | let ei = ea._1 | |
618 | + | let ej = ea._2 | |
619 | + | let ek = ea._3 | |
620 | + | let dz = H(ea._4, b) | |
621 | + | let el = H(ea._5, b) | |
622 | + | if ((0 >= ei)) | |
637 | 623 | then throw("Invalid calculations. LP calculated is less than zero.") | |
638 | 624 | else { | |
639 | - | let | |
625 | + | let em = if (!(dQ)) | |
640 | 626 | then 0 | |
641 | - | else | |
642 | - | let | |
643 | - | let | |
644 | - | let | |
645 | - | $Tuple13( | |
627 | + | else ei | |
628 | + | let en = (dL - ej) | |
629 | + | let eo = (dN - ek) | |
630 | + | let ep = [IntegerEntry(W(), dz), IntegerEntry(X(height, lastBlock.timestamp), dz), StringEntry(aa(ab, dm), by(ej, ek, em, dz, dK, el, height, lastBlock.timestamp, en, eo))] | |
631 | + | $Tuple13(ei, em, dz, du, dw, dt, dp, ds, ep, en, eo, dM, dO) | |
646 | 632 | } | |
647 | 633 | } | |
648 | 634 | } | |
649 | 635 | ||
650 | 636 | ||
651 | - | func | |
652 | - | let | |
653 | - | let | |
654 | - | let | |
655 | - | if (( | |
637 | + | func eq (er,es,dt) = { | |
638 | + | let et = G(er, toBigInt(bt)) | |
639 | + | let eu = G(es, toBigInt(bu)) | |
640 | + | let ev = fraction(pow((et * eu), 0, toBigInt(5), 1, 18, DOWN), g, dt) | |
641 | + | if ((dt == f)) | |
656 | 642 | then f | |
657 | - | else | |
643 | + | else ev | |
658 | 644 | } | |
659 | 645 | ||
660 | 646 | ||
661 | - | func | |
662 | - | let | |
663 | - | let | |
664 | - | let | |
665 | - | let | |
666 | - | | |
647 | + | func ew (ex,ey,ez) = { | |
648 | + | let eA = (toBigInt(bN(bj(br))) - ex) | |
649 | + | let eB = (toBigInt(bN(bj(bs))) - ey) | |
650 | + | let eC = (toBigInt(value(assetInfo(bq)).quantity) - ez) | |
651 | + | let eD = eq(eA, eB, eC) | |
652 | + | eD | |
667 | 653 | } | |
668 | 654 | ||
669 | 655 | ||
670 | - | func | |
671 | - | let | |
672 | - | let | |
673 | - | let | |
674 | - | let | |
675 | - | let | |
676 | - | $Tuple2( | |
656 | + | func eE (eF,eG,ez) = { | |
657 | + | let eA = (bN(bj(br)) + eF) | |
658 | + | let eB = (bN(bj(bs)) + eG) | |
659 | + | let eC = (value(assetInfo(bq)).quantity + ez) | |
660 | + | let ev = eq(toBigInt(eA), toBigInt(eB), toBigInt(eC)) | |
661 | + | let eH = [IntegerEntry(ak, height), StringEntry(aj, toString(ev))] | |
662 | + | $Tuple2(eH, ev) | |
677 | 663 | } | |
678 | 664 | ||
679 | 665 | ||
680 | - | func | |
666 | + | func eI (eJ,ev) = if ((ev >= eJ)) | |
681 | 667 | then true | |
682 | - | else aS(makeString(["updated KLp lower than current KLp", toString( | |
668 | + | else aS(makeString(["updated KLp lower than current KLp", toString(eJ), toString(ev)], " ")) | |
683 | 669 | ||
684 | 670 | ||
685 | - | func | |
686 | - | let | |
687 | - | let | |
688 | - | let | |
689 | - | let | |
690 | - | let | |
691 | - | then $Tuple2( | |
692 | - | else $Tuple2(-( | |
693 | - | let | |
694 | - | let | |
671 | + | func eK (eL) = { | |
672 | + | let eA = bN(bj(br)) | |
673 | + | let eB = bN(bj(bs)) | |
674 | + | let eM = eL.amount | |
675 | + | let eN = fraction(eL.amount, eL.price, b, FLOOR) | |
676 | + | let eO = if ((eL.orderType == Buy)) | |
677 | + | then $Tuple2(eM, -(eN)) | |
678 | + | else $Tuple2(-(eM), eN) | |
679 | + | let eF = eO._1 | |
680 | + | let eG = eO._2 | |
695 | 681 | if (if (if (bc()) | |
696 | 682 | then true | |
697 | 683 | else (bp == m)) | |
698 | 684 | then true | |
699 | 685 | else (bp == n)) | |
700 | 686 | then throw("Exchange operations disabled") | |
701 | - | else if (if (( | |
687 | + | else if (if ((eL.assetPair.amountAsset != br)) | |
702 | 688 | then true | |
703 | - | else ( | |
689 | + | else (eL.assetPair.priceAsset != bs)) | |
704 | 690 | then throw("Wrong order assets.") | |
705 | 691 | else { | |
706 | - | let | |
707 | - | let | |
708 | - | let | |
709 | - | let | |
710 | - | let | |
711 | - | let | |
712 | - | $Tuple2( | |
692 | + | let eP = valueOrErrorMessage(parseBigInt(valueOrElse(getString(this, aj), "0")), aU("invalid kLp")) | |
693 | + | let eQ = eE(eF, eG, 0) | |
694 | + | let eR = eQ._1 | |
695 | + | let eS = eQ._2 | |
696 | + | let eT = (eS >= eP) | |
697 | + | let eU = makeString(["kLp=", toString(eP), " kLpNew=", toString(eS), " amountAssetBalance=", toString(eA), " priceAssetBalance=", toString(eB), " amountAssetBalanceDelta=", toString(eF), " priceAssetBalanceDelta=", toString(eG), " height=", toString(height)], "") | |
698 | + | $Tuple2(eT, eU) | |
713 | 699 | } | |
714 | 700 | } | |
715 | 701 | ||
716 | 702 | ||
717 | - | func | |
703 | + | func eV (eW) = if ((size(eW.payments) != 1)) | |
718 | 704 | then throw("exactly 1 payment is expected") | |
719 | 705 | else { | |
720 | - | let | |
721 | - | let | |
722 | - | let | |
723 | - | let | |
724 | - | let | |
725 | - | let | |
726 | - | let | |
727 | - | let | |
706 | + | let eX = value(eW.payments[0]) | |
707 | + | let dn = value(eX.assetId) | |
708 | + | let eY = eX.amount | |
709 | + | let ea = dl(toBase58String(eW.transactionId), toBase58String(dn), eY, eW.caller) | |
710 | + | let dE = ea._1 | |
711 | + | let dF = ea._2 | |
712 | + | let ds = parseIntValue(ea._9) | |
713 | + | let dI = ea._10 | |
728 | 714 | if (if (bc()) | |
729 | 715 | then true | |
730 | - | else ( | |
731 | - | then throw(("Get operation is blocked by admin. Status = " + toString( | |
732 | - | else $Tuple5(dF, | |
716 | + | else (ds == n)) | |
717 | + | then throw(("Get operation is blocked by admin. Status = " + toString(ds))) | |
718 | + | else $Tuple5(dE, dF, eY, dn, dI) | |
733 | 719 | } | |
734 | 720 | ||
735 | 721 | ||
736 | - | func | |
722 | + | func eZ (eW,dK,dQ) = if ((size(eW.payments) != 2)) | |
737 | 723 | then throw("exactly 2 payments are expected") | |
738 | 724 | else { | |
739 | - | let | |
740 | - | let | |
741 | - | let | |
742 | - | let | |
725 | + | let fa = value(eW.payments[0]) | |
726 | + | let fb = value(eW.payments[1]) | |
727 | + | let fc = dJ(toBase58String(eW.transactionId), dK, fa.amount, fa.assetId, fb.amount, fb.assetId, toString(eW.caller), false, dQ) | |
728 | + | let ds = parseIntValue(fc._8) | |
743 | 729 | if (if (if (bc()) | |
744 | 730 | then true | |
745 | - | else ( | |
731 | + | else (ds == l)) | |
746 | 732 | then true | |
747 | - | else ( | |
748 | - | then throw(("Put operation is blocked by admin. Status = " + toString( | |
749 | - | else | |
733 | + | else (ds == n)) | |
734 | + | then throw(("Put operation is blocked by admin. Status = " + toString(ds))) | |
735 | + | else fc | |
750 | 736 | } | |
751 | 737 | ||
752 | 738 | ||
753 | - | func | |
754 | - | let | |
755 | - | if (( | |
739 | + | func fd (ca) = { | |
740 | + | let fe = invoke(aV, "emit", [ca], nil) | |
741 | + | if ((fe == fe)) | |
756 | 742 | then { | |
757 | - | let | |
758 | - | let bX = | |
743 | + | let ff = { | |
744 | + | let bX = fe | |
759 | 745 | if ($isInstanceOf(bX, "Address")) | |
760 | 746 | then { | |
761 | - | let | |
762 | - | invoke( | |
747 | + | let fg = bX | |
748 | + | invoke(fg, "emit", [ca], nil) | |
763 | 749 | } | |
764 | 750 | else unit | |
765 | 751 | } | |
766 | - | if (( | |
752 | + | if ((ff == ff)) | |
767 | 753 | then ca | |
768 | 754 | else throw("Strict value is not equal to itself.") | |
769 | 755 | } | |
771 | 757 | } | |
772 | 758 | ||
773 | 759 | ||
774 | - | func | |
775 | - | let | |
760 | + | func fh (ca,ai) = { | |
761 | + | let fi = if ((ai == 0)) | |
776 | 762 | then 0 | |
777 | 763 | else fraction(ca, ai, b) | |
778 | - | $Tuple2((ca - | |
764 | + | $Tuple2((ca - fi), fi) | |
779 | 765 | } | |
780 | 766 | ||
781 | 767 | ||
782 | - | func | |
783 | - | let | |
784 | - | let | |
785 | - | let | |
786 | - | let | |
768 | + | func fj (fk,fl,ab,ac) = { | |
769 | + | let fm = (ac == unit) | |
770 | + | let fn = bN(bj(br)) | |
771 | + | let fo = bN(bj(bs)) | |
772 | + | let fp = if ((fl == br)) | |
787 | 773 | then true | |
788 | - | else if (( | |
774 | + | else if ((fl == bs)) | |
789 | 775 | then false | |
790 | 776 | else aS("invalid asset") | |
791 | - | let | |
792 | - | then $Tuple2( | |
793 | - | else if ( | |
794 | - | then $Tuple2(( | |
795 | - | else $Tuple2( | |
796 | - | let | |
797 | - | let | |
798 | - | let | |
799 | - | then $Tuple2( | |
800 | - | else $Tuple2(0, | |
801 | - | let | |
802 | - | let | |
803 | - | let | |
804 | - | let | |
805 | - | let | |
806 | - | let | |
807 | - | let | |
808 | - | let | |
809 | - | let | |
810 | - | let | |
811 | - | let | |
812 | - | let | |
813 | - | then | |
814 | - | else | |
815 | - | let | |
816 | - | let | |
817 | - | let | |
777 | + | let fq = if (fm) | |
778 | + | then $Tuple2(fn, fo) | |
779 | + | else if (fp) | |
780 | + | then $Tuple2((fn - fk), fo) | |
781 | + | else $Tuple2(fn, (fo - fk)) | |
782 | + | let fr = fq._1 | |
783 | + | let fs = fq._2 | |
784 | + | let ft = if (fp) | |
785 | + | then $Tuple2(fk, 0) | |
786 | + | else $Tuple2(0, fk) | |
787 | + | let fu = ft._1 | |
788 | + | let fv = ft._2 | |
789 | + | let eM = fh(fu, aX)._1 | |
790 | + | let eN = fh(fv, aX)._1 | |
791 | + | let fw = fh(fk, aX) | |
792 | + | let fx = fw._1 | |
793 | + | let fi = fw._2 | |
794 | + | let fy = (fr + eM) | |
795 | + | let fz = (fs + eN) | |
796 | + | let fA = bQ(D(fz, bu), D(fy, bt)) | |
797 | + | let fB = H(fA, b) | |
798 | + | let fC = if (fp) | |
799 | + | then fr | |
800 | + | else fs | |
801 | + | let fD = toBigInt(fC) | |
802 | + | let fE = toBigInt(valueOrErrorMessage(assetInfo(bq), (("asset " + toBase58String(bq)) + " doesn't exist")).quantity) | |
803 | + | let fF = if ((fE > f)) | |
818 | 804 | then true | |
819 | 805 | else aS("initial deposit requires all coins") | |
820 | - | if (( | |
806 | + | if ((fF == fF)) | |
821 | 807 | then { | |
822 | - | let | |
823 | - | let | |
824 | - | let | |
808 | + | let fG = toBigInt(fx) | |
809 | + | let fH = max([0, toInt(((fE * (sqrtBigInt((d + ((fG * d) / fD)), 18, 18, DOWN) - d)) / d))]) | |
810 | + | let ep = if (fm) | |
825 | 811 | then nil | |
826 | - | else [IntegerEntry(W(), | |
827 | - | let | |
828 | - | let | |
829 | - | let | |
830 | - | let | |
831 | - | then $Tuple2( | |
832 | - | else $Tuple2( | |
833 | - | let ca = | |
834 | - | let | |
835 | - | let | |
836 | - | fraction(( | |
812 | + | else [IntegerEntry(W(), fB), IntegerEntry(X(height, lastBlock.timestamp), fB), StringEntry(aa(toString(value(ab)), toBase58String(value(ac))), by(fu, fv, fH, fB, 0, 0, height, lastBlock.timestamp, 0, 0))] | |
813 | + | let fI = bQ(D(fs, bu), D(fr, bt)) | |
814 | + | let fJ = H(fI, b) | |
815 | + | let fK = { | |
816 | + | let fL = if (fp) | |
817 | + | then $Tuple2(fu, fr) | |
818 | + | else $Tuple2(fv, fs) | |
819 | + | let ca = fL._1 | |
820 | + | let fM = fL._2 | |
821 | + | let fN = toInt(fraction(fE, toBigInt((ca / 2)), toBigInt(fM))) | |
822 | + | fraction((fH - fN), b, fN) | |
837 | 823 | } | |
838 | - | $Tuple5( | |
824 | + | $Tuple5(fH, ep, fi, fK, fp) | |
839 | 825 | } | |
840 | 826 | else throw("Strict value is not equal to itself.") | |
841 | 827 | } | |
842 | 828 | ||
843 | 829 | ||
844 | - | func | |
845 | - | let | |
846 | - | let | |
847 | - | let | |
848 | - | let | |
849 | - | let | |
830 | + | func fO (fP,fx,fl,ab,ac) = { | |
831 | + | let fm = (ac == unit) | |
832 | + | let dc = be() | |
833 | + | let dd = parseIntValue(dc[t]) | |
834 | + | let de = parseIntValue(dc[u]) | |
835 | + | let fQ = [if ((fl == bq)) | |
850 | 836 | then true | |
851 | 837 | else aS("invalid lp asset")] | |
852 | - | if (( | |
838 | + | if ((fQ == fQ)) | |
853 | 839 | then { | |
854 | - | let | |
840 | + | let fR = if ((fP == br)) | |
855 | 841 | then true | |
856 | - | else if (( | |
842 | + | else if ((fP == bs)) | |
857 | 843 | then false | |
858 | 844 | else aS("invalid asset") | |
859 | - | let | |
845 | + | let fS = if (fR) | |
860 | 846 | then toBigInt(bN(bj(br))) | |
861 | 847 | else toBigInt(bN(bj(bs))) | |
862 | - | let fV = if (fT) | |
863 | - | then de | |
864 | - | else df | |
865 | - | let fW = bN(bj(br)) | |
866 | - | let fX = bN(bj(bs)) | |
867 | - | let fY = if (fT) | |
868 | - | then fW | |
869 | - | else fX | |
870 | - | let fZ = toBigInt(fY) | |
871 | - | let fG = toBigInt(valueOrErrorMessage(assetInfo(bq), (("asset " + toBase58String(bq)) + " doesn't exist")).quantity) | |
872 | - | let ga = toBigInt(fz) | |
873 | - | let gb = max([0, toInt(((fU * (d - pow((d - ((ga * d) / fG)), 18, h, 0, 18, DOWN))) / d))]) | |
874 | - | let gc = fj(gb, aZ) | |
848 | + | let fT = if (fR) | |
849 | + | then dd | |
850 | + | else de | |
851 | + | let fU = bN(bj(br)) | |
852 | + | let fV = bN(bj(bs)) | |
853 | + | let fW = if (fR) | |
854 | + | then fU | |
855 | + | else fV | |
856 | + | let fX = toBigInt(fW) | |
857 | + | let fE = toBigInt(valueOrErrorMessage(assetInfo(bq), (("asset " + toBase58String(bq)) + " doesn't exist")).quantity) | |
858 | + | let fY = toBigInt(fx) | |
859 | + | let fZ = max([0, toInt(((fS * (d - pow((d - ((fY * d) / fE)), 18, h, 0, 18, DOWN))) / d))]) | |
860 | + | let ga = fh(fZ, aZ) | |
861 | + | let gb = ga._1 | |
862 | + | let fi = ga._2 | |
863 | + | let gc = if (fR) | |
864 | + | then $Tuple4(gb, 0, (fU - fZ), fV) | |
865 | + | else $Tuple4(0, gb, fU, (fV - fZ)) | |
875 | 866 | let gd = gc._1 | |
876 | - | let fk = gc._2 | |
877 | - | let ge = if (fT) | |
878 | - | then $Tuple4(gd, 0, (fW - gb), fX) | |
879 | - | else $Tuple4(0, gd, fW, (fX - gb)) | |
880 | - | let gf = ge._1 | |
881 | - | let gg = ge._2 | |
882 | - | let gh = ge._3 | |
883 | - | let gi = ge._4 | |
884 | - | let fC = bQ(D(gi, bu), D(gh, bt)) | |
885 | - | let fD = H(fC, b) | |
886 | - | let er = if (fo) | |
867 | + | let ge = gc._2 | |
868 | + | let gf = gc._3 | |
869 | + | let gg = gc._4 | |
870 | + | let fA = bQ(D(gg, bu), D(gf, bt)) | |
871 | + | let fB = H(fA, b) | |
872 | + | let ep = if (fm) | |
887 | 873 | then nil | |
888 | - | else [StringEntry(ad(toString(value(ab)), toBase58String(value(ac))), bJ( | |
889 | - | let | |
890 | - | let | |
891 | - | let | |
892 | - | let | |
893 | - | fraction(( | |
874 | + | else [StringEntry(ad(toString(value(ab)), toBase58String(value(ac))), bJ(gd, ge, fx, fB, height, lastBlock.timestamp)), IntegerEntry(W(), fB), IntegerEntry(X(height, lastBlock.timestamp), fB)] | |
875 | + | let fI = bQ(D(fV, bu), D(fU, bt)) | |
876 | + | let fJ = H(fI, b) | |
877 | + | let fK = { | |
878 | + | let gh = (toInt(fraction(fS, fY, fE)) * 2) | |
879 | + | fraction((gb - gh), b, gh) | |
894 | 880 | } | |
895 | - | $Tuple5( | |
881 | + | $Tuple5(gb, ep, fi, fK, fR) | |
896 | 882 | } | |
897 | 883 | else throw("Strict value is not equal to itself.") | |
898 | 884 | } | |
899 | 885 | ||
900 | 886 | ||
901 | - | func | |
887 | + | func gi () = { | |
902 | 888 | let bX = getString(U()) | |
903 | 889 | if ($isInstanceOf(bX, "String")) | |
904 | 890 | then { | |
905 | - | let | |
906 | - | fromBase58String( | |
891 | + | let gj = bX | |
892 | + | fromBase58String(gj) | |
907 | 893 | } | |
908 | 894 | else if ($isInstanceOf(bX, "Unit")) | |
909 | 895 | then unit | |
911 | 897 | } | |
912 | 898 | ||
913 | 899 | ||
914 | - | func | |
900 | + | func gk () = { | |
915 | 901 | let bX = getString(V()) | |
916 | 902 | if ($isInstanceOf(bX, "String")) | |
917 | 903 | then { | |
918 | - | let | |
919 | - | fromBase58String( | |
904 | + | let gj = bX | |
905 | + | fromBase58String(gj) | |
920 | 906 | } | |
921 | 907 | else if ($isInstanceOf(bX, "Unit")) | |
922 | 908 | then unit | |
924 | 910 | } | |
925 | 911 | ||
926 | 912 | ||
927 | - | func | |
928 | - | let bX = | |
913 | + | func gl (eW) = { | |
914 | + | let bX = gi() | |
929 | 915 | if ($isInstanceOf(bX, "ByteVector")) | |
930 | 916 | then { | |
931 | - | let | |
932 | - | ( | |
917 | + | let gm = bX | |
918 | + | (eW.callerPublicKey == gm) | |
933 | 919 | } | |
934 | 920 | else if ($isInstanceOf(bX, "Unit")) | |
935 | - | then ( | |
921 | + | then (eW.caller == this) | |
936 | 922 | else throw("Match error") | |
937 | 923 | } | |
938 | 924 | ||
939 | 925 | ||
940 | - | func | |
941 | - | let | |
942 | - | let bX = | |
926 | + | func gn (eW) = { | |
927 | + | let go = throw("Permission denied") | |
928 | + | let bX = gi() | |
943 | 929 | if ($isInstanceOf(bX, "ByteVector")) | |
944 | 930 | then { | |
945 | - | let | |
946 | - | if (( | |
931 | + | let gm = bX | |
932 | + | if ((eW.callerPublicKey == gm)) | |
947 | 933 | then true | |
948 | - | else | |
934 | + | else go | |
949 | 935 | } | |
950 | 936 | else if ($isInstanceOf(bX, "Unit")) | |
951 | - | then if (( | |
937 | + | then if ((eW.caller == this)) | |
952 | 938 | then true | |
953 | - | else | |
939 | + | else go | |
954 | 940 | else throw("Match error") | |
955 | 941 | } | |
956 | 942 | ||
957 | 943 | ||
958 | - | @Callable( | |
944 | + | @Callable(eW) | |
959 | 945 | func rebalance () = (cG(aO(this, ae())) ++ cG(aO(this, af()))) | |
960 | 946 | ||
961 | 947 | ||
962 | 948 | ||
963 | - | @Callable( | |
964 | - | func calculateAmountOutForSwapREADONLY (gr | |
965 | - | let | |
949 | + | @Callable(eW) | |
950 | + | func calculateAmountOutForSwapREADONLY (gp,gq,gr) = { | |
951 | + | let gs = if ((gq == false)) | |
966 | 952 | then { | |
967 | - | let | |
968 | - | let | |
969 | - | $Tuple2( | |
953 | + | let gt = aO(this, af()) | |
954 | + | let gu = aO(this, ae()) | |
955 | + | $Tuple2(gt, gu) | |
970 | 956 | } | |
971 | 957 | else { | |
972 | - | let | |
973 | - | let | |
974 | - | $Tuple2( | |
958 | + | let gt = aO(this, ae()) | |
959 | + | let gu = aO(this, af()) | |
960 | + | $Tuple2(gt, gu) | |
975 | 961 | } | |
976 | - | let | |
977 | - | let | |
978 | - | let | |
979 | - | let | |
980 | - | let | |
981 | - | let | |
982 | - | let | |
983 | - | let | |
962 | + | let gt = gs._1 | |
963 | + | let gu = gs._2 | |
964 | + | let gv = bN(gu) | |
965 | + | let gw = bN(gt) | |
966 | + | let gx = fraction(gw, gp, (gv + gp)) | |
967 | + | let gy = (toBigInt(gv) * toBigInt(gw)) | |
968 | + | let gz = (((toBigInt(bN(gu)) + toBigInt(gp)) + toBigInt(gr)) * (toBigInt(bN(gt)) - toBigInt(gx))) | |
969 | + | let gA = if ((gz >= gy)) | |
984 | 970 | then true | |
985 | 971 | else throw("new K is fewer error") | |
986 | - | if (( | |
987 | - | then $Tuple2(nil, | |
972 | + | if ((gA == gA)) | |
973 | + | then $Tuple2(nil, gx) | |
988 | 974 | else throw("Strict value is not equal to itself.") | |
989 | 975 | } | |
990 | 976 | ||
991 | 977 | ||
992 | 978 | ||
993 | - | @Callable( | |
994 | - | func calculateAmountOutForSwapAndSendTokens (gr | |
995 | - | let | |
979 | + | @Callable(eW) | |
980 | + | func calculateAmountOutForSwapAndSendTokens (gp,gq,gB,gC,gr) = { | |
981 | + | let gD = { | |
996 | 982 | let aY = invoke(aV, "getSwapContractREADONLY", nil, nil) | |
997 | 983 | if ($isInstanceOf(aY, "String")) | |
998 | 984 | then aY | |
999 | 985 | else throw(($getType(aY) + " couldn't be cast to String")) | |
1000 | 986 | } | |
1001 | - | let | |
987 | + | let fQ = [if ((value(eW.payments[0]).amount >= gp)) | |
1002 | 988 | then true | |
1003 | - | else aS("Wrong amount"), if (( | |
989 | + | else aS("Wrong amount"), if ((eW.caller == addressFromStringValue(gD))) | |
1004 | 990 | then true | |
1005 | 991 | else aS("Permission denied")] | |
1006 | - | if (( | |
992 | + | if ((fQ == fQ)) | |
1007 | 993 | then { | |
1008 | - | let | |
1009 | - | let | |
1010 | - | let | |
994 | + | let eX = value(eW.payments[0]) | |
995 | + | let gu = bj(eX.assetId) | |
996 | + | let gt = if ((gq == false)) | |
1011 | 997 | then aO(this, af()) | |
1012 | 998 | else aO(this, ae()) | |
1013 | - | let | |
1014 | - | let | |
1015 | - | let | |
1016 | - | let | |
1017 | - | let | |
1018 | - | let | |
999 | + | let gv = (bN(gu) - value(eW.payments[0]).amount) | |
1000 | + | let gw = bN(gt) | |
1001 | + | let gx = fraction(gw, gp, (gv + gp)) | |
1002 | + | let gy = (toBigInt(gv) * toBigInt(gw)) | |
1003 | + | let gz = ((toBigInt(bN(gu)) + toBigInt(gr)) * (toBigInt(bN(gt)) - toBigInt(gx))) | |
1004 | + | let gA = if ((gz >= gy)) | |
1019 | 1005 | then true | |
1020 | 1006 | else throw("new K is fewer error") | |
1021 | - | if (( | |
1007 | + | if ((gA == gA)) | |
1022 | 1008 | then { | |
1023 | - | let | |
1009 | + | let gE = if ((gx >= gB)) | |
1024 | 1010 | then true | |
1025 | 1011 | else throw("Exchange result is fewer coins than expected") | |
1026 | - | if (( | |
1012 | + | if ((gE == gE)) | |
1027 | 1013 | then { | |
1028 | - | let | |
1029 | - | let bX = cu( | |
1014 | + | let gF = { | |
1015 | + | let bX = cu(gt) | |
1030 | 1016 | if ($isInstanceOf(bX, "(Boolean, Int, Int, String, String, Int, String)")) | |
1031 | 1017 | then { | |
1032 | 1018 | let cH = bX | |
1034 | 1020 | } | |
1035 | 1021 | else throw("error lease config") | |
1036 | 1022 | } | |
1037 | - | let gI = cQ(gv, gz) | |
1038 | - | if ((gI == gI)) | |
1039 | - | then { | |
1040 | - | let dJ = invoke(this, "rebalance", nil, nil) | |
1041 | - | if ((dJ == dJ)) | |
1042 | - | then $Tuple2((gI ++ [ScriptTransfer(addressFromStringValue(gE), gz, bh(gv))]), gz) | |
1043 | - | else throw("Strict value is not equal to itself.") | |
1044 | - | } | |
1023 | + | let gG = cO(gt, gx) | |
1024 | + | if ((gG == gG)) | |
1025 | + | then $Tuple2((gG ++ [ScriptTransfer(addressFromStringValue(gC), gx, bh(gt))]), gx) | |
1045 | 1026 | else throw("Strict value is not equal to itself.") | |
1046 | 1027 | } | |
1047 | 1028 | else throw("Strict value is not equal to itself.") | |
1053 | 1034 | ||
1054 | 1035 | ||
1055 | 1036 | ||
1056 | - | @Callable( | |
1057 | - | func setManager ( | |
1058 | - | let | |
1059 | - | if (( | |
1037 | + | @Callable(eW) | |
1038 | + | func setManager (gH) = { | |
1039 | + | let gI = gn(eW) | |
1040 | + | if ((gI == gI)) | |
1060 | 1041 | then { | |
1061 | - | let | |
1062 | - | if (( | |
1063 | - | then [StringEntry(V(), | |
1042 | + | let gJ = fromBase58String(gH) | |
1043 | + | if ((gJ == gJ)) | |
1044 | + | then [StringEntry(V(), gH)] | |
1064 | 1045 | else throw("Strict value is not equal to itself.") | |
1065 | 1046 | } | |
1066 | 1047 | else throw("Strict value is not equal to itself.") | |
1068 | 1049 | ||
1069 | 1050 | ||
1070 | 1051 | ||
1071 | - | @Callable( | |
1052 | + | @Callable(eW) | |
1072 | 1053 | func confirmManager () = { | |
1073 | - | let | |
1074 | - | let | |
1054 | + | let gK = gk() | |
1055 | + | let gL = if (isDefined(gK)) | |
1075 | 1056 | then true | |
1076 | 1057 | else throw("No pending manager") | |
1077 | - | if (( | |
1058 | + | if ((gL == gL)) | |
1078 | 1059 | then { | |
1079 | - | let | |
1060 | + | let gM = if ((eW.callerPublicKey == value(gK))) | |
1080 | 1061 | then true | |
1081 | 1062 | else throw("You are not pending manager") | |
1082 | - | if (( | |
1083 | - | then [StringEntry(U(), toBase58String(value( | |
1063 | + | if ((gM == gM)) | |
1064 | + | then [StringEntry(U(), toBase58String(value(gK))), DeleteEntry(V())] | |
1084 | 1065 | else throw("Strict value is not equal to itself.") | |
1085 | 1066 | } | |
1086 | 1067 | else throw("Strict value is not equal to itself.") | |
1088 | 1069 | ||
1089 | 1070 | ||
1090 | 1071 | ||
1091 | - | @Callable( | |
1092 | - | func put ( | |
1072 | + | @Callable(eW) | |
1073 | + | func put (dK,gN) = if ((0 > dK)) | |
1093 | 1074 | then throw("Invalid slippageTolerance passed") | |
1094 | 1075 | else { | |
1095 | - | let | |
1096 | - | let | |
1097 | - | let | |
1098 | - | let | |
1099 | - | let | |
1100 | - | let | |
1101 | - | let | |
1102 | - | let | |
1103 | - | let | |
1104 | - | let | |
1105 | - | let | |
1106 | - | if (( | |
1076 | + | let fc = eZ(eW, dK, true) | |
1077 | + | let em = fc._2 | |
1078 | + | let dp = fc._7 | |
1079 | + | let dI = fc._9 | |
1080 | + | let en = fc._10 | |
1081 | + | let eo = fc._11 | |
1082 | + | let gO = fc._12 | |
1083 | + | let gP = fc._13 | |
1084 | + | let fa = toBigInt(value(eW.payments[0]).amount) | |
1085 | + | let fb = toBigInt(value(eW.payments[1]).amount) | |
1086 | + | let eD = ew(fa, fb, toBigInt(0)) | |
1087 | + | if ((eD == eD)) | |
1107 | 1088 | then { | |
1108 | - | let | |
1109 | - | if (( | |
1089 | + | let fe = invoke(aV, "emit", [em], nil) | |
1090 | + | if ((fe == fe)) | |
1110 | 1091 | then { | |
1111 | - | let | |
1112 | - | let bX = | |
1092 | + | let ff = { | |
1093 | + | let bX = fe | |
1113 | 1094 | if ($isInstanceOf(bX, "Address")) | |
1114 | 1095 | then { | |
1115 | - | let | |
1116 | - | invoke( | |
1096 | + | let fg = bX | |
1097 | + | invoke(fg, "emit", [em], nil) | |
1117 | 1098 | } | |
1118 | 1099 | else unit | |
1119 | 1100 | } | |
1120 | - | if (( | |
1101 | + | if ((ff == ff)) | |
1121 | 1102 | then { | |
1122 | - | let | |
1123 | - | then invoke(bx, "put", nil, [AttachedPayment( | |
1103 | + | let gQ = if ((en > 0)) | |
1104 | + | then invoke(bx, "put", nil, [AttachedPayment(gO, en)]) | |
1124 | 1105 | else nil | |
1125 | - | if (( | |
1106 | + | if ((gQ == gQ)) | |
1126 | 1107 | then { | |
1127 | - | let | |
1128 | - | then invoke(bx, "put", nil, [AttachedPayment( | |
1108 | + | let gR = if ((eo > 0)) | |
1109 | + | then invoke(bx, "put", nil, [AttachedPayment(gP, eo)]) | |
1129 | 1110 | else nil | |
1130 | - | if (( | |
1111 | + | if ((gR == gR)) | |
1131 | 1112 | then { | |
1132 | - | let | |
1113 | + | let gS = if (gN) | |
1133 | 1114 | then { | |
1134 | - | let | |
1135 | - | if (( | |
1115 | + | let gT = invoke(bw, "stake", nil, [AttachedPayment(dp, em)]) | |
1116 | + | if ((gT == gT)) | |
1136 | 1117 | then nil | |
1137 | 1118 | else throw("Strict value is not equal to itself.") | |
1138 | 1119 | } | |
1139 | - | else [ScriptTransfer( | |
1140 | - | let | |
1141 | - | if (( | |
1120 | + | else [ScriptTransfer(eW.caller, em, dp)] | |
1121 | + | let gU = eE(0, 0, 0) | |
1122 | + | if ((gU == gU)) | |
1142 | 1123 | then { | |
1143 | - | let | |
1144 | - | let | |
1145 | - | let | |
1146 | - | if (( | |
1124 | + | let ev = gU._2 | |
1125 | + | let gV = gU._1 | |
1126 | + | let gW = eI(eD, ev) | |
1127 | + | if ((gW == gW)) | |
1147 | 1128 | then { | |
1148 | - | let | |
1149 | - | if (( | |
1150 | - | then (( | |
1129 | + | let gX = invoke(this, "rebalance", nil, nil) | |
1130 | + | if ((gX == gX)) | |
1131 | + | then ((dI ++ gS) ++ gV) | |
1151 | 1132 | else throw("Strict value is not equal to itself.") | |
1152 | 1133 | } | |
1153 | 1134 | else throw("Strict value is not equal to itself.") | |
1167 | 1148 | ||
1168 | 1149 | ||
1169 | 1150 | ||
1170 | - | @Callable( | |
1171 | - | func putForFree ( | |
1151 | + | @Callable(eW) | |
1152 | + | func putForFree (gY) = if ((0 > gY)) | |
1172 | 1153 | then throw("Invalid value passed") | |
1173 | 1154 | else { | |
1174 | - | let | |
1175 | - | let | |
1176 | - | let | |
1177 | - | let | |
1178 | - | let | |
1179 | - | if (( | |
1155 | + | let fc = eZ(eW, gY, false) | |
1156 | + | let dI = fc._9 | |
1157 | + | let fa = toBigInt(value(eW.payments[0]).amount) | |
1158 | + | let fb = toBigInt(value(eW.payments[1]).amount) | |
1159 | + | let eD = ew(fa, fb, toBigInt(0)) | |
1160 | + | if ((eD == eD)) | |
1180 | 1161 | then { | |
1181 | - | let | |
1182 | - | let | |
1183 | - | let | |
1184 | - | let | |
1185 | - | if (( | |
1186 | - | then ( | |
1162 | + | let gZ = eE(0, 0, 0) | |
1163 | + | let gV = gZ._1 | |
1164 | + | let ev = gZ._2 | |
1165 | + | let gW = eI(eD, ev) | |
1166 | + | if ((gW == gW)) | |
1167 | + | then (dI ++ gV) | |
1187 | 1168 | else throw("Strict value is not equal to itself.") | |
1188 | 1169 | } | |
1189 | 1170 | else throw("Strict value is not equal to itself.") | |
1191 | 1172 | ||
1192 | 1173 | ||
1193 | 1174 | ||
1194 | - | @Callable( | |
1195 | - | func putOneTkn (hb | |
1196 | - | let | |
1175 | + | @Callable(eW) | |
1176 | + | func putOneTkn (ha,hb) = { | |
1177 | + | let hc = { | |
1197 | 1178 | let aY = invoke(aV, "isPoolOneTokenOperationsDisabledREADONLY", [toString(this)], nil) | |
1198 | 1179 | if ($isInstanceOf(aY, "Boolean")) | |
1199 | 1180 | then aY | |
1200 | 1181 | else throw(($getType(aY) + " couldn't be cast to Boolean")) | |
1201 | 1182 | } | |
1202 | - | let | |
1183 | + | let hd = if (if (if (bc()) | |
1203 | 1184 | then true | |
1204 | 1185 | else (bp == l)) | |
1205 | 1186 | then true | |
1206 | 1187 | else (bp == n)) | |
1207 | 1188 | then true | |
1208 | - | else | |
1209 | - | let | |
1189 | + | else hc | |
1190 | + | let fQ = [if (if (!(hd)) | |
1210 | 1191 | then true | |
1211 | - | else | |
1192 | + | else gl(eW)) | |
1212 | 1193 | then true | |
1213 | - | else aS("put operation is blocked by admin"), if ((size( | |
1194 | + | else aS("put operation is blocked by admin"), if ((size(eW.payments) == 1)) | |
1214 | 1195 | then true | |
1215 | 1196 | else aS("exactly 1 payment are expected")] | |
1216 | - | if (( | |
1197 | + | if ((fQ == fQ)) | |
1217 | 1198 | then { | |
1218 | - | let | |
1219 | - | let | |
1220 | - | let | |
1221 | - | let | |
1222 | - | then | |
1223 | - | else if (( | |
1224 | - | then | |
1199 | + | let he = eW.payments[0] | |
1200 | + | let fl = he.assetId | |
1201 | + | let fk = he.amount | |
1202 | + | let eD = if ((fl == br)) | |
1203 | + | then ew(toBigInt(fk), toBigInt(0), toBigInt(0)) | |
1204 | + | else if ((fl == bs)) | |
1205 | + | then ew(toBigInt(0), toBigInt(fk), toBigInt(0)) | |
1225 | 1206 | else aS("payment asset is not supported") | |
1226 | - | if (( | |
1207 | + | if ((eD == eD)) | |
1227 | 1208 | then { | |
1228 | - | let ab = | |
1229 | - | let ac = | |
1230 | - | let | |
1231 | - | if (( | |
1209 | + | let ab = eW.caller | |
1210 | + | let ac = eW.transactionId | |
1211 | + | let hf = fj(fk, fl, ab, ac) | |
1212 | + | if ((hf == hf)) | |
1232 | 1213 | then { | |
1233 | - | let | |
1234 | - | let | |
1235 | - | let | |
1236 | - | let | |
1237 | - | let | |
1238 | - | let | |
1239 | - | then ( | |
1214 | + | let fp = hf._5 | |
1215 | + | let hg = hf._4 | |
1216 | + | let fi = hf._3 | |
1217 | + | let ep = hf._2 | |
1218 | + | let hh = hf._1 | |
1219 | + | let hi = if (if ((ha > 0)) | |
1220 | + | then (ha > hh) | |
1240 | 1221 | else false) | |
1241 | - | then aS(makeString(["amount to receive is less than ", toString( | |
1242 | - | else | |
1243 | - | let | |
1244 | - | if (( | |
1222 | + | then aS(makeString(["amount to receive is less than ", toString(ha)], "")) | |
1223 | + | else hh | |
1224 | + | let fe = fd(hi) | |
1225 | + | if ((fe == fe)) | |
1245 | 1226 | then { | |
1246 | - | let | |
1227 | + | let gS = if (hb) | |
1247 | 1228 | then { | |
1248 | - | let | |
1249 | - | if (( | |
1229 | + | let hj = invoke(bw, "stake", nil, [AttachedPayment(bq, hi)]) | |
1230 | + | if ((hj == hj)) | |
1250 | 1231 | then nil | |
1251 | 1232 | else throw("Strict value is not equal to itself.") | |
1252 | 1233 | } | |
1253 | - | else [ScriptTransfer( | |
1254 | - | let | |
1255 | - | then [ScriptTransfer(aW, | |
1234 | + | else [ScriptTransfer(eW.caller, hi, bq)] | |
1235 | + | let hk = if ((fi > 0)) | |
1236 | + | then [ScriptTransfer(aW, fi, fl)] | |
1256 | 1237 | else nil | |
1257 | - | let | |
1238 | + | let hl = if ((this == aW)) | |
1258 | 1239 | then $Tuple2(0, 0) | |
1259 | - | else if ( | |
1260 | - | then $Tuple2(-( | |
1261 | - | else $Tuple2(0, -( | |
1262 | - | let | |
1263 | - | let | |
1264 | - | let | |
1265 | - | let | |
1266 | - | let | |
1267 | - | let | |
1268 | - | let | |
1269 | - | if (( | |
1240 | + | else if (fp) | |
1241 | + | then $Tuple2(-(fi), 0) | |
1242 | + | else $Tuple2(0, -(fi)) | |
1243 | + | let eF = hl._1 | |
1244 | + | let eG = hl._2 | |
1245 | + | let hm = eE(eF, eG, 0) | |
1246 | + | let gV = hm._1 | |
1247 | + | let ev = hm._2 | |
1248 | + | let eP = value(getString(aj)) | |
1249 | + | let gW = eI(eD, ev) | |
1250 | + | if ((gW == gW)) | |
1270 | 1251 | then { | |
1271 | - | let | |
1272 | - | if (( | |
1273 | - | then $Tuple2(((( | |
1252 | + | let gX = invoke(this, "rebalance", nil, nil) | |
1253 | + | if ((gX == gX)) | |
1254 | + | then $Tuple2((((ep ++ gS) ++ hk) ++ gV), hi) | |
1274 | 1255 | else throw("Strict value is not equal to itself.") | |
1275 | 1256 | } | |
1276 | 1257 | else throw("Strict value is not equal to itself.") | |
1286 | 1267 | ||
1287 | 1268 | ||
1288 | 1269 | ||
1289 | - | @Callable( | |
1290 | - | func putOneTknREADONLY ( | |
1291 | - | let | |
1292 | - | let | |
1293 | - | let | |
1294 | - | let | |
1295 | - | let | |
1296 | - | let | |
1297 | - | $Tuple2(nil, $Tuple3( | |
1270 | + | @Callable(eW) | |
1271 | + | func putOneTknREADONLY (fl,fk) = { | |
1272 | + | let hn = fj(fk, bh(fl), unit, unit) | |
1273 | + | let hh = hn._1 | |
1274 | + | let ep = hn._2 | |
1275 | + | let fi = hn._3 | |
1276 | + | let hg = hn._4 | |
1277 | + | let fp = hn._5 | |
1278 | + | $Tuple2(nil, $Tuple3(hh, fi, hg)) | |
1298 | 1279 | } | |
1299 | 1280 | ||
1300 | 1281 | ||
1301 | 1282 | ||
1302 | - | @Callable( | |
1303 | - | func getOneTkn ( | |
1304 | - | let | |
1283 | + | @Callable(eW) | |
1284 | + | func getOneTkn (ho,ha) = { | |
1285 | + | let hc = { | |
1305 | 1286 | let aY = invoke(aV, "isPoolOneTokenOperationsDisabledREADONLY", [toString(this)], nil) | |
1306 | 1287 | if ($isInstanceOf(aY, "Boolean")) | |
1307 | 1288 | then aY | |
1308 | 1289 | else throw(($getType(aY) + " couldn't be cast to Boolean")) | |
1309 | 1290 | } | |
1310 | - | let | |
1291 | + | let hp = if (if (bc()) | |
1311 | 1292 | then true | |
1312 | 1293 | else (bp == n)) | |
1313 | 1294 | then true | |
1314 | - | else | |
1315 | - | let | |
1295 | + | else hc | |
1296 | + | let fQ = [if (if (!(hp)) | |
1316 | 1297 | then true | |
1317 | - | else | |
1298 | + | else gl(eW)) | |
1318 | 1299 | then true | |
1319 | - | else aS("get operation is blocked by admin"), if ((size( | |
1300 | + | else aS("get operation is blocked by admin"), if ((size(eW.payments) == 1)) | |
1320 | 1301 | then true | |
1321 | 1302 | else aS("exactly 1 payment are expected")] | |
1322 | - | if (( | |
1303 | + | if ((fQ == fQ)) | |
1323 | 1304 | then { | |
1324 | - | let | |
1325 | - | let | |
1326 | - | let | |
1327 | - | let | |
1328 | - | let | |
1329 | - | if (( | |
1305 | + | let fP = bh(ho) | |
1306 | + | let he = eW.payments[0] | |
1307 | + | let fl = he.assetId | |
1308 | + | let fx = he.amount | |
1309 | + | let eD = ew(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1310 | + | if ((eD == eD)) | |
1330 | 1311 | then { | |
1331 | - | let ab = | |
1332 | - | let ac = | |
1333 | - | let | |
1334 | - | if (( | |
1312 | + | let ab = eW.caller | |
1313 | + | let ac = eW.transactionId | |
1314 | + | let hq = fO(fP, fx, fl, ab, ac) | |
1315 | + | if ((hq == hq)) | |
1335 | 1316 | then { | |
1336 | - | let | |
1337 | - | let | |
1338 | - | let | |
1339 | - | let | |
1340 | - | let | |
1341 | - | let ca = if (if (( | |
1342 | - | then ( | |
1317 | + | let fR = hq._5 | |
1318 | + | let hg = hq._4 | |
1319 | + | let fi = hq._3 | |
1320 | + | let ep = hq._2 | |
1321 | + | let hr = hq._1 | |
1322 | + | let ca = if (if ((ha > 0)) | |
1323 | + | then (ha > hr) | |
1343 | 1324 | else false) | |
1344 | - | then aS(makeString(["amount to receive is less than ", toString( | |
1345 | - | else | |
1346 | - | let | |
1347 | - | let bX = cu( | |
1325 | + | then aS(makeString(["amount to receive is less than ", toString(ha)], "")) | |
1326 | + | else hr | |
1327 | + | let gF = { | |
1328 | + | let bX = cu(ho) | |
1348 | 1329 | if ($isInstanceOf(bX, "(Boolean, Int, Int, String, String, Int, String)")) | |
1349 | 1330 | then { | |
1350 | 1331 | let cH = bX | |
1352 | 1333 | } | |
1353 | 1334 | else throw("error lease config") | |
1354 | 1335 | } | |
1355 | - | let | |
1356 | - | if (( | |
1336 | + | let hs = invoke(aV, "burn", [fx], [AttachedPayment(fl, fx)]) | |
1337 | + | if ((hs == hs)) | |
1357 | 1338 | then { | |
1358 | - | let | |
1359 | - | if (( | |
1339 | + | let gG = cO(ho, ca) | |
1340 | + | if ((gG == gG)) | |
1360 | 1341 | then { | |
1361 | - | let | |
1362 | - | let | |
1363 | - | then [ScriptTransfer(aW, | |
1342 | + | let ht = [ScriptTransfer(ab, ca, fP)] | |
1343 | + | let hk = if ((fi > 0)) | |
1344 | + | then [ScriptTransfer(aW, fi, fP)] | |
1364 | 1345 | else nil | |
1365 | - | let | |
1366 | - | let | |
1346 | + | let hu = { | |
1347 | + | let hv = if ((this == aW)) | |
1367 | 1348 | then 0 | |
1368 | - | else | |
1369 | - | if ( | |
1370 | - | then $Tuple2(-((ca + | |
1371 | - | else $Tuple2(0, -((ca + | |
1349 | + | else fi | |
1350 | + | if (fR) | |
1351 | + | then $Tuple2(-((ca + hv)), 0) | |
1352 | + | else $Tuple2(0, -((ca + hv))) | |
1372 | 1353 | } | |
1373 | - | let eH = hv._1 | |
1374 | - | let eI = hv._2 | |
1375 | - | let hx = eG(eH, eI, 0) | |
1376 | - | let gX = hx._1 | |
1377 | - | let ex = hx._2 | |
1378 | - | let gY = eK(eF, ex) | |
1379 | - | if ((gY == gY)) | |
1354 | + | let eF = hu._1 | |
1355 | + | let eG = hu._2 | |
1356 | + | let hw = eE(eF, eG, 0) | |
1357 | + | let gV = hw._1 | |
1358 | + | let ev = hw._2 | |
1359 | + | let gW = eI(eD, ev) | |
1360 | + | if ((gW == gW)) | |
1361 | + | then $Tuple2(((((ep ++ gG) ++ ht) ++ hk) ++ gV), ca) | |
1362 | + | else throw("Strict value is not equal to itself.") | |
1363 | + | } | |
1364 | + | else throw("Strict value is not equal to itself.") | |
1365 | + | } | |
1366 | + | else throw("Strict value is not equal to itself.") | |
1367 | + | } | |
1368 | + | else throw("Strict value is not equal to itself.") | |
1369 | + | } | |
1370 | + | else throw("Strict value is not equal to itself.") | |
1371 | + | } | |
1372 | + | else throw("Strict value is not equal to itself.") | |
1373 | + | } | |
1374 | + | ||
1375 | + | ||
1376 | + | ||
1377 | + | @Callable(eW) | |
1378 | + | func getOneTknREADONLY (fP,fx) = { | |
1379 | + | let hx = fO(bh(fP), fx, bq, unit, unit) | |
1380 | + | let hr = hx._1 | |
1381 | + | let ep = hx._2 | |
1382 | + | let fi = hx._3 | |
1383 | + | let hg = hx._4 | |
1384 | + | let fR = hx._5 | |
1385 | + | $Tuple2(nil, $Tuple3(hr, fi, hg)) | |
1386 | + | } | |
1387 | + | ||
1388 | + | ||
1389 | + | ||
1390 | + | @Callable(eW) | |
1391 | + | func unstakeAndGetOneTkn (hy,ho,ha) = { | |
1392 | + | let hc = { | |
1393 | + | let aY = invoke(aV, "isPoolOneTokenOperationsDisabledREADONLY", [toString(this)], nil) | |
1394 | + | if ($isInstanceOf(aY, "Boolean")) | |
1395 | + | then aY | |
1396 | + | else throw(($getType(aY) + " couldn't be cast to Boolean")) | |
1397 | + | } | |
1398 | + | let hp = if (if (bc()) | |
1399 | + | then true | |
1400 | + | else (bp == n)) | |
1401 | + | then true | |
1402 | + | else hc | |
1403 | + | let fQ = [if (if (!(hp)) | |
1404 | + | then true | |
1405 | + | else gl(eW)) | |
1406 | + | then true | |
1407 | + | else aS("get operation is blocked by admin"), if ((size(eW.payments) == 0)) | |
1408 | + | then true | |
1409 | + | else aS("no payments are expected")] | |
1410 | + | if ((fQ == fQ)) | |
1411 | + | then { | |
1412 | + | let fP = bh(ho) | |
1413 | + | let ab = eW.caller | |
1414 | + | let ac = eW.transactionId | |
1415 | + | let eD = ew(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1416 | + | if ((eD == eD)) | |
1417 | + | then { | |
1418 | + | let hz = invoke(bw, "unstake", [toBase58String(bq), hy], nil) | |
1419 | + | if ((hz == hz)) | |
1420 | + | then { | |
1421 | + | let hA = fO(fP, hy, bq, ab, ac) | |
1422 | + | if ((hA == hA)) | |
1423 | + | then { | |
1424 | + | let fR = hA._5 | |
1425 | + | let hg = hA._4 | |
1426 | + | let fi = hA._3 | |
1427 | + | let ep = hA._2 | |
1428 | + | let hr = hA._1 | |
1429 | + | let ca = if (if ((ha > 0)) | |
1430 | + | then (ha > hr) | |
1431 | + | else false) | |
1432 | + | then aS(makeString(["amount to receive is less than ", toString(ha)], "")) | |
1433 | + | else hr | |
1434 | + | let hs = invoke(aV, "burn", [hy], [AttachedPayment(bq, hy)]) | |
1435 | + | if ((hs == hs)) | |
1436 | + | then { | |
1437 | + | let gG = cO(ho, ca) | |
1438 | + | if ((gG == gG)) | |
1380 | 1439 | then { | |
1381 | - | let dJ = invoke(this, "rebalance", nil, nil) | |
1382 | - | if ((dJ == dJ)) | |
1383 | - | then $Tuple2(((((er ++ gI) ++ hu) ++ hl) ++ gX), ca) | |
1440 | + | let ht = [ScriptTransfer(eW.caller, ca, fP)] | |
1441 | + | let hk = if ((fi > 0)) | |
1442 | + | then [ScriptTransfer(aW, fi, fP)] | |
1443 | + | else nil | |
1444 | + | let hB = { | |
1445 | + | let hv = if ((this == aW)) | |
1446 | + | then 0 | |
1447 | + | else fi | |
1448 | + | if (fR) | |
1449 | + | then $Tuple2(-((ca + hv)), 0) | |
1450 | + | else $Tuple2(0, -((ca + hv))) | |
1451 | + | } | |
1452 | + | let eF = hB._1 | |
1453 | + | let eG = hB._2 | |
1454 | + | let hC = eE(eF, eG, 0) | |
1455 | + | let gV = hC._1 | |
1456 | + | let ev = hC._2 | |
1457 | + | let gW = eI(eD, ev) | |
1458 | + | if ((gW == gW)) | |
1459 | + | then $Tuple2(((((ep ++ gG) ++ ht) ++ hk) ++ gV), ca) | |
1384 | 1460 | else throw("Strict value is not equal to itself.") | |
1385 | 1461 | } | |
1386 | 1462 | else throw("Strict value is not equal to itself.") | |
1398 | 1474 | ||
1399 | 1475 | ||
1400 | 1476 | ||
1401 | - | @Callable(eY) | |
1402 | - | func getOneTknREADONLY (fR,fz) = { | |
1403 | - | let hy = fQ(bh(fR), fz, bq, unit, unit) | |
1404 | - | let hs = hy._1 | |
1405 | - | let er = hy._2 | |
1406 | - | let fk = hy._3 | |
1407 | - | let hh = hy._4 | |
1408 | - | let fT = hy._5 | |
1409 | - | $Tuple2(nil, $Tuple3(hs, fk, hh)) | |
1477 | + | @Callable(eW) | |
1478 | + | func get () = { | |
1479 | + | let ea = eV(eW) | |
1480 | + | let hD = ea._1 | |
1481 | + | let dF = ea._2 | |
1482 | + | let eY = ea._3 | |
1483 | + | let dn = ea._4 | |
1484 | + | let dI = ea._5 | |
1485 | + | let eD = ew(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1486 | + | if ((eD == eD)) | |
1487 | + | then { | |
1488 | + | let hE = invoke(aV, "burn", [eY], [AttachedPayment(dn, eY)]) | |
1489 | + | if ((hE == hE)) | |
1490 | + | then { | |
1491 | + | let hF = eE(-(hD), -(dF), 0) | |
1492 | + | let gV = hF._1 | |
1493 | + | let ev = hF._2 | |
1494 | + | let gW = eI(eD, ev) | |
1495 | + | if ((gW == gW)) | |
1496 | + | then (dI ++ gV) | |
1497 | + | else throw("Strict value is not equal to itself.") | |
1498 | + | } | |
1499 | + | else throw("Strict value is not equal to itself.") | |
1500 | + | } | |
1501 | + | else throw("Strict value is not equal to itself.") | |
1410 | 1502 | } | |
1411 | 1503 | ||
1412 | 1504 | ||
1413 | 1505 | ||
1414 | - | @Callable(eY) | |
1415 | - | func unstakeAndGetOneTkn (hz,hp,hb) = { | |
1416 | - | let hd = { | |
1417 | - | let aY = invoke(aV, "isPoolOneTokenOperationsDisabledREADONLY", [toString(this)], nil) | |
1418 | - | if ($isInstanceOf(aY, "Boolean")) | |
1419 | - | then aY | |
1420 | - | else throw(($getType(aY) + " couldn't be cast to Boolean")) | |
1421 | - | } | |
1422 | - | let hq = if (if (bc()) | |
1423 | - | then true | |
1424 | - | else (bp == n)) | |
1425 | - | then true | |
1426 | - | else hd | |
1427 | - | let fS = [if (if (!(hq)) | |
1428 | - | then true | |
1429 | - | else gn(eY)) | |
1430 | - | then true | |
1431 | - | else aS("get operation is blocked by admin"), if ((size(eY.payments) == 0)) | |
1432 | - | then true | |
1433 | - | else aS("no payments are expected")] | |
1434 | - | if ((fS == fS)) | |
1506 | + | @Callable(eW) | |
1507 | + | func getNoLess (hG,hH) = { | |
1508 | + | let ea = eV(eW) | |
1509 | + | let dE = ea._1 | |
1510 | + | let dF = ea._2 | |
1511 | + | let eY = ea._3 | |
1512 | + | let dn = ea._4 | |
1513 | + | let dI = ea._5 | |
1514 | + | if ((hG > dE)) | |
1515 | + | then throw(((("noLessThenAmtAsset failed: " + toString(dE)) + " < ") + toString(hG))) | |
1516 | + | else if ((hH > dF)) | |
1517 | + | then throw(((("noLessThenPriceAsset failed: " + toString(dF)) + " < ") + toString(hH))) | |
1518 | + | else { | |
1519 | + | let eD = ew(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1520 | + | if ((eD == eD)) | |
1521 | + | then { | |
1522 | + | let hE = invoke(aV, "burn", [eY], [AttachedPayment(dn, eY)]) | |
1523 | + | if ((hE == hE)) | |
1524 | + | then { | |
1525 | + | let hI = eE(-(dE), -(dF), 0) | |
1526 | + | let gV = hI._1 | |
1527 | + | let ev = hI._2 | |
1528 | + | let gW = eI(eD, ev) | |
1529 | + | if ((gW == gW)) | |
1530 | + | then (dI ++ gV) | |
1531 | + | else throw("Strict value is not equal to itself.") | |
1532 | + | } | |
1533 | + | else throw("Strict value is not equal to itself.") | |
1534 | + | } | |
1535 | + | else throw("Strict value is not equal to itself.") | |
1536 | + | } | |
1537 | + | } | |
1538 | + | ||
1539 | + | ||
1540 | + | ||
1541 | + | @Callable(eW) | |
1542 | + | func unstakeAndGet (ca) = { | |
1543 | + | let hJ = if ((size(eW.payments) != 0)) | |
1544 | + | then throw("No payments are expected") | |
1545 | + | else true | |
1546 | + | if ((hJ == hJ)) | |
1435 | 1547 | then { | |
1436 | - | let fR = bh(hp) | |
1437 | - | let ab = eY.caller | |
1438 | - | let ac = eY.transactionId | |
1439 | - | let eF = ey(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1440 | - | if ((eF == eF)) | |
1548 | + | let dc = be() | |
1549 | + | let dp = fromBase58String(dc[q]) | |
1550 | + | let eD = ew(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1551 | + | if ((eD == eD)) | |
1441 | 1552 | then { | |
1442 | - | let | |
1443 | - | if (( | |
1553 | + | let hz = invoke(bw, "unstake", [toBase58String(dp), ca], nil) | |
1554 | + | if ((hz == hz)) | |
1444 | 1555 | then { | |
1445 | - | let hB = fQ(fR, hz, bq, ab, ac) | |
1446 | - | if ((hB == hB)) | |
1556 | + | let ea = dl(toBase58String(eW.transactionId), toBase58String(dp), ca, eW.caller) | |
1557 | + | let dE = ea._1 | |
1558 | + | let dF = ea._2 | |
1559 | + | let ds = parseIntValue(ea._9) | |
1560 | + | let dI = ea._10 | |
1561 | + | let hK = if (if (bc()) | |
1562 | + | then true | |
1563 | + | else (ds == n)) | |
1564 | + | then throw(("Get operation is blocked by admin. Status = " + toString(ds))) | |
1565 | + | else true | |
1566 | + | if ((hK == hK)) | |
1447 | 1567 | then { | |
1448 | - | let fT = hB._5 | |
1449 | - | let hh = hB._4 | |
1450 | - | let fk = hB._3 | |
1451 | - | let er = hB._2 | |
1452 | - | let hs = hB._1 | |
1453 | - | let ca = if (if ((hb > 0)) | |
1454 | - | then (hb > hs) | |
1455 | - | else false) | |
1456 | - | then aS(makeString(["amount to receive is less than ", toString(hb)], "")) | |
1457 | - | else hs | |
1458 | - | let ht = invoke(aV, "burn", [hz], [AttachedPayment(bq, hz)]) | |
1459 | - | if ((ht == ht)) | |
1568 | + | let hE = invoke(aV, "burn", [ca], [AttachedPayment(dp, ca)]) | |
1569 | + | if ((hE == hE)) | |
1460 | 1570 | then { | |
1461 | - | let gI = cQ(hp, ca) | |
1462 | - | if ((gI == gI)) | |
1463 | - | then { | |
1464 | - | let hu = [ScriptTransfer(eY.caller, ca, fR)] | |
1465 | - | let hl = if ((fk > 0)) | |
1466 | - | then [ScriptTransfer(aW, fk, fR)] | |
1467 | - | else nil | |
1468 | - | let hC = { | |
1469 | - | let hw = if ((this == aW)) | |
1470 | - | then 0 | |
1471 | - | else fk | |
1472 | - | if (fT) | |
1473 | - | then $Tuple2(-((ca + hw)), 0) | |
1474 | - | else $Tuple2(0, -((ca + hw))) | |
1475 | - | } | |
1476 | - | let eH = hC._1 | |
1477 | - | let eI = hC._2 | |
1478 | - | let hD = eG(eH, eI, 0) | |
1479 | - | let gX = hD._1 | |
1480 | - | let ex = hD._2 | |
1481 | - | let gY = eK(eF, ex) | |
1482 | - | if ((gY == gY)) | |
1483 | - | then { | |
1484 | - | let dJ = invoke(this, "rebalance", nil, nil) | |
1485 | - | if ((dJ == dJ)) | |
1486 | - | then $Tuple2(((((er ++ gI) ++ hu) ++ hl) ++ gX), ca) | |
1487 | - | else throw("Strict value is not equal to itself.") | |
1488 | - | } | |
1489 | - | else throw("Strict value is not equal to itself.") | |
1490 | - | } | |
1571 | + | let hL = eE(-(dE), -(dF), 0) | |
1572 | + | let gV = hL._1 | |
1573 | + | let ev = hL._2 | |
1574 | + | let gW = eI(eD, ev) | |
1575 | + | if ((gW == gW)) | |
1576 | + | then (dI ++ gV) | |
1491 | 1577 | else throw("Strict value is not equal to itself.") | |
1492 | 1578 | } | |
1493 | 1579 | else throw("Strict value is not equal to itself.") | |
1503 | 1589 | ||
1504 | 1590 | ||
1505 | 1591 | ||
1506 | - | @Callable(eY) | |
1507 | - | func get () = { | |
1508 | - | let ec = eX(eY) | |
1509 | - | let hE = ec._1 | |
1510 | - | let dG = ec._2 | |
1511 | - | let fa = ec._3 | |
1512 | - | let do = ec._4 | |
1513 | - | let dK = ec._5 | |
1514 | - | let eF = ey(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1515 | - | if ((eF == eF)) | |
1592 | + | @Callable(eW) | |
1593 | + | func unstakeAndGetNoLess (hy,hM,hH) = { | |
1594 | + | let hp = if (bc()) | |
1595 | + | then true | |
1596 | + | else (bp == n) | |
1597 | + | let fQ = [if (!(hp)) | |
1598 | + | then true | |
1599 | + | else throw("get operation is blocked by admin"), if ((size(eW.payments) == 0)) | |
1600 | + | then true | |
1601 | + | else throw("no payments are expected")] | |
1602 | + | if ((fQ == fQ)) | |
1516 | 1603 | then { | |
1517 | - | let | |
1518 | - | if (( | |
1604 | + | let eD = ew(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1605 | + | if ((eD == eD)) | |
1519 | 1606 | then { | |
1520 | - | let hG = eG(-(hE), -(dG), 0) | |
1521 | - | let gX = hG._1 | |
1522 | - | let ex = hG._2 | |
1523 | - | let gY = eK(eF, ex) | |
1524 | - | if ((gY == gY)) | |
1525 | - | then (dK ++ gX) | |
1526 | - | else throw("Strict value is not equal to itself.") | |
1527 | - | } | |
1528 | - | else throw("Strict value is not equal to itself.") | |
1529 | - | } | |
1530 | - | else throw("Strict value is not equal to itself.") | |
1531 | - | } | |
1532 | - | ||
1533 | - | ||
1534 | - | ||
1535 | - | @Callable(eY) | |
1536 | - | func getNoLess (hH,hI) = { | |
1537 | - | let ec = eX(eY) | |
1538 | - | let dF = ec._1 | |
1539 | - | let dG = ec._2 | |
1540 | - | let fa = ec._3 | |
1541 | - | let do = ec._4 | |
1542 | - | let dK = ec._5 | |
1543 | - | if ((hH > dF)) | |
1544 | - | then throw(((("noLessThenAmtAsset failed: " + toString(dF)) + " < ") + toString(hH))) | |
1545 | - | else if ((hI > dG)) | |
1546 | - | then throw(((("noLessThenPriceAsset failed: " + toString(dG)) + " < ") + toString(hI))) | |
1547 | - | else { | |
1548 | - | let eF = ey(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1549 | - | if ((eF == eF)) | |
1550 | - | then { | |
1551 | - | let hF = invoke(aV, "burn", [fa], [AttachedPayment(do, fa)]) | |
1552 | - | if ((hF == hF)) | |
1553 | - | then { | |
1554 | - | let hJ = eG(-(dF), -(dG), 0) | |
1555 | - | let gX = hJ._1 | |
1556 | - | let ex = hJ._2 | |
1557 | - | let gY = eK(eF, ex) | |
1558 | - | if ((gY == gY)) | |
1559 | - | then (dK ++ gX) | |
1560 | - | else throw("Strict value is not equal to itself.") | |
1561 | - | } | |
1562 | - | else throw("Strict value is not equal to itself.") | |
1563 | - | } | |
1564 | - | else throw("Strict value is not equal to itself.") | |
1565 | - | } | |
1566 | - | } | |
1567 | - | ||
1568 | - | ||
1569 | - | ||
1570 | - | @Callable(eY) | |
1571 | - | func unstakeAndGet (ca) = { | |
1572 | - | let hK = if ((size(eY.payments) != 0)) | |
1573 | - | then throw("No payments are expected") | |
1574 | - | else true | |
1575 | - | if ((hK == hK)) | |
1576 | - | then { | |
1577 | - | let dd = be() | |
1578 | - | let dq = fromBase58String(dd[q]) | |
1579 | - | let eF = ey(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1580 | - | if ((eF == eF)) | |
1581 | - | then { | |
1582 | - | let hA = invoke(bw, "unstake", [toBase58String(dq), ca], nil) | |
1583 | - | if ((hA == hA)) | |
1607 | + | let hz = invoke(bw, "unstake", [toBase58String(bq), hy], nil) | |
1608 | + | if ((hz == hz)) | |
1584 | 1609 | then { | |
1585 | - | let ec = dm(toBase58String(eY.transactionId), toBase58String(dq), ca, eY.caller) | |
1586 | - | let dF = ec._1 | |
1587 | - | let dG = ec._2 | |
1588 | - | let dt = parseIntValue(ec._9) | |
1589 | - | let dK = ec._10 | |
1590 | - | let hL = if (if (bc()) | |
1610 | + | let ea = dl(toBase58String(eW.transactionId), toBase58String(bq), hy, eW.caller) | |
1611 | + | let dE = ea._1 | |
1612 | + | let dF = ea._2 | |
1613 | + | let dI = ea._10 | |
1614 | + | let hN = [if ((dE >= hM)) | |
1591 | 1615 | then true | |
1592 | - | else ( | |
1593 | - | then | |
1594 | - | else | |
1595 | - | if (( | |
1616 | + | else throw(makeString(["amount asset amount to receive is less than ", toString(hM)], "")), if ((dF >= hH)) | |
1617 | + | then true | |
1618 | + | else throw(makeString(["price asset amount to receive is less than ", toString(hH)], ""))] | |
1619 | + | if ((hN == hN)) | |
1596 | 1620 | then { | |
1597 | - | let | |
1598 | - | if (( | |
1621 | + | let hE = invoke(aV, "burn", [hy], [AttachedPayment(bq, hy)]) | |
1622 | + | if ((hE == hE)) | |
1599 | 1623 | then { | |
1600 | - | let | |
1601 | - | let | |
1602 | - | let | |
1603 | - | let | |
1604 | - | if (( | |
1605 | - | then ( | |
1624 | + | let hO = eE(-(dE), -(dF), 0) | |
1625 | + | let gV = hO._1 | |
1626 | + | let ev = hO._2 | |
1627 | + | let gW = eI(eD, ev) | |
1628 | + | if ((gW == gW)) | |
1629 | + | then (dI ++ gV) | |
1606 | 1630 | else throw("Strict value is not equal to itself.") | |
1607 | 1631 | } | |
1608 | 1632 | else throw("Strict value is not equal to itself.") | |
1618 | 1642 | ||
1619 | 1643 | ||
1620 | 1644 | ||
1621 | - | @Callable(eY) | |
1622 | - | func unstakeAndGetNoLess (hz,hN,hI) = { | |
1623 | - | let hq = if (bc()) | |
1624 | - | then true | |
1625 | - | else (bp == n) | |
1626 | - | let fS = [if (!(hq)) | |
1627 | - | then true | |
1628 | - | else throw("get operation is blocked by admin"), if ((size(eY.payments) == 0)) | |
1629 | - | then true | |
1630 | - | else throw("no payments are expected")] | |
1631 | - | if ((fS == fS)) | |
1645 | + | @Callable(eW) | |
1646 | + | func activate (hP,hQ) = if ((toString(eW.caller) != toString(aV))) | |
1647 | + | then throw("permissions denied") | |
1648 | + | else $Tuple2([StringEntry(ae(), hP), StringEntry(af(), hQ)], "success") | |
1649 | + | ||
1650 | + | ||
1651 | + | ||
1652 | + | @Callable(eW) | |
1653 | + | func refreshKLp () = { | |
1654 | + | let hR = valueOrElse(getInteger(ak), 0) | |
1655 | + | let hS = if (((height - hR) >= an)) | |
1656 | + | then unit | |
1657 | + | else aS(makeString([toString(an), " blocks have not passed since the previous call"], "")) | |
1658 | + | if ((hS == hS)) | |
1632 | 1659 | then { | |
1633 | - | let eF = ey(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1634 | - | if ((eF == eF)) | |
1635 | - | then { | |
1636 | - | let hA = invoke(bw, "unstake", [toBase58String(bq), hz], nil) | |
1637 | - | if ((hA == hA)) | |
1638 | - | then { | |
1639 | - | let ec = dm(toBase58String(eY.transactionId), toBase58String(bq), hz, eY.caller) | |
1640 | - | let dF = ec._1 | |
1641 | - | let dG = ec._2 | |
1642 | - | let dK = ec._10 | |
1643 | - | let hO = [if ((dF >= hN)) | |
1644 | - | then true | |
1645 | - | else throw(makeString(["amount asset amount to receive is less than ", toString(hN)], "")), if ((dG >= hI)) | |
1646 | - | then true | |
1647 | - | else throw(makeString(["price asset amount to receive is less than ", toString(hI)], ""))] | |
1648 | - | if ((hO == hO)) | |
1649 | - | then { | |
1650 | - | let hF = invoke(aV, "burn", [hz], [AttachedPayment(bq, hz)]) | |
1651 | - | if ((hF == hF)) | |
1652 | - | then { | |
1653 | - | let hP = eG(-(dF), -(dG), 0) | |
1654 | - | let gX = hP._1 | |
1655 | - | let ex = hP._2 | |
1656 | - | let gY = eK(eF, ex) | |
1657 | - | if ((gY == gY)) | |
1658 | - | then (dK ++ gX) | |
1659 | - | else throw("Strict value is not equal to itself.") | |
1660 | - | } | |
1661 | - | else throw("Strict value is not equal to itself.") | |
1662 | - | } | |
1663 | - | else throw("Strict value is not equal to itself.") | |
1664 | - | } | |
1665 | - | else throw("Strict value is not equal to itself.") | |
1666 | - | } | |
1667 | - | else throw("Strict value is not equal to itself.") | |
1660 | + | let eP = valueOrErrorMessage(parseBigInt(valueOrElse(getString(this, aj), "0")), aU("invalid kLp")) | |
1661 | + | let hT = eE(0, 0, 0) | |
1662 | + | let hU = hT._1 | |
1663 | + | let ev = hT._2 | |
1664 | + | let eH = if ((eP != ev)) | |
1665 | + | then hU | |
1666 | + | else aS("nothing to refresh") | |
1667 | + | $Tuple2(eH, toString(ev)) | |
1668 | 1668 | } | |
1669 | 1669 | else throw("Strict value is not equal to itself.") | |
1670 | 1670 | } | |
1671 | 1671 | ||
1672 | 1672 | ||
1673 | 1673 | ||
1674 | - | @Callable(eY) | |
1675 | - | func activate (hQ,hR) = if ((toString(eY.caller) != toString(aV))) | |
1676 | - | then throw("permissions denied") | |
1677 | - | else $Tuple2([StringEntry(ae(), hQ), StringEntry(af(), hR)], "success") | |
1674 | + | @Callable(eW) | |
1675 | + | func getPoolConfigWrapperREADONLY () = $Tuple2(nil, be()) | |
1678 | 1676 | ||
1679 | 1677 | ||
1680 | 1678 | ||
1681 | - | @Callable(eY) | |
1682 | - | func refreshKLp () = { | |
1683 | - | let hS = valueOrElse(getInteger(ak), 0) | |
1684 | - | let hT = if (((height - hS) >= an)) | |
1685 | - | then unit | |
1686 | - | else aS(makeString([toString(an), " blocks have not passed since the previous call"], "")) | |
1687 | - | if ((hT == hT)) | |
1688 | - | then { | |
1689 | - | let eR = valueOrErrorMessage(parseBigInt(valueOrElse(getString(this, aj), "0")), aU("invalid kLp")) | |
1690 | - | let hU = eG(0, 0, 0) | |
1691 | - | let hV = hU._1 | |
1692 | - | let ex = hU._2 | |
1693 | - | let eJ = if ((eR != ex)) | |
1694 | - | then hV | |
1695 | - | else aS("nothing to refresh") | |
1696 | - | $Tuple2(eJ, toString(ex)) | |
1697 | - | } | |
1698 | - | else throw("Strict value is not equal to itself.") | |
1679 | + | @Callable(eW) | |
1680 | + | func getAccBalanceWrapperREADONLY (ar) = $Tuple2(nil, bN(ar)) | |
1681 | + | ||
1682 | + | ||
1683 | + | ||
1684 | + | @Callable(eW) | |
1685 | + | func calcPricesWrapperREADONLY (cW,cX,db) = { | |
1686 | + | let dk = da(cW, cX, db) | |
1687 | + | $Tuple2(nil, [toString(dk[0]), toString(dk[1]), toString(dk[2])]) | |
1699 | 1688 | } | |
1700 | 1689 | ||
1701 | 1690 | ||
1702 | 1691 | ||
1703 | - | @Callable( | |
1704 | - | func | |
1692 | + | @Callable(eW) | |
1693 | + | func toX18WrapperREADONLY (E,F) = $Tuple2(nil, toString(D(E, F))) | |
1705 | 1694 | ||
1706 | 1695 | ||
1707 | 1696 | ||
1708 | - | @Callable( | |
1709 | - | func | |
1697 | + | @Callable(eW) | |
1698 | + | func fromX18WrapperREADONLY (I,J) = $Tuple2(nil, H(parseBigIntValue(I), J)) | |
1710 | 1699 | ||
1711 | 1700 | ||
1712 | 1701 | ||
1713 | - | @Callable(eY) | |
1714 | - | func calcPricesWrapperREADONLY (cX,cY,dc) = { | |
1715 | - | let dl = db(cX, cY, dc) | |
1716 | - | $Tuple2(nil, [toString(dl[0]), toString(dl[1]), toString(dl[2])]) | |
1702 | + | @Callable(eW) | |
1703 | + | func calcPriceBigIntWrapperREADONLY (bR,bS) = $Tuple2(nil, toString(bQ(parseBigIntValue(bR), parseBigIntValue(bS)))) | |
1704 | + | ||
1705 | + | ||
1706 | + | ||
1707 | + | @Callable(eW) | |
1708 | + | func estimatePutOperationWrapperREADONLY (dm,dK,dL,dM,dN,dO,ab,dP,dQ) = $Tuple2(nil, dJ(dm, dK, dL, dM, dN, dO, ab, dP, dQ)) | |
1709 | + | ||
1710 | + | ||
1711 | + | ||
1712 | + | @Callable(eW) | |
1713 | + | func estimateGetOperationWrapperREADONLY (dm,dn,do,ab) = { | |
1714 | + | let ea = dl(dm, dn, do, addressFromStringValue(ab)) | |
1715 | + | $Tuple2(nil, $Tuple10(ea._1, ea._2, ea._3, ea._4, ea._5, ea._6, ea._7, toString(ea._8), ea._9, ea._10)) | |
1717 | 1716 | } | |
1718 | 1717 | ||
1719 | 1718 | ||
1720 | 1719 | ||
1721 | - | @Callable(eY) | |
1722 | - | func toX18WrapperREADONLY (E,F) = $Tuple2(nil, toString(D(E, F))) | |
1723 | - | ||
1724 | - | ||
1725 | - | ||
1726 | - | @Callable(eY) | |
1727 | - | func fromX18WrapperREADONLY (I,J) = $Tuple2(nil, H(parseBigIntValue(I), J)) | |
1728 | - | ||
1729 | - | ||
1730 | - | ||
1731 | - | @Callable(eY) | |
1732 | - | func calcPriceBigIntWrapperREADONLY (bR,bS) = $Tuple2(nil, toString(bQ(parseBigIntValue(bR), parseBigIntValue(bS)))) | |
1733 | - | ||
1734 | - | ||
1735 | - | ||
1736 | - | @Callable(eY) | |
1737 | - | func estimatePutOperationWrapperREADONLY (dn,dM,dN,dO,dP,dQ,ab,dR,dS) = $Tuple2(nil, dL(dn, dM, dN, dO, dP, dQ, ab, dR, dS)) | |
1738 | - | ||
1739 | - | ||
1740 | - | ||
1741 | - | @Callable(eY) | |
1742 | - | func estimateGetOperationWrapperREADONLY (dn,do,dp,ab) = { | |
1743 | - | let ec = dm(dn, do, dp, addressFromStringValue(ab)) | |
1744 | - | $Tuple2(nil, $Tuple10(ec._1, ec._2, ec._3, ec._4, ec._5, ec._6, ec._7, toString(ec._8), ec._9, ec._10)) | |
1720 | + | @Callable(eW) | |
1721 | + | func statsREADONLY () = { | |
1722 | + | let dc = be() | |
1723 | + | let dp = fromBase58String(dc[q]) | |
1724 | + | let hV = dc[r] | |
1725 | + | let hW = dc[s] | |
1726 | + | let dT = dc[v] | |
1727 | + | let dU = dc[w] | |
1728 | + | let dd = parseIntValue(dc[t]) | |
1729 | + | let de = parseIntValue(dc[u]) | |
1730 | + | let hX = valueOrErrorMessage(assetInfo(dp), (("Asset " + toBase58String(dp)) + " doesn't exist")).quantity | |
1731 | + | let hY = bN(hV) | |
1732 | + | let hZ = bN(hW) | |
1733 | + | let ia = if ((hX == 0)) | |
1734 | + | then [e, e, e] | |
1735 | + | else da(hY, hZ, hX) | |
1736 | + | let dz = 0 | |
1737 | + | let ib = H(ia[1], b) | |
1738 | + | let ic = H(ia[2], b) | |
1739 | + | let id = value(getInteger(aV, aF(toString(this)))) | |
1740 | + | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d", toString(hY), toString(hZ), toString(hX), toString(dz), toString(ib), toString(ic), toString(id)], j)) | |
1745 | 1741 | } | |
1746 | 1742 | ||
1747 | 1743 | ||
1748 | 1744 | ||
1749 | - | @Callable(eY) | |
1750 | - | func statsREADONLY () = { | |
1751 | - | let dd = be() | |
1752 | - | let dq = fromBase58String(dd[q]) | |
1753 | - | let hW = dd[r] | |
1754 | - | let hX = dd[s] | |
1755 | - | let dV = dd[v] | |
1756 | - | let dW = dd[w] | |
1757 | - | let de = parseIntValue(dd[t]) | |
1758 | - | let df = parseIntValue(dd[u]) | |
1759 | - | let hY = valueOrErrorMessage(assetInfo(dq), (("Asset " + toBase58String(dq)) + " doesn't exist")).quantity | |
1760 | - | let hZ = bN(hW) | |
1761 | - | let ia = bN(hX) | |
1762 | - | let ib = if ((hY == 0)) | |
1763 | - | then [e, e, e] | |
1764 | - | else db(hZ, ia, hY) | |
1765 | - | let dA = 0 | |
1766 | - | let ic = H(ib[1], b) | |
1767 | - | let id = H(ib[2], b) | |
1768 | - | let ie = value(getInteger(aV, aF(toString(this)))) | |
1769 | - | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d", toString(hZ), toString(ia), toString(hY), toString(dA), toString(ic), toString(id), toString(ie)], j)) | |
1745 | + | @Callable(eW) | |
1746 | + | func evaluatePutByAmountAssetREADONLY (dL) = { | |
1747 | + | let dc = be() | |
1748 | + | let dp = fromBase58String(dc[q]) | |
1749 | + | let dR = dc[r] | |
1750 | + | let dq = fromBase58String(dR) | |
1751 | + | let dS = dc[s] | |
1752 | + | let dr = fromBase58String(dS) | |
1753 | + | let dd = parseIntValue(dc[t]) | |
1754 | + | let de = parseIntValue(dc[u]) | |
1755 | + | let ds = dc[p] | |
1756 | + | let hX = valueOrErrorMessage(assetInfo(dp), (("Asset " + toBase58String(dp)) + " doesn't exist")).quantity | |
1757 | + | let hY = bN(dR) | |
1758 | + | let hZ = bN(dS) | |
1759 | + | let cY = D(hY, dd) | |
1760 | + | let cZ = D(hZ, de) | |
1761 | + | let dy = if ((hX == 0)) | |
1762 | + | then e | |
1763 | + | else bQ(cZ, cY) | |
1764 | + | let dX = D(dL, dd) | |
1765 | + | let dY = fraction(dX, dy, d) | |
1766 | + | let dN = H(dY, de) | |
1767 | + | let fc = dJ("", 500000, dL, dq, dN, dr, "", true, false) | |
1768 | + | let ei = fc._1 | |
1769 | + | let ie = fc._3 | |
1770 | + | let du = fc._4 | |
1771 | + | let dw = fc._5 | |
1772 | + | let dt = fc._6 | |
1773 | + | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d%d", toString(ei), toString(H(dy, b)), toString(du), toString(dw), toString(dt), ds, toString(dL), toString(dN)], j)) | |
1770 | 1774 | } | |
1771 | 1775 | ||
1772 | 1776 | ||
1773 | 1777 | ||
1774 | - | @Callable( | |
1775 | - | func | |
1776 | - | let | |
1777 | - | let | |
1778 | - | let | |
1779 | - | let | |
1780 | - | let | |
1781 | - | let | |
1782 | - | let | |
1783 | - | let | |
1784 | - | let | |
1785 | - | let | |
1786 | - | let | |
1787 | - | let | |
1788 | - | let | |
1789 | - | let | |
1790 | - | let | |
1778 | + | @Callable(eW) | |
1779 | + | func evaluatePutByPriceAssetREADONLY (dN) = { | |
1780 | + | let dc = be() | |
1781 | + | let dp = fromBase58String(dc[q]) | |
1782 | + | let dR = dc[r] | |
1783 | + | let dq = fromBase58String(dR) | |
1784 | + | let dS = dc[s] | |
1785 | + | let dr = fromBase58String(dS) | |
1786 | + | let dd = parseIntValue(dc[t]) | |
1787 | + | let de = parseIntValue(dc[u]) | |
1788 | + | let ds = dc[p] | |
1789 | + | let hX = valueOrErrorMessage(assetInfo(dp), (("Asset " + toBase58String(dp)) + " doesn't exist")).quantity | |
1790 | + | let if = bN(dR) | |
1791 | + | let ig = bN(dS) | |
1792 | + | let ih = D(if, dd) | |
1793 | + | let ii = D(ig, de) | |
1794 | + | let dy = if ((hX == 0)) | |
1791 | 1795 | then e | |
1792 | - | else bQ( | |
1793 | - | let | |
1794 | - | let | |
1795 | - | let | |
1796 | - | let | |
1797 | - | let | |
1798 | - | let | |
1799 | - | let | |
1800 | - | let | |
1801 | - | let | |
1802 | - | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d%d", toString( | |
1796 | + | else bQ(ii, ih) | |
1797 | + | let dY = D(dN, de) | |
1798 | + | let dX = fraction(dY, d, dy) | |
1799 | + | let dL = H(dX, dd) | |
1800 | + | let fc = dJ("", 500000, dL, dq, dN, dr, "", true, false) | |
1801 | + | let ei = fc._1 | |
1802 | + | let ie = fc._3 | |
1803 | + | let du = fc._4 | |
1804 | + | let dw = fc._5 | |
1805 | + | let dt = fc._6 | |
1806 | + | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d%d", toString(ei), toString(H(dy, b)), toString(du), toString(dw), toString(dt), ds, toString(dL), toString(dN)], j)) | |
1803 | 1807 | } | |
1804 | 1808 | ||
1805 | 1809 | ||
1806 | 1810 | ||
1807 | - | @Callable(eY) | |
1808 | - | func evaluatePutByPriceAssetREADONLY (dP) = { | |
1809 | - | let dd = be() | |
1810 | - | let dq = fromBase58String(dd[q]) | |
1811 | - | let dT = dd[r] | |
1812 | - | let dr = fromBase58String(dT) | |
1813 | - | let dU = dd[s] | |
1814 | - | let ds = fromBase58String(dU) | |
1815 | - | let de = parseIntValue(dd[t]) | |
1816 | - | let df = parseIntValue(dd[u]) | |
1817 | - | let dt = dd[p] | |
1818 | - | let hY = valueOrErrorMessage(assetInfo(dq), (("Asset " + toBase58String(dq)) + " doesn't exist")).quantity | |
1819 | - | let ig = bN(dT) | |
1820 | - | let ih = bN(dU) | |
1821 | - | let ii = D(ig, de) | |
1822 | - | let ij = D(ih, df) | |
1823 | - | let dz = if ((hY == 0)) | |
1824 | - | then e | |
1825 | - | else bQ(ij, ii) | |
1826 | - | let ea = D(dP, df) | |
1827 | - | let dZ = fraction(ea, d, dz) | |
1828 | - | let dN = H(dZ, de) | |
1829 | - | let fe = dL("", 500000, dN, dr, dP, ds, "", true, false) | |
1830 | - | let ek = fe._1 | |
1831 | - | let if = fe._3 | |
1832 | - | let dv = fe._4 | |
1833 | - | let dx = fe._5 | |
1834 | - | let du = fe._6 | |
1835 | - | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d%d", toString(ek), toString(H(dz, b)), toString(dv), toString(dx), toString(du), dt, toString(dN), toString(dP)], j)) | |
1811 | + | @Callable(eW) | |
1812 | + | func evaluateGetREADONLY (ij,ik) = { | |
1813 | + | let ea = dl("", ij, ik, this) | |
1814 | + | let dE = ea._1 | |
1815 | + | let dF = ea._2 | |
1816 | + | let du = ea._5 | |
1817 | + | let dw = ea._6 | |
1818 | + | let dt = ea._7 | |
1819 | + | let dz = ea._8 | |
1820 | + | let ds = parseIntValue(ea._9) | |
1821 | + | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d", toString(dE), toString(dF), toString(du), toString(dw), toString(dt), toString(dz), toString(ds)], j)) | |
1836 | 1822 | } | |
1837 | 1823 | ||
1838 | 1824 | ||
1839 | - | ||
1840 | - | @Callable(eY) | |
1841 | - | func evaluateGetREADONLY (ik,il) = { | |
1842 | - | let ec = dm("", ik, il, this) | |
1843 | - | let dF = ec._1 | |
1844 | - | let dG = ec._2 | |
1845 | - | let dv = ec._5 | |
1846 | - | let dx = ec._6 | |
1847 | - | let du = ec._7 | |
1848 | - | let dA = ec._8 | |
1849 | - | let dt = parseIntValue(ec._9) | |
1850 | - | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d", toString(dF), toString(dG), toString(dv), toString(dx), toString(du), toString(dA), toString(dt)], j)) | |
1851 | - | } | |
1852 | - | ||
1853 | - | ||
1854 | - | @Verifier(im) | |
1855 | - | func in () = { | |
1856 | - | let io = { | |
1857 | - | let bX = gk() | |
1825 | + | @Verifier(il) | |
1826 | + | func im () = { | |
1827 | + | let in = { | |
1828 | + | let bX = gi() | |
1858 | 1829 | if ($isInstanceOf(bX, "ByteVector")) | |
1859 | 1830 | then { | |
1860 | - | let | |
1861 | - | | |
1831 | + | let gm = bX | |
1832 | + | gm | |
1862 | 1833 | } | |
1863 | 1834 | else if ($isInstanceOf(bX, "Unit")) | |
1864 | - | then | |
1835 | + | then il.senderPublicKey | |
1865 | 1836 | else throw("Match error") | |
1866 | 1837 | } | |
1867 | - | let bX = | |
1838 | + | let bX = il | |
1868 | 1839 | if ($isInstanceOf(bX, "Order")) | |
1869 | 1840 | then { | |
1870 | - | let | |
1871 | - | let | |
1872 | - | let | |
1873 | - | let aK = | |
1874 | - | let aL = | |
1875 | - | let aM = sigVerify( | |
1876 | - | let aN = sigVerify( | |
1841 | + | let eL = bX | |
1842 | + | let io = bd() | |
1843 | + | let ip = eK(eL) | |
1844 | + | let aK = ip._1 | |
1845 | + | let aL = ip._2 | |
1846 | + | let aM = sigVerify(eL.bodyBytes, eL.proofs[0], eL.senderPublicKey) | |
1847 | + | let aN = sigVerify(eL.bodyBytes, eL.proofs[1], io) | |
1877 | 1848 | if (if (if (aK) | |
1878 | 1849 | then aM | |
1879 | 1850 | else false) | |
1884 | 1855 | } | |
1885 | 1856 | else if ($isInstanceOf(bX, "SetScriptTransaction")) | |
1886 | 1857 | then { | |
1887 | - | let | |
1888 | - | if (sigVerify( | |
1858 | + | let gj = bX | |
1859 | + | if (sigVerify(il.bodyBytes, il.proofs[0], in)) | |
1889 | 1860 | then true | |
1890 | 1861 | else { | |
1891 | - | let | |
1892 | - | let | |
1893 | - | let | |
1894 | - | if (( | |
1895 | - | then ( | |
1862 | + | let iq = blake2b256(value(gj.script)) | |
1863 | + | let ir = fromBase64String(value(getString(aV, aH()))) | |
1864 | + | let is = scriptHash(this) | |
1865 | + | if ((ir == iq)) | |
1866 | + | then (is != iq) | |
1896 | 1867 | else false | |
1897 | 1868 | } | |
1898 | 1869 | } | |
1899 | - | else sigVerify( | |
1870 | + | else sigVerify(il.bodyBytes, il.proofs[0], in) | |
1900 | 1871 | } | |
1901 | 1872 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let a = 8 | |
5 | 5 | ||
6 | 6 | let b = 100000000 | |
7 | 7 | ||
8 | 8 | let c = toBigInt(100000000) | |
9 | 9 | ||
10 | 10 | let d = toBigInt(1000000000000000000) | |
11 | 11 | ||
12 | 12 | let e = toBigInt(0) | |
13 | 13 | ||
14 | 14 | let f = toBigInt(0) | |
15 | 15 | ||
16 | 16 | let g = toBigInt(1) | |
17 | 17 | ||
18 | 18 | let h = toBigInt(2) | |
19 | 19 | ||
20 | 20 | let i = "WAVES" | |
21 | 21 | ||
22 | 22 | let j = "__" | |
23 | 23 | ||
24 | 24 | let k = 1 | |
25 | 25 | ||
26 | 26 | let l = 2 | |
27 | 27 | ||
28 | 28 | let m = 3 | |
29 | 29 | ||
30 | 30 | let n = 4 | |
31 | 31 | ||
32 | 32 | let o = 1 | |
33 | 33 | ||
34 | 34 | let p = 2 | |
35 | 35 | ||
36 | 36 | let q = 3 | |
37 | 37 | ||
38 | 38 | let r = 4 | |
39 | 39 | ||
40 | 40 | let s = 5 | |
41 | 41 | ||
42 | 42 | let t = 6 | |
43 | 43 | ||
44 | 44 | let u = 7 | |
45 | 45 | ||
46 | 46 | let v = 8 | |
47 | 47 | ||
48 | 48 | let w = 9 | |
49 | 49 | ||
50 | 50 | let x = 10 | |
51 | 51 | ||
52 | 52 | let y = 1 | |
53 | 53 | ||
54 | 54 | let z = 2 | |
55 | 55 | ||
56 | 56 | let A = 3 | |
57 | 57 | ||
58 | 58 | let B = 1 | |
59 | 59 | ||
60 | 60 | let C = 7 | |
61 | 61 | ||
62 | 62 | func D (E,F) = fraction(toBigInt(E), d, toBigInt(F)) | |
63 | 63 | ||
64 | 64 | ||
65 | 65 | func G (E,F) = fraction(E, d, F) | |
66 | 66 | ||
67 | 67 | ||
68 | 68 | func H (I,J) = toInt(fraction(I, toBigInt(J), d)) | |
69 | 69 | ||
70 | 70 | ||
71 | 71 | func K (I,J,L) = toInt(fraction(I, toBigInt(J), d, L)) | |
72 | 72 | ||
73 | 73 | ||
74 | 74 | func M (N,O,P) = fraction(N, O, P) | |
75 | 75 | ||
76 | 76 | ||
77 | 77 | func Q (I) = if ((0 > I)) | |
78 | 78 | then -(I) | |
79 | 79 | else I | |
80 | 80 | ||
81 | 81 | ||
82 | 82 | func R (I) = if ((e > I)) | |
83 | 83 | then -(I) | |
84 | 84 | else I | |
85 | 85 | ||
86 | 86 | ||
87 | 87 | func S () = "%s__swapContract" | |
88 | 88 | ||
89 | 89 | ||
90 | 90 | func T () = "%s__factoryContract" | |
91 | 91 | ||
92 | 92 | ||
93 | 93 | func U () = "%s__managerPublicKey" | |
94 | 94 | ||
95 | 95 | ||
96 | 96 | func V () = "%s__pendingManagerPublicKey" | |
97 | 97 | ||
98 | 98 | ||
99 | 99 | func W () = "%s%s__price__last" | |
100 | 100 | ||
101 | 101 | ||
102 | 102 | func X (Y,Z) = makeString(["%s%s%d%d__price__history", toString(Y), toString(Z)], j) | |
103 | 103 | ||
104 | 104 | ||
105 | 105 | func aa (ab,ac) = ((("%s%s%s__P__" + ab) + "__") + ac) | |
106 | 106 | ||
107 | 107 | ||
108 | 108 | func ad (ab,ac) = ((("%s%s%s__G__" + ab) + "__") + ac) | |
109 | 109 | ||
110 | 110 | ||
111 | 111 | func ae () = "%s__amountAsset" | |
112 | 112 | ||
113 | 113 | ||
114 | 114 | func af () = "%s__priceAsset" | |
115 | 115 | ||
116 | 116 | ||
117 | 117 | let ag = "%s__fee" | |
118 | 118 | ||
119 | 119 | let ah = fraction(10, b, 10000) | |
120 | 120 | ||
121 | 121 | let ai = valueOrElse(getInteger(this, ag), ah) | |
122 | 122 | ||
123 | 123 | let aj = makeString(["%s", "kLp"], j) | |
124 | 124 | ||
125 | 125 | let ak = makeString(["%s", "kLpRefreshedHeight"], j) | |
126 | 126 | ||
127 | 127 | let al = makeString(["%s", "refreshKLpDelay"], j) | |
128 | 128 | ||
129 | 129 | let am = 30 | |
130 | 130 | ||
131 | 131 | let an = valueOrElse(getInteger(this, al), am) | |
132 | 132 | ||
133 | 133 | func ao () = "%s__sWavesAssetId" | |
134 | 134 | ||
135 | 135 | ||
136 | 136 | func ap () = "%s__sWavesProxyAddress" | |
137 | 137 | ||
138 | 138 | ||
139 | 139 | func aq (ar) = makeString(["%s%s", "additionalBalance", ar], j) | |
140 | 140 | ||
141 | 141 | ||
142 | 142 | func as (ar) = makeString(["%s%s", "stakingAssetBalance", ar], j) | |
143 | 143 | ||
144 | 144 | ||
145 | 145 | func at (ar) = valueOrElse(getInteger(this, aq(ar)), 0) | |
146 | 146 | ||
147 | 147 | ||
148 | 148 | func au (ar) = valueOrElse(getInteger(this, as(ar)), 0) | |
149 | 149 | ||
150 | 150 | ||
151 | 151 | func av () = "%s__factoryConfig" | |
152 | 152 | ||
153 | 153 | ||
154 | 154 | func aw () = "%s%s__matcher__publicKey" | |
155 | 155 | ||
156 | 156 | ||
157 | 157 | func ax (ay) = (("%s%s%s__" + ay) + "__mappings__poolContract2LpAsset") | |
158 | 158 | ||
159 | 159 | ||
160 | 160 | func az (aA,aB) = (((("%d%d%s__" + aA) + "__") + aB) + "__config") | |
161 | 161 | ||
162 | 162 | ||
163 | 163 | func aC (aD) = ("%s%s%s__mappings__baseAsset2internalId__" + aD) | |
164 | 164 | ||
165 | 165 | ||
166 | 166 | func aE () = "%s__shutdown" | |
167 | 167 | ||
168 | 168 | ||
169 | 169 | func aF (aG) = ("%s%s__poolWeight__" + aG) | |
170 | 170 | ||
171 | 171 | ||
172 | 172 | func aH () = "%s__allowedLpScriptHash" | |
173 | 173 | ||
174 | 174 | ||
175 | 175 | let aI = "%s__feeCollectorAddress" | |
176 | 176 | ||
177 | 177 | func aJ (aK,aL,aM,aN) = throw((((((((("order validation failed: orderValid=" + toString(aK)) + " (") + aL) + ")") + " senderValid=") + toString(aM)) + " matcherValid=") + toString(aN))) | |
178 | 178 | ||
179 | 179 | ||
180 | 180 | func aO (aP,aQ) = valueOrErrorMessage(getString(aP, aQ), makeString(["mandatory ", toString(aP), ".", aQ, " is not defined"], "")) | |
181 | 181 | ||
182 | 182 | ||
183 | 183 | func aR (aP,aQ) = valueOrErrorMessage(getInteger(aP, aQ), makeString(["mandatory ", toString(aP), ".", aQ, " is not defined"], "")) | |
184 | 184 | ||
185 | 185 | ||
186 | 186 | func aS (aT) = throw(makeString(["lp.ride:", aT], " ")) | |
187 | 187 | ||
188 | 188 | ||
189 | 189 | func aU (aT) = makeString(["lp.ride:", aT], " ") | |
190 | 190 | ||
191 | 191 | ||
192 | 192 | let aV = addressFromStringValue(aO(this, T())) | |
193 | 193 | ||
194 | 194 | let aW = addressFromStringValue(aO(aV, aI)) | |
195 | 195 | ||
196 | 196 | let aX = { | |
197 | 197 | let aY = invoke(aV, "getInFeeREADONLY", [toString(this)], nil) | |
198 | 198 | if ($isInstanceOf(aY, "Int")) | |
199 | 199 | then aY | |
200 | 200 | else throw(($getType(aY) + " couldn't be cast to Int")) | |
201 | 201 | } | |
202 | 202 | ||
203 | 203 | let aZ = { | |
204 | 204 | let aY = invoke(aV, "getOutFeeREADONLY", [toString(this)], nil) | |
205 | 205 | if ($isInstanceOf(aY, "Int")) | |
206 | 206 | then aY | |
207 | 207 | else throw(($getType(aY) + " couldn't be cast to Int")) | |
208 | 208 | } | |
209 | 209 | ||
210 | 210 | func ba () = aO(aV, ao()) | |
211 | 211 | ||
212 | 212 | ||
213 | 213 | func bb () = aO(aV, ap()) | |
214 | 214 | ||
215 | 215 | ||
216 | 216 | func bc () = valueOrElse(getBoolean(aV, aE()), false) | |
217 | 217 | ||
218 | 218 | ||
219 | 219 | func bd () = fromBase58String(aO(aV, aw())) | |
220 | 220 | ||
221 | 221 | ||
222 | 222 | func be () = { | |
223 | 223 | let bf = aO(this, ae()) | |
224 | 224 | let bg = aO(this, af()) | |
225 | 225 | let aB = aR(aV, aC(bg)) | |
226 | 226 | let aA = aR(aV, aC(bf)) | |
227 | 227 | split(aO(aV, az(toString(aA), toString(aB))), j) | |
228 | 228 | } | |
229 | 229 | ||
230 | 230 | ||
231 | 231 | func bh (bi) = if ((bi == i)) | |
232 | 232 | then unit | |
233 | 233 | else fromBase58String(bi) | |
234 | 234 | ||
235 | 235 | ||
236 | 236 | func bj (bi) = if ((bi == unit)) | |
237 | 237 | then i | |
238 | 238 | else toBase58String(value(bi)) | |
239 | 239 | ||
240 | 240 | ||
241 | 241 | func bk (bl) = $Tuple7(addressFromStringValue(bl[o]), parseIntValue(bl[p]), fromBase58String(bl[q]), bh(bl[r]), bh(bl[s]), parseIntValue(bl[t]), parseIntValue(bl[u])) | |
242 | 242 | ||
243 | 243 | ||
244 | 244 | let bm = bk(be()) | |
245 | 245 | ||
246 | 246 | let bn = bm | |
247 | 247 | ||
248 | 248 | let bo = bn._1 | |
249 | 249 | ||
250 | 250 | let bp = bn._2 | |
251 | 251 | ||
252 | 252 | let bq = bn._3 | |
253 | 253 | ||
254 | 254 | let br = bn._4 | |
255 | 255 | ||
256 | 256 | let bs = bn._5 | |
257 | 257 | ||
258 | 258 | let bt = bn._6 | |
259 | 259 | ||
260 | 260 | let bu = bn._7 | |
261 | 261 | ||
262 | 262 | func bv () = split(aO(aV, av()), j) | |
263 | 263 | ||
264 | 264 | ||
265 | 265 | let bw = valueOrErrorMessage(addressFromString(bv()[B]), "incorrect staking address") | |
266 | 266 | ||
267 | 267 | let bx = valueOrErrorMessage(addressFromString(bv()[C]), "incorrect staking address") | |
268 | 268 | ||
269 | 269 | func by (bz,bA,bB,bC,bD,bE,bF,bG,bH,bI) = makeString(["%d%d%d%d%d%d%d%d%d%d", toString(bz), toString(bA), toString(bB), toString(bC), toString(bD), toString(bE), toString(bF), toString(bG), toString(bH), toString(bI)], j) | |
270 | 270 | ||
271 | 271 | ||
272 | 272 | func bJ (bK,bL,bM,bC,bF,bG) = makeString(["%d%d%d%d%d%d", toString(bK), toString(bL), toString(bM), toString(bC), toString(bF), toString(bG)], j) | |
273 | 273 | ||
274 | 274 | ||
275 | 275 | func bN (ar) = { | |
276 | 276 | let bO = if ((ar == "WAVES")) | |
277 | 277 | then wavesBalance(this).available | |
278 | 278 | else assetBalance(this, fromBase58String(ar)) | |
279 | 279 | let bP = ((bO + at(ar)) - au(ar)) | |
280 | 280 | max([0, bP]) | |
281 | 281 | } | |
282 | 282 | ||
283 | 283 | ||
284 | 284 | func bQ (bR,bS) = fraction(bR, d, bS) | |
285 | 285 | ||
286 | 286 | ||
287 | 287 | func bT (bR,bS,L) = fraction(bR, d, bS, L) | |
288 | 288 | ||
289 | 289 | ||
290 | 290 | func bU (bV) = { | |
291 | 291 | let bW = invoke(bV, "getRate", nil, nil) | |
292 | 292 | if ((bW == bW)) | |
293 | 293 | then { | |
294 | 294 | let bX = bW | |
295 | 295 | if ($isInstanceOf(bX, "Int")) | |
296 | 296 | then { | |
297 | 297 | let bY = bX | |
298 | 298 | bY | |
299 | 299 | } | |
300 | 300 | else aS("proxy.getRate() unexpected value") | |
301 | 301 | } | |
302 | 302 | else throw("Strict value is not equal to itself.") | |
303 | 303 | } | |
304 | 304 | ||
305 | 305 | ||
306 | 306 | func bZ (ar,ca,cb,bV) = { | |
307 | 307 | let cc = at(ar) | |
308 | 308 | if ((cc == cc)) | |
309 | 309 | then { | |
310 | 310 | let cd = au(cb) | |
311 | 311 | if ((cd == cd)) | |
312 | 312 | then { | |
313 | 313 | let ce = bh(ar) | |
314 | 314 | if ((ca > 0)) | |
315 | 315 | then { | |
316 | 316 | let cf = invoke(bV, "deposit", nil, [AttachedPayment(ce, ca)]) | |
317 | 317 | if ((cf == cf)) | |
318 | 318 | then { | |
319 | 319 | let bX = cf | |
320 | 320 | if ($isInstanceOf(bX, "Int")) | |
321 | 321 | then { | |
322 | 322 | let cg = bX | |
323 | 323 | let ch = (cc + ca) | |
324 | 324 | let ci = (cd + cg) | |
325 | 325 | [IntegerEntry(aq(ar), ch), IntegerEntry(as(cb), ci)] | |
326 | 326 | } | |
327 | 327 | else nil | |
328 | 328 | } | |
329 | 329 | else throw("Strict value is not equal to itself.") | |
330 | 330 | } | |
331 | 331 | else nil | |
332 | 332 | } | |
333 | 333 | else throw("Strict value is not equal to itself.") | |
334 | 334 | } | |
335 | 335 | else throw("Strict value is not equal to itself.") | |
336 | 336 | } | |
337 | 337 | ||
338 | 338 | ||
339 | 339 | func cj (ar,ca,cb,bV,ck,cl) = { | |
340 | 340 | let cc = at(ar) | |
341 | 341 | if ((cc == cc)) | |
342 | 342 | then { | |
343 | 343 | let cd = au(cb) | |
344 | 344 | if ((cd == cd)) | |
345 | 345 | then { | |
346 | 346 | let cm = bU(bV) | |
347 | 347 | if ((cm == cm)) | |
348 | 348 | then { | |
349 | 349 | let cn = fraction(ck, cc, cd) | |
350 | 350 | let co = bh(cb) | |
351 | 351 | let cp = fraction(ck, ca, cn) | |
352 | 352 | let cq = fraction(ck, ca, cm) | |
353 | 353 | let cr = max([0, (cp - cq)]) | |
354 | 354 | if ((cq > 0)) | |
355 | 355 | then { | |
356 | 356 | let cs = invoke(bV, "withdraw", nil, [AttachedPayment(co, cq)]) | |
357 | 357 | if ((cs == cs)) | |
358 | 358 | then { | |
359 | 359 | let bX = cs | |
360 | 360 | if ($isInstanceOf(bX, "Int")) | |
361 | 361 | then { | |
362 | 362 | let ct = bX | |
363 | 363 | let ch = (cc - ct) | |
364 | 364 | let ci = ((cd - cq) - cr) | |
365 | 365 | [IntegerEntry(aq(ar), ch), IntegerEntry(as(cb), ci), ScriptTransfer(cl, cr, bh(cb))] | |
366 | 366 | } | |
367 | 367 | else nil | |
368 | 368 | } | |
369 | 369 | else throw("Strict value is not equal to itself.") | |
370 | 370 | } | |
371 | 371 | else nil | |
372 | 372 | } | |
373 | 373 | else throw("Strict value is not equal to itself.") | |
374 | 374 | } | |
375 | 375 | else throw("Strict value is not equal to itself.") | |
376 | 376 | } | |
377 | 377 | else throw("Strict value is not equal to itself.") | |
378 | 378 | } | |
379 | 379 | ||
380 | 380 | ||
381 | 381 | func cu (ar) = invoke(aV, "getPoolLeaseConfigREADONLY", [toString(this), ar], nil) | |
382 | 382 | ||
383 | 383 | ||
384 | 384 | func cv (cw,ar,cb,cx,bV,ck,cl) = { | |
385 | 385 | let cc = at(ar) | |
386 | 386 | if ((cc == cc)) | |
387 | 387 | then { | |
388 | 388 | let cd = au(cb) | |
389 | 389 | if ((cd == cd)) | |
390 | 390 | then { | |
391 | 391 | let cy = { | |
392 | 392 | let bX = bh(ar) | |
393 | 393 | if ($isInstanceOf(bX, "ByteVector")) | |
394 | 394 | then { | |
395 | 395 | let cz = bX | |
396 | 396 | assetBalance(this, cz) | |
397 | 397 | } | |
398 | 398 | else if ($isInstanceOf(bX, "Unit")) | |
399 | 399 | then { | |
400 | 400 | let cA = bX | |
401 | 401 | wavesBalance(this).available | |
402 | 402 | } | |
403 | 403 | else throw("Match error") | |
404 | 404 | } | |
405 | 405 | if ((cy == cy)) | |
406 | 406 | then { | |
407 | 407 | let cB = max([0, ((cy + cc) - cx)]) | |
408 | 408 | let cC = fraction(cw, cB, 100) | |
409 | 409 | let cD = (cc - cC) | |
410 | 410 | if ((cD == 0)) | |
411 | 411 | then nil | |
412 | 412 | else if ((0 > cD)) | |
413 | 413 | then { | |
414 | 414 | let cE = -(cD) | |
415 | 415 | bZ(ar, cE, cb, bV) | |
416 | 416 | } | |
417 | 417 | else { | |
418 | 418 | let cF = cD | |
419 | 419 | cj(ar, cF, cb, bV, ck, cl) | |
420 | 420 | } | |
421 | 421 | } | |
422 | 422 | else throw("Strict value is not equal to itself.") | |
423 | 423 | } | |
424 | 424 | else throw("Strict value is not equal to itself.") | |
425 | 425 | } | |
426 | 426 | else throw("Strict value is not equal to itself.") | |
427 | 427 | } | |
428 | 428 | ||
429 | 429 | ||
430 | 430 | func cG (ar) = { | |
431 | 431 | let bX = cu(ar) | |
432 | 432 | if ($isInstanceOf(bX, "(Boolean, Int, Int, String, String, Int, String)")) | |
433 | 433 | then { | |
434 | 434 | let cH = bX | |
435 | 435 | let cI = cH | |
436 | 436 | let cJ = cI._1 | |
437 | 437 | let cK = cI._2 | |
438 | 438 | let cx = cI._3 | |
439 | 439 | let cL = cI._4 | |
440 | 440 | let cM = cI._5 | |
441 | 441 | let ck = cI._6 | |
442 | 442 | let cN = cI._7 | |
443 | 443 | if (cJ) | |
444 | 444 | then cv(cK, ar, cM, cx, addressFromStringValue(cL), ck, addressFromStringValue(cN)) | |
445 | 445 | else nil | |
446 | 446 | } | |
447 | 447 | else aS((("[" + ar) + "] Rebalance error")) | |
448 | 448 | } | |
449 | 449 | ||
450 | 450 | ||
451 | - | func cO (ar, | |
451 | + | func cO (ar,cP) = { | |
452 | 452 | let bX = cu(ar) | |
453 | 453 | if ($isInstanceOf(bX, "(Boolean, Int, Int, String, String, Int, String)")) | |
454 | 454 | then { | |
455 | 455 | let cH = bX | |
456 | - | let | |
457 | - | let cJ = | |
458 | - | let cK = | |
459 | - | let cx = | |
460 | - | let cL = | |
461 | - | let cM = | |
462 | - | let ck = | |
463 | - | let cN = | |
456 | + | let cQ = cH | |
457 | + | let cJ = cQ._1 | |
458 | + | let cK = cQ._2 | |
459 | + | let cx = cQ._3 | |
460 | + | let cL = cQ._4 | |
461 | + | let cM = cQ._5 | |
462 | + | let ck = cQ._6 | |
463 | + | let cN = cQ._7 | |
464 | 464 | if (cJ) | |
465 | - | then cj(ar, ca, cM, addressFromStringValue(cL), ck, addressFromStringValue(cN)) | |
465 | + | then { | |
466 | + | let cR = max([0, ((bN(ar) - cP) - cx)]) | |
467 | + | if ((cR == cR)) | |
468 | + | then { | |
469 | + | let ch = fraction(cK, cR, 100) | |
470 | + | if ((ch == ch)) | |
471 | + | then { | |
472 | + | let cS = max([0, (at(ar) - ch)]) | |
473 | + | if ((cS == cS)) | |
474 | + | then cj(ar, cS, cM, addressFromStringValue(cL), ck, addressFromStringValue(cN)) | |
475 | + | else throw("Strict value is not equal to itself.") | |
476 | + | } | |
477 | + | else throw("Strict value is not equal to itself.") | |
478 | + | } | |
479 | + | else throw("Strict value is not equal to itself.") | |
480 | + | } | |
466 | 481 | else nil | |
467 | 482 | } | |
468 | - | else aS((("[" + ar) + "] | |
483 | + | else aS((("[" + ar) + "] getWithdrawAssetState() error")) | |
469 | 484 | } | |
470 | 485 | ||
471 | 486 | ||
472 | - | func cQ (ar,ca) = { | |
473 | - | let cR = { | |
474 | - | let bX = bh(ar) | |
475 | - | if ($isInstanceOf(bX, "ByteVector")) | |
476 | - | then { | |
477 | - | let cz = bX | |
478 | - | assetBalance(this, cz) | |
479 | - | } | |
480 | - | else if ($isInstanceOf(bX, "Unit")) | |
481 | - | then { | |
482 | - | let cS = bX | |
483 | - | wavesBalance(this).available | |
484 | - | } | |
485 | - | else throw("Match error") | |
486 | - | } | |
487 | - | if ((ca > cR)) | |
488 | - | then { | |
489 | - | let cT = (ca - cR) | |
490 | - | cO(ar, cT) | |
491 | - | } | |
492 | - | else nil | |
487 | + | func cT (cU,cV,cW,cX) = { | |
488 | + | let cY = D(cW, cU) | |
489 | + | let cZ = D(cX, cV) | |
490 | + | bQ(cZ, cY) | |
493 | 491 | } | |
494 | 492 | ||
495 | 493 | ||
496 | - | func cU (cV,cW,cX,cY) = { | |
497 | - | let cZ = D(cX, cV) | |
498 | - | let da = D(cY, cW) | |
499 | - | bQ(da, cZ) | |
494 | + | func da (cW,cX,db) = { | |
495 | + | let dc = be() | |
496 | + | let dd = parseIntValue(dc[t]) | |
497 | + | let de = parseIntValue(dc[u]) | |
498 | + | let df = cT(dd, de, cW, cX) | |
499 | + | let bS = D(cW, dd) | |
500 | + | let bR = D(cX, de) | |
501 | + | let dg = D(db, b) | |
502 | + | let dh = bQ(bS, dg) | |
503 | + | let di = bQ(bR, dg) | |
504 | + | [df, dh, di] | |
500 | 505 | } | |
501 | 506 | ||
502 | 507 | ||
503 | - | func db (cX,cY,dc) = { | |
504 | - | let dd = be() | |
505 | - | let de = parseIntValue(dd[t]) | |
506 | - | let df = parseIntValue(dd[u]) | |
507 | - | let dg = cU(de, df, cX, cY) | |
508 | - | let bS = D(cX, de) | |
509 | - | let bR = D(cY, df) | |
510 | - | let dh = D(dc, b) | |
511 | - | let di = bQ(bS, dh) | |
512 | - | let dj = bQ(bR, dh) | |
513 | - | [dg, di, dj] | |
508 | + | func dj (cW,cX,db) = { | |
509 | + | let dk = da(cW, cX, db) | |
510 | + | [H(dk[0], b), H(dk[1], b), H(dk[2], b)] | |
514 | 511 | } | |
515 | 512 | ||
516 | 513 | ||
517 | - | func dk (cX,cY,dc) = { | |
518 | - | let dl = db(cX, cY, dc) | |
519 | - | [H(dl[0], b), H(dl[1], b), H(dl[2], b)] | |
520 | - | } | |
521 | - | ||
522 | - | ||
523 | - | func dm (dn,do,dp,ab) = { | |
524 | - | let dd = be() | |
525 | - | let dq = dd[q] | |
526 | - | let dr = dd[r] | |
527 | - | let ds = dd[s] | |
528 | - | let cV = parseIntValue(dd[t]) | |
529 | - | let cW = parseIntValue(dd[u]) | |
530 | - | let dt = dd[p] | |
531 | - | let du = valueOrErrorMessage(assetInfo(fromBase58String(dq)), (("Asset " + dq) + " doesn't exist")).quantity | |
532 | - | if ((dq != do)) | |
514 | + | func dl (dm,dn,do,ab) = { | |
515 | + | let dc = be() | |
516 | + | let dp = dc[q] | |
517 | + | let dq = dc[r] | |
518 | + | let dr = dc[s] | |
519 | + | let cU = parseIntValue(dc[t]) | |
520 | + | let cV = parseIntValue(dc[u]) | |
521 | + | let ds = dc[p] | |
522 | + | let dt = valueOrErrorMessage(assetInfo(fromBase58String(dp)), (("Asset " + dp) + " doesn't exist")).quantity | |
523 | + | if ((dp != dn)) | |
533 | 524 | then throw("Invalid asset passed.") | |
534 | 525 | else { | |
535 | - | let dv = bN(dr) | |
536 | - | let dw = D(dv, cV) | |
537 | - | let dx = bN(ds) | |
538 | - | let dy = D(dx, cW) | |
539 | - | let dz = bQ(dy, dw) | |
540 | - | let dA = H(dz, b) | |
541 | - | let dB = D(dp, b) | |
542 | - | let dC = D(du, b) | |
543 | - | let dD = fraction(dw, dB, dC) | |
544 | - | let dE = fraction(dy, dB, dC) | |
526 | + | let du = bN(dq) | |
527 | + | let dv = D(du, cU) | |
528 | + | let dw = bN(dr) | |
529 | + | let dx = D(dw, cV) | |
530 | + | let dy = bQ(dx, dv) | |
531 | + | let dz = H(dy, b) | |
532 | + | let dA = D(do, b) | |
533 | + | let dB = D(dt, b) | |
534 | + | let dC = fraction(dv, dA, dB) | |
535 | + | let dD = fraction(dx, dA, dB) | |
536 | + | let dE = K(dC, cU, FLOOR) | |
545 | 537 | let dF = K(dD, cV, FLOOR) | |
546 | - | let dG = K(dE, cW, FLOOR) | |
547 | - | let dH = cQ(dr, dF) | |
548 | - | if ((dH == dH)) | |
538 | + | let dG = cO(dq, dE) | |
539 | + | if ((dG == dG)) | |
549 | 540 | then { | |
550 | - | let | |
551 | - | if (( | |
541 | + | let dH = cO(dr, dF) | |
542 | + | if ((dH == dH)) | |
552 | 543 | then { | |
553 | - | let dJ = invoke(this, "rebalance", nil, nil) | |
554 | - | if ((dJ == dJ)) | |
555 | - | then { | |
556 | - | let dK = if ((dn == "")) | |
557 | - | then nil | |
558 | - | else ((dH ++ dI) ++ [ScriptTransfer(ab, dF, if ((dr == "WAVES")) | |
559 | - | then unit | |
560 | - | else fromBase58String(dr)), ScriptTransfer(ab, dG, if ((ds == "WAVES")) | |
561 | - | then unit | |
562 | - | else fromBase58String(ds)), StringEntry(ad(toString(ab), dn), bJ(dF, dG, dp, dA, height, lastBlock.timestamp)), IntegerEntry(W(), dA), IntegerEntry(X(height, lastBlock.timestamp), dA)]) | |
563 | - | $Tuple10(dF, dG, dr, ds, dv, dx, du, dz, dt, dK) | |
564 | - | } | |
565 | - | else throw("Strict value is not equal to itself.") | |
544 | + | let dI = if ((dm == "")) | |
545 | + | then nil | |
546 | + | else ((dG ++ dH) ++ [ScriptTransfer(ab, dE, if ((dq == "WAVES")) | |
547 | + | then unit | |
548 | + | else fromBase58String(dq)), ScriptTransfer(ab, dF, if ((dr == "WAVES")) | |
549 | + | then unit | |
550 | + | else fromBase58String(dr)), StringEntry(ad(toString(ab), dm), bJ(dE, dF, do, dz, height, lastBlock.timestamp)), IntegerEntry(W(), dz), IntegerEntry(X(height, lastBlock.timestamp), dz)]) | |
551 | + | $Tuple10(dE, dF, dq, dr, du, dw, dt, dy, ds, dI) | |
566 | 552 | } | |
567 | 553 | else throw("Strict value is not equal to itself.") | |
568 | 554 | } | |
569 | 555 | else throw("Strict value is not equal to itself.") | |
570 | 556 | } | |
571 | 557 | } | |
572 | 558 | ||
573 | 559 | ||
574 | - | func | |
575 | - | let | |
576 | - | let | |
577 | - | let | |
578 | - | let | |
579 | - | let | |
580 | - | let | |
581 | - | let | |
582 | - | let | |
583 | - | let | |
584 | - | let | |
585 | - | let | |
586 | - | let | |
587 | - | if (if (( | |
560 | + | func dJ (dm,dK,dL,dM,dN,dO,ab,dP,dQ) = { | |
561 | + | let dc = be() | |
562 | + | let dp = fromBase58String(dc[q]) | |
563 | + | let dR = dc[r] | |
564 | + | let dS = dc[s] | |
565 | + | let dT = dc[v] | |
566 | + | let dU = dc[w] | |
567 | + | let dd = parseIntValue(dc[t]) | |
568 | + | let de = parseIntValue(dc[u]) | |
569 | + | let ds = dc[p] | |
570 | + | let dt = valueOrErrorMessage(assetInfo(dp), (("Asset " + toBase58String(dp)) + " doesn't exist")).quantity | |
571 | + | let dV = toBase58String(valueOrElse(dM, fromBase58String("WAVES"))) | |
572 | + | let dW = toBase58String(valueOrElse(dO, fromBase58String("WAVES"))) | |
573 | + | if (if ((dR != dV)) | |
588 | 574 | then true | |
589 | - | else ( | |
575 | + | else (dS != dW)) | |
590 | 576 | then throw("Invalid amt or price asset passed.") | |
591 | 577 | else { | |
592 | - | let | |
593 | - | then bN( | |
594 | - | else (bN( | |
595 | - | let | |
596 | - | then bN( | |
597 | - | else (bN( | |
598 | - | let | |
599 | - | let | |
600 | - | let | |
601 | - | let | |
602 | - | let | |
603 | - | let | |
578 | + | let du = if (dP) | |
579 | + | then bN(dR) | |
580 | + | else (bN(dR) - dL) | |
581 | + | let dw = if (dP) | |
582 | + | then bN(dS) | |
583 | + | else (bN(dS) - dN) | |
584 | + | let dX = D(dL, dd) | |
585 | + | let dY = D(dN, de) | |
586 | + | let dZ = bQ(dY, dX) | |
587 | + | let dv = D(du, dd) | |
588 | + | let dx = D(dw, de) | |
589 | + | let ea = if ((dt == 0)) | |
604 | 590 | then { | |
605 | - | let | |
606 | - | let | |
607 | - | let | |
608 | - | $Tuple5(H( | |
591 | + | let dy = e | |
592 | + | let eb = e | |
593 | + | let dg = pow((dX * dY), 0, toBigInt(5), 1, 0, DOWN) | |
594 | + | $Tuple5(H(dg, b), H(dX, dd), H(dY, de), bQ((dx + dY), (dv + dX)), eb) | |
609 | 595 | } | |
610 | 596 | else { | |
611 | - | let | |
612 | - | let | |
613 | - | let | |
614 | - | if (if (( | |
615 | - | then ( | |
597 | + | let dy = bQ(dx, dv) | |
598 | + | let eb = fraction(R((dy - dZ)), d, dy) | |
599 | + | let ec = D(dK, b) | |
600 | + | if (if ((dy != e)) | |
601 | + | then (eb > ec) | |
616 | 602 | else false) | |
617 | - | then throw(((("Price slippage " + toString( | |
603 | + | then throw(((("Price slippage " + toString(eb)) + " exceeded the passed limit of ") + toString(ec))) | |
618 | 604 | else { | |
619 | - | let | |
620 | - | let | |
621 | - | let | |
622 | - | let | |
623 | - | then $Tuple2( | |
624 | - | else $Tuple2( | |
625 | - | let | |
626 | - | let | |
627 | - | let | |
628 | - | $Tuple5(K( | |
605 | + | let dB = D(dt, b) | |
606 | + | let ed = fraction(dX, bT(dx, dv, CEILING), d, CEILING) | |
607 | + | let ee = fraction(dY, d, bT(dx, dv, FLOOR), CEILING) | |
608 | + | let ef = if ((ed > dY)) | |
609 | + | then $Tuple2(ee, dY) | |
610 | + | else $Tuple2(dX, ed) | |
611 | + | let eg = ef._1 | |
612 | + | let eh = ef._2 | |
613 | + | let dg = fraction(dB, eh, dx, FLOOR) | |
614 | + | $Tuple5(K(dg, b, FLOOR), K(eg, dd, CEILING), K(eh, de, CEILING), dy, eb) | |
629 | 615 | } | |
630 | 616 | } | |
631 | - | let | |
632 | - | let | |
633 | - | let | |
634 | - | let | |
635 | - | let | |
636 | - | if ((0 >= | |
617 | + | let ei = ea._1 | |
618 | + | let ej = ea._2 | |
619 | + | let ek = ea._3 | |
620 | + | let dz = H(ea._4, b) | |
621 | + | let el = H(ea._5, b) | |
622 | + | if ((0 >= ei)) | |
637 | 623 | then throw("Invalid calculations. LP calculated is less than zero.") | |
638 | 624 | else { | |
639 | - | let | |
625 | + | let em = if (!(dQ)) | |
640 | 626 | then 0 | |
641 | - | else | |
642 | - | let | |
643 | - | let | |
644 | - | let | |
645 | - | $Tuple13( | |
627 | + | else ei | |
628 | + | let en = (dL - ej) | |
629 | + | let eo = (dN - ek) | |
630 | + | let ep = [IntegerEntry(W(), dz), IntegerEntry(X(height, lastBlock.timestamp), dz), StringEntry(aa(ab, dm), by(ej, ek, em, dz, dK, el, height, lastBlock.timestamp, en, eo))] | |
631 | + | $Tuple13(ei, em, dz, du, dw, dt, dp, ds, ep, en, eo, dM, dO) | |
646 | 632 | } | |
647 | 633 | } | |
648 | 634 | } | |
649 | 635 | ||
650 | 636 | ||
651 | - | func | |
652 | - | let | |
653 | - | let | |
654 | - | let | |
655 | - | if (( | |
637 | + | func eq (er,es,dt) = { | |
638 | + | let et = G(er, toBigInt(bt)) | |
639 | + | let eu = G(es, toBigInt(bu)) | |
640 | + | let ev = fraction(pow((et * eu), 0, toBigInt(5), 1, 18, DOWN), g, dt) | |
641 | + | if ((dt == f)) | |
656 | 642 | then f | |
657 | - | else | |
643 | + | else ev | |
658 | 644 | } | |
659 | 645 | ||
660 | 646 | ||
661 | - | func | |
662 | - | let | |
663 | - | let | |
664 | - | let | |
665 | - | let | |
666 | - | | |
647 | + | func ew (ex,ey,ez) = { | |
648 | + | let eA = (toBigInt(bN(bj(br))) - ex) | |
649 | + | let eB = (toBigInt(bN(bj(bs))) - ey) | |
650 | + | let eC = (toBigInt(value(assetInfo(bq)).quantity) - ez) | |
651 | + | let eD = eq(eA, eB, eC) | |
652 | + | eD | |
667 | 653 | } | |
668 | 654 | ||
669 | 655 | ||
670 | - | func | |
671 | - | let | |
672 | - | let | |
673 | - | let | |
674 | - | let | |
675 | - | let | |
676 | - | $Tuple2( | |
656 | + | func eE (eF,eG,ez) = { | |
657 | + | let eA = (bN(bj(br)) + eF) | |
658 | + | let eB = (bN(bj(bs)) + eG) | |
659 | + | let eC = (value(assetInfo(bq)).quantity + ez) | |
660 | + | let ev = eq(toBigInt(eA), toBigInt(eB), toBigInt(eC)) | |
661 | + | let eH = [IntegerEntry(ak, height), StringEntry(aj, toString(ev))] | |
662 | + | $Tuple2(eH, ev) | |
677 | 663 | } | |
678 | 664 | ||
679 | 665 | ||
680 | - | func | |
666 | + | func eI (eJ,ev) = if ((ev >= eJ)) | |
681 | 667 | then true | |
682 | - | else aS(makeString(["updated KLp lower than current KLp", toString( | |
668 | + | else aS(makeString(["updated KLp lower than current KLp", toString(eJ), toString(ev)], " ")) | |
683 | 669 | ||
684 | 670 | ||
685 | - | func | |
686 | - | let | |
687 | - | let | |
688 | - | let | |
689 | - | let | |
690 | - | let | |
691 | - | then $Tuple2( | |
692 | - | else $Tuple2(-( | |
693 | - | let | |
694 | - | let | |
671 | + | func eK (eL) = { | |
672 | + | let eA = bN(bj(br)) | |
673 | + | let eB = bN(bj(bs)) | |
674 | + | let eM = eL.amount | |
675 | + | let eN = fraction(eL.amount, eL.price, b, FLOOR) | |
676 | + | let eO = if ((eL.orderType == Buy)) | |
677 | + | then $Tuple2(eM, -(eN)) | |
678 | + | else $Tuple2(-(eM), eN) | |
679 | + | let eF = eO._1 | |
680 | + | let eG = eO._2 | |
695 | 681 | if (if (if (bc()) | |
696 | 682 | then true | |
697 | 683 | else (bp == m)) | |
698 | 684 | then true | |
699 | 685 | else (bp == n)) | |
700 | 686 | then throw("Exchange operations disabled") | |
701 | - | else if (if (( | |
687 | + | else if (if ((eL.assetPair.amountAsset != br)) | |
702 | 688 | then true | |
703 | - | else ( | |
689 | + | else (eL.assetPair.priceAsset != bs)) | |
704 | 690 | then throw("Wrong order assets.") | |
705 | 691 | else { | |
706 | - | let | |
707 | - | let | |
708 | - | let | |
709 | - | let | |
710 | - | let | |
711 | - | let | |
712 | - | $Tuple2( | |
692 | + | let eP = valueOrErrorMessage(parseBigInt(valueOrElse(getString(this, aj), "0")), aU("invalid kLp")) | |
693 | + | let eQ = eE(eF, eG, 0) | |
694 | + | let eR = eQ._1 | |
695 | + | let eS = eQ._2 | |
696 | + | let eT = (eS >= eP) | |
697 | + | let eU = makeString(["kLp=", toString(eP), " kLpNew=", toString(eS), " amountAssetBalance=", toString(eA), " priceAssetBalance=", toString(eB), " amountAssetBalanceDelta=", toString(eF), " priceAssetBalanceDelta=", toString(eG), " height=", toString(height)], "") | |
698 | + | $Tuple2(eT, eU) | |
713 | 699 | } | |
714 | 700 | } | |
715 | 701 | ||
716 | 702 | ||
717 | - | func | |
703 | + | func eV (eW) = if ((size(eW.payments) != 1)) | |
718 | 704 | then throw("exactly 1 payment is expected") | |
719 | 705 | else { | |
720 | - | let | |
721 | - | let | |
722 | - | let | |
723 | - | let | |
724 | - | let | |
725 | - | let | |
726 | - | let | |
727 | - | let | |
706 | + | let eX = value(eW.payments[0]) | |
707 | + | let dn = value(eX.assetId) | |
708 | + | let eY = eX.amount | |
709 | + | let ea = dl(toBase58String(eW.transactionId), toBase58String(dn), eY, eW.caller) | |
710 | + | let dE = ea._1 | |
711 | + | let dF = ea._2 | |
712 | + | let ds = parseIntValue(ea._9) | |
713 | + | let dI = ea._10 | |
728 | 714 | if (if (bc()) | |
729 | 715 | then true | |
730 | - | else ( | |
731 | - | then throw(("Get operation is blocked by admin. Status = " + toString( | |
732 | - | else $Tuple5(dF, | |
716 | + | else (ds == n)) | |
717 | + | then throw(("Get operation is blocked by admin. Status = " + toString(ds))) | |
718 | + | else $Tuple5(dE, dF, eY, dn, dI) | |
733 | 719 | } | |
734 | 720 | ||
735 | 721 | ||
736 | - | func | |
722 | + | func eZ (eW,dK,dQ) = if ((size(eW.payments) != 2)) | |
737 | 723 | then throw("exactly 2 payments are expected") | |
738 | 724 | else { | |
739 | - | let | |
740 | - | let | |
741 | - | let | |
742 | - | let | |
725 | + | let fa = value(eW.payments[0]) | |
726 | + | let fb = value(eW.payments[1]) | |
727 | + | let fc = dJ(toBase58String(eW.transactionId), dK, fa.amount, fa.assetId, fb.amount, fb.assetId, toString(eW.caller), false, dQ) | |
728 | + | let ds = parseIntValue(fc._8) | |
743 | 729 | if (if (if (bc()) | |
744 | 730 | then true | |
745 | - | else ( | |
731 | + | else (ds == l)) | |
746 | 732 | then true | |
747 | - | else ( | |
748 | - | then throw(("Put operation is blocked by admin. Status = " + toString( | |
749 | - | else | |
733 | + | else (ds == n)) | |
734 | + | then throw(("Put operation is blocked by admin. Status = " + toString(ds))) | |
735 | + | else fc | |
750 | 736 | } | |
751 | 737 | ||
752 | 738 | ||
753 | - | func | |
754 | - | let | |
755 | - | if (( | |
739 | + | func fd (ca) = { | |
740 | + | let fe = invoke(aV, "emit", [ca], nil) | |
741 | + | if ((fe == fe)) | |
756 | 742 | then { | |
757 | - | let | |
758 | - | let bX = | |
743 | + | let ff = { | |
744 | + | let bX = fe | |
759 | 745 | if ($isInstanceOf(bX, "Address")) | |
760 | 746 | then { | |
761 | - | let | |
762 | - | invoke( | |
747 | + | let fg = bX | |
748 | + | invoke(fg, "emit", [ca], nil) | |
763 | 749 | } | |
764 | 750 | else unit | |
765 | 751 | } | |
766 | - | if (( | |
752 | + | if ((ff == ff)) | |
767 | 753 | then ca | |
768 | 754 | else throw("Strict value is not equal to itself.") | |
769 | 755 | } | |
770 | 756 | else throw("Strict value is not equal to itself.") | |
771 | 757 | } | |
772 | 758 | ||
773 | 759 | ||
774 | - | func | |
775 | - | let | |
760 | + | func fh (ca,ai) = { | |
761 | + | let fi = if ((ai == 0)) | |
776 | 762 | then 0 | |
777 | 763 | else fraction(ca, ai, b) | |
778 | - | $Tuple2((ca - | |
764 | + | $Tuple2((ca - fi), fi) | |
779 | 765 | } | |
780 | 766 | ||
781 | 767 | ||
782 | - | func | |
783 | - | let | |
784 | - | let | |
785 | - | let | |
786 | - | let | |
768 | + | func fj (fk,fl,ab,ac) = { | |
769 | + | let fm = (ac == unit) | |
770 | + | let fn = bN(bj(br)) | |
771 | + | let fo = bN(bj(bs)) | |
772 | + | let fp = if ((fl == br)) | |
787 | 773 | then true | |
788 | - | else if (( | |
774 | + | else if ((fl == bs)) | |
789 | 775 | then false | |
790 | 776 | else aS("invalid asset") | |
791 | - | let | |
792 | - | then $Tuple2( | |
793 | - | else if ( | |
794 | - | then $Tuple2(( | |
795 | - | else $Tuple2( | |
796 | - | let | |
797 | - | let | |
798 | - | let | |
799 | - | then $Tuple2( | |
800 | - | else $Tuple2(0, | |
801 | - | let | |
802 | - | let | |
803 | - | let | |
804 | - | let | |
805 | - | let | |
806 | - | let | |
807 | - | let | |
808 | - | let | |
809 | - | let | |
810 | - | let | |
811 | - | let | |
812 | - | let | |
813 | - | then | |
814 | - | else | |
815 | - | let | |
816 | - | let | |
817 | - | let | |
777 | + | let fq = if (fm) | |
778 | + | then $Tuple2(fn, fo) | |
779 | + | else if (fp) | |
780 | + | then $Tuple2((fn - fk), fo) | |
781 | + | else $Tuple2(fn, (fo - fk)) | |
782 | + | let fr = fq._1 | |
783 | + | let fs = fq._2 | |
784 | + | let ft = if (fp) | |
785 | + | then $Tuple2(fk, 0) | |
786 | + | else $Tuple2(0, fk) | |
787 | + | let fu = ft._1 | |
788 | + | let fv = ft._2 | |
789 | + | let eM = fh(fu, aX)._1 | |
790 | + | let eN = fh(fv, aX)._1 | |
791 | + | let fw = fh(fk, aX) | |
792 | + | let fx = fw._1 | |
793 | + | let fi = fw._2 | |
794 | + | let fy = (fr + eM) | |
795 | + | let fz = (fs + eN) | |
796 | + | let fA = bQ(D(fz, bu), D(fy, bt)) | |
797 | + | let fB = H(fA, b) | |
798 | + | let fC = if (fp) | |
799 | + | then fr | |
800 | + | else fs | |
801 | + | let fD = toBigInt(fC) | |
802 | + | let fE = toBigInt(valueOrErrorMessage(assetInfo(bq), (("asset " + toBase58String(bq)) + " doesn't exist")).quantity) | |
803 | + | let fF = if ((fE > f)) | |
818 | 804 | then true | |
819 | 805 | else aS("initial deposit requires all coins") | |
820 | - | if (( | |
806 | + | if ((fF == fF)) | |
821 | 807 | then { | |
822 | - | let | |
823 | - | let | |
824 | - | let | |
808 | + | let fG = toBigInt(fx) | |
809 | + | let fH = max([0, toInt(((fE * (sqrtBigInt((d + ((fG * d) / fD)), 18, 18, DOWN) - d)) / d))]) | |
810 | + | let ep = if (fm) | |
825 | 811 | then nil | |
826 | - | else [IntegerEntry(W(), | |
827 | - | let | |
828 | - | let | |
829 | - | let | |
830 | - | let | |
831 | - | then $Tuple2( | |
832 | - | else $Tuple2( | |
833 | - | let ca = | |
834 | - | let | |
835 | - | let | |
836 | - | fraction(( | |
812 | + | else [IntegerEntry(W(), fB), IntegerEntry(X(height, lastBlock.timestamp), fB), StringEntry(aa(toString(value(ab)), toBase58String(value(ac))), by(fu, fv, fH, fB, 0, 0, height, lastBlock.timestamp, 0, 0))] | |
813 | + | let fI = bQ(D(fs, bu), D(fr, bt)) | |
814 | + | let fJ = H(fI, b) | |
815 | + | let fK = { | |
816 | + | let fL = if (fp) | |
817 | + | then $Tuple2(fu, fr) | |
818 | + | else $Tuple2(fv, fs) | |
819 | + | let ca = fL._1 | |
820 | + | let fM = fL._2 | |
821 | + | let fN = toInt(fraction(fE, toBigInt((ca / 2)), toBigInt(fM))) | |
822 | + | fraction((fH - fN), b, fN) | |
837 | 823 | } | |
838 | - | $Tuple5( | |
824 | + | $Tuple5(fH, ep, fi, fK, fp) | |
839 | 825 | } | |
840 | 826 | else throw("Strict value is not equal to itself.") | |
841 | 827 | } | |
842 | 828 | ||
843 | 829 | ||
844 | - | func | |
845 | - | let | |
846 | - | let | |
847 | - | let | |
848 | - | let | |
849 | - | let | |
830 | + | func fO (fP,fx,fl,ab,ac) = { | |
831 | + | let fm = (ac == unit) | |
832 | + | let dc = be() | |
833 | + | let dd = parseIntValue(dc[t]) | |
834 | + | let de = parseIntValue(dc[u]) | |
835 | + | let fQ = [if ((fl == bq)) | |
850 | 836 | then true | |
851 | 837 | else aS("invalid lp asset")] | |
852 | - | if (( | |
838 | + | if ((fQ == fQ)) | |
853 | 839 | then { | |
854 | - | let | |
840 | + | let fR = if ((fP == br)) | |
855 | 841 | then true | |
856 | - | else if (( | |
842 | + | else if ((fP == bs)) | |
857 | 843 | then false | |
858 | 844 | else aS("invalid asset") | |
859 | - | let | |
845 | + | let fS = if (fR) | |
860 | 846 | then toBigInt(bN(bj(br))) | |
861 | 847 | else toBigInt(bN(bj(bs))) | |
862 | - | let fV = if (fT) | |
863 | - | then de | |
864 | - | else df | |
865 | - | let fW = bN(bj(br)) | |
866 | - | let fX = bN(bj(bs)) | |
867 | - | let fY = if (fT) | |
868 | - | then fW | |
869 | - | else fX | |
870 | - | let fZ = toBigInt(fY) | |
871 | - | let fG = toBigInt(valueOrErrorMessage(assetInfo(bq), (("asset " + toBase58String(bq)) + " doesn't exist")).quantity) | |
872 | - | let ga = toBigInt(fz) | |
873 | - | let gb = max([0, toInt(((fU * (d - pow((d - ((ga * d) / fG)), 18, h, 0, 18, DOWN))) / d))]) | |
874 | - | let gc = fj(gb, aZ) | |
848 | + | let fT = if (fR) | |
849 | + | then dd | |
850 | + | else de | |
851 | + | let fU = bN(bj(br)) | |
852 | + | let fV = bN(bj(bs)) | |
853 | + | let fW = if (fR) | |
854 | + | then fU | |
855 | + | else fV | |
856 | + | let fX = toBigInt(fW) | |
857 | + | let fE = toBigInt(valueOrErrorMessage(assetInfo(bq), (("asset " + toBase58String(bq)) + " doesn't exist")).quantity) | |
858 | + | let fY = toBigInt(fx) | |
859 | + | let fZ = max([0, toInt(((fS * (d - pow((d - ((fY * d) / fE)), 18, h, 0, 18, DOWN))) / d))]) | |
860 | + | let ga = fh(fZ, aZ) | |
861 | + | let gb = ga._1 | |
862 | + | let fi = ga._2 | |
863 | + | let gc = if (fR) | |
864 | + | then $Tuple4(gb, 0, (fU - fZ), fV) | |
865 | + | else $Tuple4(0, gb, fU, (fV - fZ)) | |
875 | 866 | let gd = gc._1 | |
876 | - | let fk = gc._2 | |
877 | - | let ge = if (fT) | |
878 | - | then $Tuple4(gd, 0, (fW - gb), fX) | |
879 | - | else $Tuple4(0, gd, fW, (fX - gb)) | |
880 | - | let gf = ge._1 | |
881 | - | let gg = ge._2 | |
882 | - | let gh = ge._3 | |
883 | - | let gi = ge._4 | |
884 | - | let fC = bQ(D(gi, bu), D(gh, bt)) | |
885 | - | let fD = H(fC, b) | |
886 | - | let er = if (fo) | |
867 | + | let ge = gc._2 | |
868 | + | let gf = gc._3 | |
869 | + | let gg = gc._4 | |
870 | + | let fA = bQ(D(gg, bu), D(gf, bt)) | |
871 | + | let fB = H(fA, b) | |
872 | + | let ep = if (fm) | |
887 | 873 | then nil | |
888 | - | else [StringEntry(ad(toString(value(ab)), toBase58String(value(ac))), bJ( | |
889 | - | let | |
890 | - | let | |
891 | - | let | |
892 | - | let | |
893 | - | fraction(( | |
874 | + | else [StringEntry(ad(toString(value(ab)), toBase58String(value(ac))), bJ(gd, ge, fx, fB, height, lastBlock.timestamp)), IntegerEntry(W(), fB), IntegerEntry(X(height, lastBlock.timestamp), fB)] | |
875 | + | let fI = bQ(D(fV, bu), D(fU, bt)) | |
876 | + | let fJ = H(fI, b) | |
877 | + | let fK = { | |
878 | + | let gh = (toInt(fraction(fS, fY, fE)) * 2) | |
879 | + | fraction((gb - gh), b, gh) | |
894 | 880 | } | |
895 | - | $Tuple5( | |
881 | + | $Tuple5(gb, ep, fi, fK, fR) | |
896 | 882 | } | |
897 | 883 | else throw("Strict value is not equal to itself.") | |
898 | 884 | } | |
899 | 885 | ||
900 | 886 | ||
901 | - | func | |
887 | + | func gi () = { | |
902 | 888 | let bX = getString(U()) | |
903 | 889 | if ($isInstanceOf(bX, "String")) | |
904 | 890 | then { | |
905 | - | let | |
906 | - | fromBase58String( | |
891 | + | let gj = bX | |
892 | + | fromBase58String(gj) | |
907 | 893 | } | |
908 | 894 | else if ($isInstanceOf(bX, "Unit")) | |
909 | 895 | then unit | |
910 | 896 | else throw("Match error") | |
911 | 897 | } | |
912 | 898 | ||
913 | 899 | ||
914 | - | func | |
900 | + | func gk () = { | |
915 | 901 | let bX = getString(V()) | |
916 | 902 | if ($isInstanceOf(bX, "String")) | |
917 | 903 | then { | |
918 | - | let | |
919 | - | fromBase58String( | |
904 | + | let gj = bX | |
905 | + | fromBase58String(gj) | |
920 | 906 | } | |
921 | 907 | else if ($isInstanceOf(bX, "Unit")) | |
922 | 908 | then unit | |
923 | 909 | else throw("Match error") | |
924 | 910 | } | |
925 | 911 | ||
926 | 912 | ||
927 | - | func | |
928 | - | let bX = | |
913 | + | func gl (eW) = { | |
914 | + | let bX = gi() | |
929 | 915 | if ($isInstanceOf(bX, "ByteVector")) | |
930 | 916 | then { | |
931 | - | let | |
932 | - | ( | |
917 | + | let gm = bX | |
918 | + | (eW.callerPublicKey == gm) | |
933 | 919 | } | |
934 | 920 | else if ($isInstanceOf(bX, "Unit")) | |
935 | - | then ( | |
921 | + | then (eW.caller == this) | |
936 | 922 | else throw("Match error") | |
937 | 923 | } | |
938 | 924 | ||
939 | 925 | ||
940 | - | func | |
941 | - | let | |
942 | - | let bX = | |
926 | + | func gn (eW) = { | |
927 | + | let go = throw("Permission denied") | |
928 | + | let bX = gi() | |
943 | 929 | if ($isInstanceOf(bX, "ByteVector")) | |
944 | 930 | then { | |
945 | - | let | |
946 | - | if (( | |
931 | + | let gm = bX | |
932 | + | if ((eW.callerPublicKey == gm)) | |
947 | 933 | then true | |
948 | - | else | |
934 | + | else go | |
949 | 935 | } | |
950 | 936 | else if ($isInstanceOf(bX, "Unit")) | |
951 | - | then if (( | |
937 | + | then if ((eW.caller == this)) | |
952 | 938 | then true | |
953 | - | else | |
939 | + | else go | |
954 | 940 | else throw("Match error") | |
955 | 941 | } | |
956 | 942 | ||
957 | 943 | ||
958 | - | @Callable( | |
944 | + | @Callable(eW) | |
959 | 945 | func rebalance () = (cG(aO(this, ae())) ++ cG(aO(this, af()))) | |
960 | 946 | ||
961 | 947 | ||
962 | 948 | ||
963 | - | @Callable( | |
964 | - | func calculateAmountOutForSwapREADONLY (gr | |
965 | - | let | |
949 | + | @Callable(eW) | |
950 | + | func calculateAmountOutForSwapREADONLY (gp,gq,gr) = { | |
951 | + | let gs = if ((gq == false)) | |
966 | 952 | then { | |
967 | - | let | |
968 | - | let | |
969 | - | $Tuple2( | |
953 | + | let gt = aO(this, af()) | |
954 | + | let gu = aO(this, ae()) | |
955 | + | $Tuple2(gt, gu) | |
970 | 956 | } | |
971 | 957 | else { | |
972 | - | let | |
973 | - | let | |
974 | - | $Tuple2( | |
958 | + | let gt = aO(this, ae()) | |
959 | + | let gu = aO(this, af()) | |
960 | + | $Tuple2(gt, gu) | |
975 | 961 | } | |
976 | - | let | |
977 | - | let | |
978 | - | let | |
979 | - | let | |
980 | - | let | |
981 | - | let | |
982 | - | let | |
983 | - | let | |
962 | + | let gt = gs._1 | |
963 | + | let gu = gs._2 | |
964 | + | let gv = bN(gu) | |
965 | + | let gw = bN(gt) | |
966 | + | let gx = fraction(gw, gp, (gv + gp)) | |
967 | + | let gy = (toBigInt(gv) * toBigInt(gw)) | |
968 | + | let gz = (((toBigInt(bN(gu)) + toBigInt(gp)) + toBigInt(gr)) * (toBigInt(bN(gt)) - toBigInt(gx))) | |
969 | + | let gA = if ((gz >= gy)) | |
984 | 970 | then true | |
985 | 971 | else throw("new K is fewer error") | |
986 | - | if (( | |
987 | - | then $Tuple2(nil, | |
972 | + | if ((gA == gA)) | |
973 | + | then $Tuple2(nil, gx) | |
988 | 974 | else throw("Strict value is not equal to itself.") | |
989 | 975 | } | |
990 | 976 | ||
991 | 977 | ||
992 | 978 | ||
993 | - | @Callable( | |
994 | - | func calculateAmountOutForSwapAndSendTokens (gr | |
995 | - | let | |
979 | + | @Callable(eW) | |
980 | + | func calculateAmountOutForSwapAndSendTokens (gp,gq,gB,gC,gr) = { | |
981 | + | let gD = { | |
996 | 982 | let aY = invoke(aV, "getSwapContractREADONLY", nil, nil) | |
997 | 983 | if ($isInstanceOf(aY, "String")) | |
998 | 984 | then aY | |
999 | 985 | else throw(($getType(aY) + " couldn't be cast to String")) | |
1000 | 986 | } | |
1001 | - | let | |
987 | + | let fQ = [if ((value(eW.payments[0]).amount >= gp)) | |
1002 | 988 | then true | |
1003 | - | else aS("Wrong amount"), if (( | |
989 | + | else aS("Wrong amount"), if ((eW.caller == addressFromStringValue(gD))) | |
1004 | 990 | then true | |
1005 | 991 | else aS("Permission denied")] | |
1006 | - | if (( | |
992 | + | if ((fQ == fQ)) | |
1007 | 993 | then { | |
1008 | - | let | |
1009 | - | let | |
1010 | - | let | |
994 | + | let eX = value(eW.payments[0]) | |
995 | + | let gu = bj(eX.assetId) | |
996 | + | let gt = if ((gq == false)) | |
1011 | 997 | then aO(this, af()) | |
1012 | 998 | else aO(this, ae()) | |
1013 | - | let | |
1014 | - | let | |
1015 | - | let | |
1016 | - | let | |
1017 | - | let | |
1018 | - | let | |
999 | + | let gv = (bN(gu) - value(eW.payments[0]).amount) | |
1000 | + | let gw = bN(gt) | |
1001 | + | let gx = fraction(gw, gp, (gv + gp)) | |
1002 | + | let gy = (toBigInt(gv) * toBigInt(gw)) | |
1003 | + | let gz = ((toBigInt(bN(gu)) + toBigInt(gr)) * (toBigInt(bN(gt)) - toBigInt(gx))) | |
1004 | + | let gA = if ((gz >= gy)) | |
1019 | 1005 | then true | |
1020 | 1006 | else throw("new K is fewer error") | |
1021 | - | if (( | |
1007 | + | if ((gA == gA)) | |
1022 | 1008 | then { | |
1023 | - | let | |
1009 | + | let gE = if ((gx >= gB)) | |
1024 | 1010 | then true | |
1025 | 1011 | else throw("Exchange result is fewer coins than expected") | |
1026 | - | if (( | |
1012 | + | if ((gE == gE)) | |
1027 | 1013 | then { | |
1028 | - | let | |
1029 | - | let bX = cu( | |
1014 | + | let gF = { | |
1015 | + | let bX = cu(gt) | |
1030 | 1016 | if ($isInstanceOf(bX, "(Boolean, Int, Int, String, String, Int, String)")) | |
1031 | 1017 | then { | |
1032 | 1018 | let cH = bX | |
1033 | 1019 | cH | |
1034 | 1020 | } | |
1035 | 1021 | else throw("error lease config") | |
1036 | 1022 | } | |
1037 | - | let gI = cQ(gv, gz) | |
1038 | - | if ((gI == gI)) | |
1039 | - | then { | |
1040 | - | let dJ = invoke(this, "rebalance", nil, nil) | |
1041 | - | if ((dJ == dJ)) | |
1042 | - | then $Tuple2((gI ++ [ScriptTransfer(addressFromStringValue(gE), gz, bh(gv))]), gz) | |
1043 | - | else throw("Strict value is not equal to itself.") | |
1044 | - | } | |
1023 | + | let gG = cO(gt, gx) | |
1024 | + | if ((gG == gG)) | |
1025 | + | then $Tuple2((gG ++ [ScriptTransfer(addressFromStringValue(gC), gx, bh(gt))]), gx) | |
1045 | 1026 | else throw("Strict value is not equal to itself.") | |
1046 | 1027 | } | |
1047 | 1028 | else throw("Strict value is not equal to itself.") | |
1048 | 1029 | } | |
1049 | 1030 | else throw("Strict value is not equal to itself.") | |
1050 | 1031 | } | |
1051 | 1032 | else throw("Strict value is not equal to itself.") | |
1052 | 1033 | } | |
1053 | 1034 | ||
1054 | 1035 | ||
1055 | 1036 | ||
1056 | - | @Callable( | |
1057 | - | func setManager ( | |
1058 | - | let | |
1059 | - | if (( | |
1037 | + | @Callable(eW) | |
1038 | + | func setManager (gH) = { | |
1039 | + | let gI = gn(eW) | |
1040 | + | if ((gI == gI)) | |
1060 | 1041 | then { | |
1061 | - | let | |
1062 | - | if (( | |
1063 | - | then [StringEntry(V(), | |
1042 | + | let gJ = fromBase58String(gH) | |
1043 | + | if ((gJ == gJ)) | |
1044 | + | then [StringEntry(V(), gH)] | |
1064 | 1045 | else throw("Strict value is not equal to itself.") | |
1065 | 1046 | } | |
1066 | 1047 | else throw("Strict value is not equal to itself.") | |
1067 | 1048 | } | |
1068 | 1049 | ||
1069 | 1050 | ||
1070 | 1051 | ||
1071 | - | @Callable( | |
1052 | + | @Callable(eW) | |
1072 | 1053 | func confirmManager () = { | |
1073 | - | let | |
1074 | - | let | |
1054 | + | let gK = gk() | |
1055 | + | let gL = if (isDefined(gK)) | |
1075 | 1056 | then true | |
1076 | 1057 | else throw("No pending manager") | |
1077 | - | if (( | |
1058 | + | if ((gL == gL)) | |
1078 | 1059 | then { | |
1079 | - | let | |
1060 | + | let gM = if ((eW.callerPublicKey == value(gK))) | |
1080 | 1061 | then true | |
1081 | 1062 | else throw("You are not pending manager") | |
1082 | - | if (( | |
1083 | - | then [StringEntry(U(), toBase58String(value( | |
1063 | + | if ((gM == gM)) | |
1064 | + | then [StringEntry(U(), toBase58String(value(gK))), DeleteEntry(V())] | |
1084 | 1065 | else throw("Strict value is not equal to itself.") | |
1085 | 1066 | } | |
1086 | 1067 | else throw("Strict value is not equal to itself.") | |
1087 | 1068 | } | |
1088 | 1069 | ||
1089 | 1070 | ||
1090 | 1071 | ||
1091 | - | @Callable( | |
1092 | - | func put ( | |
1072 | + | @Callable(eW) | |
1073 | + | func put (dK,gN) = if ((0 > dK)) | |
1093 | 1074 | then throw("Invalid slippageTolerance passed") | |
1094 | 1075 | else { | |
1095 | - | let | |
1096 | - | let | |
1097 | - | let | |
1098 | - | let | |
1099 | - | let | |
1100 | - | let | |
1101 | - | let | |
1102 | - | let | |
1103 | - | let | |
1104 | - | let | |
1105 | - | let | |
1106 | - | if (( | |
1076 | + | let fc = eZ(eW, dK, true) | |
1077 | + | let em = fc._2 | |
1078 | + | let dp = fc._7 | |
1079 | + | let dI = fc._9 | |
1080 | + | let en = fc._10 | |
1081 | + | let eo = fc._11 | |
1082 | + | let gO = fc._12 | |
1083 | + | let gP = fc._13 | |
1084 | + | let fa = toBigInt(value(eW.payments[0]).amount) | |
1085 | + | let fb = toBigInt(value(eW.payments[1]).amount) | |
1086 | + | let eD = ew(fa, fb, toBigInt(0)) | |
1087 | + | if ((eD == eD)) | |
1107 | 1088 | then { | |
1108 | - | let | |
1109 | - | if (( | |
1089 | + | let fe = invoke(aV, "emit", [em], nil) | |
1090 | + | if ((fe == fe)) | |
1110 | 1091 | then { | |
1111 | - | let | |
1112 | - | let bX = | |
1092 | + | let ff = { | |
1093 | + | let bX = fe | |
1113 | 1094 | if ($isInstanceOf(bX, "Address")) | |
1114 | 1095 | then { | |
1115 | - | let | |
1116 | - | invoke( | |
1096 | + | let fg = bX | |
1097 | + | invoke(fg, "emit", [em], nil) | |
1117 | 1098 | } | |
1118 | 1099 | else unit | |
1119 | 1100 | } | |
1120 | - | if (( | |
1101 | + | if ((ff == ff)) | |
1121 | 1102 | then { | |
1122 | - | let | |
1123 | - | then invoke(bx, "put", nil, [AttachedPayment( | |
1103 | + | let gQ = if ((en > 0)) | |
1104 | + | then invoke(bx, "put", nil, [AttachedPayment(gO, en)]) | |
1124 | 1105 | else nil | |
1125 | - | if (( | |
1106 | + | if ((gQ == gQ)) | |
1126 | 1107 | then { | |
1127 | - | let | |
1128 | - | then invoke(bx, "put", nil, [AttachedPayment( | |
1108 | + | let gR = if ((eo > 0)) | |
1109 | + | then invoke(bx, "put", nil, [AttachedPayment(gP, eo)]) | |
1129 | 1110 | else nil | |
1130 | - | if (( | |
1111 | + | if ((gR == gR)) | |
1131 | 1112 | then { | |
1132 | - | let | |
1113 | + | let gS = if (gN) | |
1133 | 1114 | then { | |
1134 | - | let | |
1135 | - | if (( | |
1115 | + | let gT = invoke(bw, "stake", nil, [AttachedPayment(dp, em)]) | |
1116 | + | if ((gT == gT)) | |
1136 | 1117 | then nil | |
1137 | 1118 | else throw("Strict value is not equal to itself.") | |
1138 | 1119 | } | |
1139 | - | else [ScriptTransfer( | |
1140 | - | let | |
1141 | - | if (( | |
1120 | + | else [ScriptTransfer(eW.caller, em, dp)] | |
1121 | + | let gU = eE(0, 0, 0) | |
1122 | + | if ((gU == gU)) | |
1142 | 1123 | then { | |
1143 | - | let | |
1144 | - | let | |
1145 | - | let | |
1146 | - | if (( | |
1124 | + | let ev = gU._2 | |
1125 | + | let gV = gU._1 | |
1126 | + | let gW = eI(eD, ev) | |
1127 | + | if ((gW == gW)) | |
1147 | 1128 | then { | |
1148 | - | let | |
1149 | - | if (( | |
1150 | - | then (( | |
1129 | + | let gX = invoke(this, "rebalance", nil, nil) | |
1130 | + | if ((gX == gX)) | |
1131 | + | then ((dI ++ gS) ++ gV) | |
1151 | 1132 | else throw("Strict value is not equal to itself.") | |
1152 | 1133 | } | |
1153 | 1134 | else throw("Strict value is not equal to itself.") | |
1154 | 1135 | } | |
1155 | 1136 | else throw("Strict value is not equal to itself.") | |
1156 | 1137 | } | |
1157 | 1138 | else throw("Strict value is not equal to itself.") | |
1158 | 1139 | } | |
1159 | 1140 | else throw("Strict value is not equal to itself.") | |
1160 | 1141 | } | |
1161 | 1142 | else throw("Strict value is not equal to itself.") | |
1162 | 1143 | } | |
1163 | 1144 | else throw("Strict value is not equal to itself.") | |
1164 | 1145 | } | |
1165 | 1146 | else throw("Strict value is not equal to itself.") | |
1166 | 1147 | } | |
1167 | 1148 | ||
1168 | 1149 | ||
1169 | 1150 | ||
1170 | - | @Callable( | |
1171 | - | func putForFree ( | |
1151 | + | @Callable(eW) | |
1152 | + | func putForFree (gY) = if ((0 > gY)) | |
1172 | 1153 | then throw("Invalid value passed") | |
1173 | 1154 | else { | |
1174 | - | let | |
1175 | - | let | |
1176 | - | let | |
1177 | - | let | |
1178 | - | let | |
1179 | - | if (( | |
1155 | + | let fc = eZ(eW, gY, false) | |
1156 | + | let dI = fc._9 | |
1157 | + | let fa = toBigInt(value(eW.payments[0]).amount) | |
1158 | + | let fb = toBigInt(value(eW.payments[1]).amount) | |
1159 | + | let eD = ew(fa, fb, toBigInt(0)) | |
1160 | + | if ((eD == eD)) | |
1180 | 1161 | then { | |
1181 | - | let | |
1182 | - | let | |
1183 | - | let | |
1184 | - | let | |
1185 | - | if (( | |
1186 | - | then ( | |
1162 | + | let gZ = eE(0, 0, 0) | |
1163 | + | let gV = gZ._1 | |
1164 | + | let ev = gZ._2 | |
1165 | + | let gW = eI(eD, ev) | |
1166 | + | if ((gW == gW)) | |
1167 | + | then (dI ++ gV) | |
1187 | 1168 | else throw("Strict value is not equal to itself.") | |
1188 | 1169 | } | |
1189 | 1170 | else throw("Strict value is not equal to itself.") | |
1190 | 1171 | } | |
1191 | 1172 | ||
1192 | 1173 | ||
1193 | 1174 | ||
1194 | - | @Callable( | |
1195 | - | func putOneTkn (hb | |
1196 | - | let | |
1175 | + | @Callable(eW) | |
1176 | + | func putOneTkn (ha,hb) = { | |
1177 | + | let hc = { | |
1197 | 1178 | let aY = invoke(aV, "isPoolOneTokenOperationsDisabledREADONLY", [toString(this)], nil) | |
1198 | 1179 | if ($isInstanceOf(aY, "Boolean")) | |
1199 | 1180 | then aY | |
1200 | 1181 | else throw(($getType(aY) + " couldn't be cast to Boolean")) | |
1201 | 1182 | } | |
1202 | - | let | |
1183 | + | let hd = if (if (if (bc()) | |
1203 | 1184 | then true | |
1204 | 1185 | else (bp == l)) | |
1205 | 1186 | then true | |
1206 | 1187 | else (bp == n)) | |
1207 | 1188 | then true | |
1208 | - | else | |
1209 | - | let | |
1189 | + | else hc | |
1190 | + | let fQ = [if (if (!(hd)) | |
1210 | 1191 | then true | |
1211 | - | else | |
1192 | + | else gl(eW)) | |
1212 | 1193 | then true | |
1213 | - | else aS("put operation is blocked by admin"), if ((size( | |
1194 | + | else aS("put operation is blocked by admin"), if ((size(eW.payments) == 1)) | |
1214 | 1195 | then true | |
1215 | 1196 | else aS("exactly 1 payment are expected")] | |
1216 | - | if (( | |
1197 | + | if ((fQ == fQ)) | |
1217 | 1198 | then { | |
1218 | - | let | |
1219 | - | let | |
1220 | - | let | |
1221 | - | let | |
1222 | - | then | |
1223 | - | else if (( | |
1224 | - | then | |
1199 | + | let he = eW.payments[0] | |
1200 | + | let fl = he.assetId | |
1201 | + | let fk = he.amount | |
1202 | + | let eD = if ((fl == br)) | |
1203 | + | then ew(toBigInt(fk), toBigInt(0), toBigInt(0)) | |
1204 | + | else if ((fl == bs)) | |
1205 | + | then ew(toBigInt(0), toBigInt(fk), toBigInt(0)) | |
1225 | 1206 | else aS("payment asset is not supported") | |
1226 | - | if (( | |
1207 | + | if ((eD == eD)) | |
1227 | 1208 | then { | |
1228 | - | let ab = | |
1229 | - | let ac = | |
1230 | - | let | |
1231 | - | if (( | |
1209 | + | let ab = eW.caller | |
1210 | + | let ac = eW.transactionId | |
1211 | + | let hf = fj(fk, fl, ab, ac) | |
1212 | + | if ((hf == hf)) | |
1232 | 1213 | then { | |
1233 | - | let | |
1234 | - | let | |
1235 | - | let | |
1236 | - | let | |
1237 | - | let | |
1238 | - | let | |
1239 | - | then ( | |
1214 | + | let fp = hf._5 | |
1215 | + | let hg = hf._4 | |
1216 | + | let fi = hf._3 | |
1217 | + | let ep = hf._2 | |
1218 | + | let hh = hf._1 | |
1219 | + | let hi = if (if ((ha > 0)) | |
1220 | + | then (ha > hh) | |
1240 | 1221 | else false) | |
1241 | - | then aS(makeString(["amount to receive is less than ", toString( | |
1242 | - | else | |
1243 | - | let | |
1244 | - | if (( | |
1222 | + | then aS(makeString(["amount to receive is less than ", toString(ha)], "")) | |
1223 | + | else hh | |
1224 | + | let fe = fd(hi) | |
1225 | + | if ((fe == fe)) | |
1245 | 1226 | then { | |
1246 | - | let | |
1227 | + | let gS = if (hb) | |
1247 | 1228 | then { | |
1248 | - | let | |
1249 | - | if (( | |
1229 | + | let hj = invoke(bw, "stake", nil, [AttachedPayment(bq, hi)]) | |
1230 | + | if ((hj == hj)) | |
1250 | 1231 | then nil | |
1251 | 1232 | else throw("Strict value is not equal to itself.") | |
1252 | 1233 | } | |
1253 | - | else [ScriptTransfer( | |
1254 | - | let | |
1255 | - | then [ScriptTransfer(aW, | |
1234 | + | else [ScriptTransfer(eW.caller, hi, bq)] | |
1235 | + | let hk = if ((fi > 0)) | |
1236 | + | then [ScriptTransfer(aW, fi, fl)] | |
1256 | 1237 | else nil | |
1257 | - | let | |
1238 | + | let hl = if ((this == aW)) | |
1258 | 1239 | then $Tuple2(0, 0) | |
1259 | - | else if ( | |
1260 | - | then $Tuple2(-( | |
1261 | - | else $Tuple2(0, -( | |
1262 | - | let | |
1263 | - | let | |
1264 | - | let | |
1265 | - | let | |
1266 | - | let | |
1267 | - | let | |
1268 | - | let | |
1269 | - | if (( | |
1240 | + | else if (fp) | |
1241 | + | then $Tuple2(-(fi), 0) | |
1242 | + | else $Tuple2(0, -(fi)) | |
1243 | + | let eF = hl._1 | |
1244 | + | let eG = hl._2 | |
1245 | + | let hm = eE(eF, eG, 0) | |
1246 | + | let gV = hm._1 | |
1247 | + | let ev = hm._2 | |
1248 | + | let eP = value(getString(aj)) | |
1249 | + | let gW = eI(eD, ev) | |
1250 | + | if ((gW == gW)) | |
1270 | 1251 | then { | |
1271 | - | let | |
1272 | - | if (( | |
1273 | - | then $Tuple2(((( | |
1252 | + | let gX = invoke(this, "rebalance", nil, nil) | |
1253 | + | if ((gX == gX)) | |
1254 | + | then $Tuple2((((ep ++ gS) ++ hk) ++ gV), hi) | |
1274 | 1255 | else throw("Strict value is not equal to itself.") | |
1275 | 1256 | } | |
1276 | 1257 | else throw("Strict value is not equal to itself.") | |
1277 | 1258 | } | |
1278 | 1259 | else throw("Strict value is not equal to itself.") | |
1279 | 1260 | } | |
1280 | 1261 | else throw("Strict value is not equal to itself.") | |
1281 | 1262 | } | |
1282 | 1263 | else throw("Strict value is not equal to itself.") | |
1283 | 1264 | } | |
1284 | 1265 | else throw("Strict value is not equal to itself.") | |
1285 | 1266 | } | |
1286 | 1267 | ||
1287 | 1268 | ||
1288 | 1269 | ||
1289 | - | @Callable( | |
1290 | - | func putOneTknREADONLY ( | |
1291 | - | let | |
1292 | - | let | |
1293 | - | let | |
1294 | - | let | |
1295 | - | let | |
1296 | - | let | |
1297 | - | $Tuple2(nil, $Tuple3( | |
1270 | + | @Callable(eW) | |
1271 | + | func putOneTknREADONLY (fl,fk) = { | |
1272 | + | let hn = fj(fk, bh(fl), unit, unit) | |
1273 | + | let hh = hn._1 | |
1274 | + | let ep = hn._2 | |
1275 | + | let fi = hn._3 | |
1276 | + | let hg = hn._4 | |
1277 | + | let fp = hn._5 | |
1278 | + | $Tuple2(nil, $Tuple3(hh, fi, hg)) | |
1298 | 1279 | } | |
1299 | 1280 | ||
1300 | 1281 | ||
1301 | 1282 | ||
1302 | - | @Callable( | |
1303 | - | func getOneTkn ( | |
1304 | - | let | |
1283 | + | @Callable(eW) | |
1284 | + | func getOneTkn (ho,ha) = { | |
1285 | + | let hc = { | |
1305 | 1286 | let aY = invoke(aV, "isPoolOneTokenOperationsDisabledREADONLY", [toString(this)], nil) | |
1306 | 1287 | if ($isInstanceOf(aY, "Boolean")) | |
1307 | 1288 | then aY | |
1308 | 1289 | else throw(($getType(aY) + " couldn't be cast to Boolean")) | |
1309 | 1290 | } | |
1310 | - | let | |
1291 | + | let hp = if (if (bc()) | |
1311 | 1292 | then true | |
1312 | 1293 | else (bp == n)) | |
1313 | 1294 | then true | |
1314 | - | else | |
1315 | - | let | |
1295 | + | else hc | |
1296 | + | let fQ = [if (if (!(hp)) | |
1316 | 1297 | then true | |
1317 | - | else | |
1298 | + | else gl(eW)) | |
1318 | 1299 | then true | |
1319 | - | else aS("get operation is blocked by admin"), if ((size( | |
1300 | + | else aS("get operation is blocked by admin"), if ((size(eW.payments) == 1)) | |
1320 | 1301 | then true | |
1321 | 1302 | else aS("exactly 1 payment are expected")] | |
1322 | - | if (( | |
1303 | + | if ((fQ == fQ)) | |
1323 | 1304 | then { | |
1324 | - | let | |
1325 | - | let | |
1326 | - | let | |
1327 | - | let | |
1328 | - | let | |
1329 | - | if (( | |
1305 | + | let fP = bh(ho) | |
1306 | + | let he = eW.payments[0] | |
1307 | + | let fl = he.assetId | |
1308 | + | let fx = he.amount | |
1309 | + | let eD = ew(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1310 | + | if ((eD == eD)) | |
1330 | 1311 | then { | |
1331 | - | let ab = | |
1332 | - | let ac = | |
1333 | - | let | |
1334 | - | if (( | |
1312 | + | let ab = eW.caller | |
1313 | + | let ac = eW.transactionId | |
1314 | + | let hq = fO(fP, fx, fl, ab, ac) | |
1315 | + | if ((hq == hq)) | |
1335 | 1316 | then { | |
1336 | - | let | |
1337 | - | let | |
1338 | - | let | |
1339 | - | let | |
1340 | - | let | |
1341 | - | let ca = if (if (( | |
1342 | - | then ( | |
1317 | + | let fR = hq._5 | |
1318 | + | let hg = hq._4 | |
1319 | + | let fi = hq._3 | |
1320 | + | let ep = hq._2 | |
1321 | + | let hr = hq._1 | |
1322 | + | let ca = if (if ((ha > 0)) | |
1323 | + | then (ha > hr) | |
1343 | 1324 | else false) | |
1344 | - | then aS(makeString(["amount to receive is less than ", toString( | |
1345 | - | else | |
1346 | - | let | |
1347 | - | let bX = cu( | |
1325 | + | then aS(makeString(["amount to receive is less than ", toString(ha)], "")) | |
1326 | + | else hr | |
1327 | + | let gF = { | |
1328 | + | let bX = cu(ho) | |
1348 | 1329 | if ($isInstanceOf(bX, "(Boolean, Int, Int, String, String, Int, String)")) | |
1349 | 1330 | then { | |
1350 | 1331 | let cH = bX | |
1351 | 1332 | cH | |
1352 | 1333 | } | |
1353 | 1334 | else throw("error lease config") | |
1354 | 1335 | } | |
1355 | - | let | |
1356 | - | if (( | |
1336 | + | let hs = invoke(aV, "burn", [fx], [AttachedPayment(fl, fx)]) | |
1337 | + | if ((hs == hs)) | |
1357 | 1338 | then { | |
1358 | - | let | |
1359 | - | if (( | |
1339 | + | let gG = cO(ho, ca) | |
1340 | + | if ((gG == gG)) | |
1360 | 1341 | then { | |
1361 | - | let | |
1362 | - | let | |
1363 | - | then [ScriptTransfer(aW, | |
1342 | + | let ht = [ScriptTransfer(ab, ca, fP)] | |
1343 | + | let hk = if ((fi > 0)) | |
1344 | + | then [ScriptTransfer(aW, fi, fP)] | |
1364 | 1345 | else nil | |
1365 | - | let | |
1366 | - | let | |
1346 | + | let hu = { | |
1347 | + | let hv = if ((this == aW)) | |
1367 | 1348 | then 0 | |
1368 | - | else | |
1369 | - | if ( | |
1370 | - | then $Tuple2(-((ca + | |
1371 | - | else $Tuple2(0, -((ca + | |
1349 | + | else fi | |
1350 | + | if (fR) | |
1351 | + | then $Tuple2(-((ca + hv)), 0) | |
1352 | + | else $Tuple2(0, -((ca + hv))) | |
1372 | 1353 | } | |
1373 | - | let eH = hv._1 | |
1374 | - | let eI = hv._2 | |
1375 | - | let hx = eG(eH, eI, 0) | |
1376 | - | let gX = hx._1 | |
1377 | - | let ex = hx._2 | |
1378 | - | let gY = eK(eF, ex) | |
1379 | - | if ((gY == gY)) | |
1354 | + | let eF = hu._1 | |
1355 | + | let eG = hu._2 | |
1356 | + | let hw = eE(eF, eG, 0) | |
1357 | + | let gV = hw._1 | |
1358 | + | let ev = hw._2 | |
1359 | + | let gW = eI(eD, ev) | |
1360 | + | if ((gW == gW)) | |
1361 | + | then $Tuple2(((((ep ++ gG) ++ ht) ++ hk) ++ gV), ca) | |
1362 | + | else throw("Strict value is not equal to itself.") | |
1363 | + | } | |
1364 | + | else throw("Strict value is not equal to itself.") | |
1365 | + | } | |
1366 | + | else throw("Strict value is not equal to itself.") | |
1367 | + | } | |
1368 | + | else throw("Strict value is not equal to itself.") | |
1369 | + | } | |
1370 | + | else throw("Strict value is not equal to itself.") | |
1371 | + | } | |
1372 | + | else throw("Strict value is not equal to itself.") | |
1373 | + | } | |
1374 | + | ||
1375 | + | ||
1376 | + | ||
1377 | + | @Callable(eW) | |
1378 | + | func getOneTknREADONLY (fP,fx) = { | |
1379 | + | let hx = fO(bh(fP), fx, bq, unit, unit) | |
1380 | + | let hr = hx._1 | |
1381 | + | let ep = hx._2 | |
1382 | + | let fi = hx._3 | |
1383 | + | let hg = hx._4 | |
1384 | + | let fR = hx._5 | |
1385 | + | $Tuple2(nil, $Tuple3(hr, fi, hg)) | |
1386 | + | } | |
1387 | + | ||
1388 | + | ||
1389 | + | ||
1390 | + | @Callable(eW) | |
1391 | + | func unstakeAndGetOneTkn (hy,ho,ha) = { | |
1392 | + | let hc = { | |
1393 | + | let aY = invoke(aV, "isPoolOneTokenOperationsDisabledREADONLY", [toString(this)], nil) | |
1394 | + | if ($isInstanceOf(aY, "Boolean")) | |
1395 | + | then aY | |
1396 | + | else throw(($getType(aY) + " couldn't be cast to Boolean")) | |
1397 | + | } | |
1398 | + | let hp = if (if (bc()) | |
1399 | + | then true | |
1400 | + | else (bp == n)) | |
1401 | + | then true | |
1402 | + | else hc | |
1403 | + | let fQ = [if (if (!(hp)) | |
1404 | + | then true | |
1405 | + | else gl(eW)) | |
1406 | + | then true | |
1407 | + | else aS("get operation is blocked by admin"), if ((size(eW.payments) == 0)) | |
1408 | + | then true | |
1409 | + | else aS("no payments are expected")] | |
1410 | + | if ((fQ == fQ)) | |
1411 | + | then { | |
1412 | + | let fP = bh(ho) | |
1413 | + | let ab = eW.caller | |
1414 | + | let ac = eW.transactionId | |
1415 | + | let eD = ew(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1416 | + | if ((eD == eD)) | |
1417 | + | then { | |
1418 | + | let hz = invoke(bw, "unstake", [toBase58String(bq), hy], nil) | |
1419 | + | if ((hz == hz)) | |
1420 | + | then { | |
1421 | + | let hA = fO(fP, hy, bq, ab, ac) | |
1422 | + | if ((hA == hA)) | |
1423 | + | then { | |
1424 | + | let fR = hA._5 | |
1425 | + | let hg = hA._4 | |
1426 | + | let fi = hA._3 | |
1427 | + | let ep = hA._2 | |
1428 | + | let hr = hA._1 | |
1429 | + | let ca = if (if ((ha > 0)) | |
1430 | + | then (ha > hr) | |
1431 | + | else false) | |
1432 | + | then aS(makeString(["amount to receive is less than ", toString(ha)], "")) | |
1433 | + | else hr | |
1434 | + | let hs = invoke(aV, "burn", [hy], [AttachedPayment(bq, hy)]) | |
1435 | + | if ((hs == hs)) | |
1436 | + | then { | |
1437 | + | let gG = cO(ho, ca) | |
1438 | + | if ((gG == gG)) | |
1380 | 1439 | then { | |
1381 | - | let dJ = invoke(this, "rebalance", nil, nil) | |
1382 | - | if ((dJ == dJ)) | |
1383 | - | then $Tuple2(((((er ++ gI) ++ hu) ++ hl) ++ gX), ca) | |
1440 | + | let ht = [ScriptTransfer(eW.caller, ca, fP)] | |
1441 | + | let hk = if ((fi > 0)) | |
1442 | + | then [ScriptTransfer(aW, fi, fP)] | |
1443 | + | else nil | |
1444 | + | let hB = { | |
1445 | + | let hv = if ((this == aW)) | |
1446 | + | then 0 | |
1447 | + | else fi | |
1448 | + | if (fR) | |
1449 | + | then $Tuple2(-((ca + hv)), 0) | |
1450 | + | else $Tuple2(0, -((ca + hv))) | |
1451 | + | } | |
1452 | + | let eF = hB._1 | |
1453 | + | let eG = hB._2 | |
1454 | + | let hC = eE(eF, eG, 0) | |
1455 | + | let gV = hC._1 | |
1456 | + | let ev = hC._2 | |
1457 | + | let gW = eI(eD, ev) | |
1458 | + | if ((gW == gW)) | |
1459 | + | then $Tuple2(((((ep ++ gG) ++ ht) ++ hk) ++ gV), ca) | |
1384 | 1460 | else throw("Strict value is not equal to itself.") | |
1385 | 1461 | } | |
1386 | 1462 | else throw("Strict value is not equal to itself.") | |
1387 | 1463 | } | |
1388 | 1464 | else throw("Strict value is not equal to itself.") | |
1389 | 1465 | } | |
1390 | 1466 | else throw("Strict value is not equal to itself.") | |
1391 | 1467 | } | |
1392 | 1468 | else throw("Strict value is not equal to itself.") | |
1393 | 1469 | } | |
1394 | 1470 | else throw("Strict value is not equal to itself.") | |
1395 | 1471 | } | |
1396 | 1472 | else throw("Strict value is not equal to itself.") | |
1397 | 1473 | } | |
1398 | 1474 | ||
1399 | 1475 | ||
1400 | 1476 | ||
1401 | - | @Callable(eY) | |
1402 | - | func getOneTknREADONLY (fR,fz) = { | |
1403 | - | let hy = fQ(bh(fR), fz, bq, unit, unit) | |
1404 | - | let hs = hy._1 | |
1405 | - | let er = hy._2 | |
1406 | - | let fk = hy._3 | |
1407 | - | let hh = hy._4 | |
1408 | - | let fT = hy._5 | |
1409 | - | $Tuple2(nil, $Tuple3(hs, fk, hh)) | |
1477 | + | @Callable(eW) | |
1478 | + | func get () = { | |
1479 | + | let ea = eV(eW) | |
1480 | + | let hD = ea._1 | |
1481 | + | let dF = ea._2 | |
1482 | + | let eY = ea._3 | |
1483 | + | let dn = ea._4 | |
1484 | + | let dI = ea._5 | |
1485 | + | let eD = ew(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1486 | + | if ((eD == eD)) | |
1487 | + | then { | |
1488 | + | let hE = invoke(aV, "burn", [eY], [AttachedPayment(dn, eY)]) | |
1489 | + | if ((hE == hE)) | |
1490 | + | then { | |
1491 | + | let hF = eE(-(hD), -(dF), 0) | |
1492 | + | let gV = hF._1 | |
1493 | + | let ev = hF._2 | |
1494 | + | let gW = eI(eD, ev) | |
1495 | + | if ((gW == gW)) | |
1496 | + | then (dI ++ gV) | |
1497 | + | else throw("Strict value is not equal to itself.") | |
1498 | + | } | |
1499 | + | else throw("Strict value is not equal to itself.") | |
1500 | + | } | |
1501 | + | else throw("Strict value is not equal to itself.") | |
1410 | 1502 | } | |
1411 | 1503 | ||
1412 | 1504 | ||
1413 | 1505 | ||
1414 | - | @Callable(eY) | |
1415 | - | func unstakeAndGetOneTkn (hz,hp,hb) = { | |
1416 | - | let hd = { | |
1417 | - | let aY = invoke(aV, "isPoolOneTokenOperationsDisabledREADONLY", [toString(this)], nil) | |
1418 | - | if ($isInstanceOf(aY, "Boolean")) | |
1419 | - | then aY | |
1420 | - | else throw(($getType(aY) + " couldn't be cast to Boolean")) | |
1421 | - | } | |
1422 | - | let hq = if (if (bc()) | |
1423 | - | then true | |
1424 | - | else (bp == n)) | |
1425 | - | then true | |
1426 | - | else hd | |
1427 | - | let fS = [if (if (!(hq)) | |
1428 | - | then true | |
1429 | - | else gn(eY)) | |
1430 | - | then true | |
1431 | - | else aS("get operation is blocked by admin"), if ((size(eY.payments) == 0)) | |
1432 | - | then true | |
1433 | - | else aS("no payments are expected")] | |
1434 | - | if ((fS == fS)) | |
1506 | + | @Callable(eW) | |
1507 | + | func getNoLess (hG,hH) = { | |
1508 | + | let ea = eV(eW) | |
1509 | + | let dE = ea._1 | |
1510 | + | let dF = ea._2 | |
1511 | + | let eY = ea._3 | |
1512 | + | let dn = ea._4 | |
1513 | + | let dI = ea._5 | |
1514 | + | if ((hG > dE)) | |
1515 | + | then throw(((("noLessThenAmtAsset failed: " + toString(dE)) + " < ") + toString(hG))) | |
1516 | + | else if ((hH > dF)) | |
1517 | + | then throw(((("noLessThenPriceAsset failed: " + toString(dF)) + " < ") + toString(hH))) | |
1518 | + | else { | |
1519 | + | let eD = ew(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1520 | + | if ((eD == eD)) | |
1521 | + | then { | |
1522 | + | let hE = invoke(aV, "burn", [eY], [AttachedPayment(dn, eY)]) | |
1523 | + | if ((hE == hE)) | |
1524 | + | then { | |
1525 | + | let hI = eE(-(dE), -(dF), 0) | |
1526 | + | let gV = hI._1 | |
1527 | + | let ev = hI._2 | |
1528 | + | let gW = eI(eD, ev) | |
1529 | + | if ((gW == gW)) | |
1530 | + | then (dI ++ gV) | |
1531 | + | else throw("Strict value is not equal to itself.") | |
1532 | + | } | |
1533 | + | else throw("Strict value is not equal to itself.") | |
1534 | + | } | |
1535 | + | else throw("Strict value is not equal to itself.") | |
1536 | + | } | |
1537 | + | } | |
1538 | + | ||
1539 | + | ||
1540 | + | ||
1541 | + | @Callable(eW) | |
1542 | + | func unstakeAndGet (ca) = { | |
1543 | + | let hJ = if ((size(eW.payments) != 0)) | |
1544 | + | then throw("No payments are expected") | |
1545 | + | else true | |
1546 | + | if ((hJ == hJ)) | |
1435 | 1547 | then { | |
1436 | - | let fR = bh(hp) | |
1437 | - | let ab = eY.caller | |
1438 | - | let ac = eY.transactionId | |
1439 | - | let eF = ey(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1440 | - | if ((eF == eF)) | |
1548 | + | let dc = be() | |
1549 | + | let dp = fromBase58String(dc[q]) | |
1550 | + | let eD = ew(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1551 | + | if ((eD == eD)) | |
1441 | 1552 | then { | |
1442 | - | let | |
1443 | - | if (( | |
1553 | + | let hz = invoke(bw, "unstake", [toBase58String(dp), ca], nil) | |
1554 | + | if ((hz == hz)) | |
1444 | 1555 | then { | |
1445 | - | let hB = fQ(fR, hz, bq, ab, ac) | |
1446 | - | if ((hB == hB)) | |
1556 | + | let ea = dl(toBase58String(eW.transactionId), toBase58String(dp), ca, eW.caller) | |
1557 | + | let dE = ea._1 | |
1558 | + | let dF = ea._2 | |
1559 | + | let ds = parseIntValue(ea._9) | |
1560 | + | let dI = ea._10 | |
1561 | + | let hK = if (if (bc()) | |
1562 | + | then true | |
1563 | + | else (ds == n)) | |
1564 | + | then throw(("Get operation is blocked by admin. Status = " + toString(ds))) | |
1565 | + | else true | |
1566 | + | if ((hK == hK)) | |
1447 | 1567 | then { | |
1448 | - | let fT = hB._5 | |
1449 | - | let hh = hB._4 | |
1450 | - | let fk = hB._3 | |
1451 | - | let er = hB._2 | |
1452 | - | let hs = hB._1 | |
1453 | - | let ca = if (if ((hb > 0)) | |
1454 | - | then (hb > hs) | |
1455 | - | else false) | |
1456 | - | then aS(makeString(["amount to receive is less than ", toString(hb)], "")) | |
1457 | - | else hs | |
1458 | - | let ht = invoke(aV, "burn", [hz], [AttachedPayment(bq, hz)]) | |
1459 | - | if ((ht == ht)) | |
1568 | + | let hE = invoke(aV, "burn", [ca], [AttachedPayment(dp, ca)]) | |
1569 | + | if ((hE == hE)) | |
1460 | 1570 | then { | |
1461 | - | let gI = cQ(hp, ca) | |
1462 | - | if ((gI == gI)) | |
1463 | - | then { | |
1464 | - | let hu = [ScriptTransfer(eY.caller, ca, fR)] | |
1465 | - | let hl = if ((fk > 0)) | |
1466 | - | then [ScriptTransfer(aW, fk, fR)] | |
1467 | - | else nil | |
1468 | - | let hC = { | |
1469 | - | let hw = if ((this == aW)) | |
1470 | - | then 0 | |
1471 | - | else fk | |
1472 | - | if (fT) | |
1473 | - | then $Tuple2(-((ca + hw)), 0) | |
1474 | - | else $Tuple2(0, -((ca + hw))) | |
1475 | - | } | |
1476 | - | let eH = hC._1 | |
1477 | - | let eI = hC._2 | |
1478 | - | let hD = eG(eH, eI, 0) | |
1479 | - | let gX = hD._1 | |
1480 | - | let ex = hD._2 | |
1481 | - | let gY = eK(eF, ex) | |
1482 | - | if ((gY == gY)) | |
1483 | - | then { | |
1484 | - | let dJ = invoke(this, "rebalance", nil, nil) | |
1485 | - | if ((dJ == dJ)) | |
1486 | - | then $Tuple2(((((er ++ gI) ++ hu) ++ hl) ++ gX), ca) | |
1487 | - | else throw("Strict value is not equal to itself.") | |
1488 | - | } | |
1489 | - | else throw("Strict value is not equal to itself.") | |
1490 | - | } | |
1571 | + | let hL = eE(-(dE), -(dF), 0) | |
1572 | + | let gV = hL._1 | |
1573 | + | let ev = hL._2 | |
1574 | + | let gW = eI(eD, ev) | |
1575 | + | if ((gW == gW)) | |
1576 | + | then (dI ++ gV) | |
1491 | 1577 | else throw("Strict value is not equal to itself.") | |
1492 | 1578 | } | |
1493 | 1579 | else throw("Strict value is not equal to itself.") | |
1494 | 1580 | } | |
1495 | 1581 | else throw("Strict value is not equal to itself.") | |
1496 | 1582 | } | |
1497 | 1583 | else throw("Strict value is not equal to itself.") | |
1498 | 1584 | } | |
1499 | 1585 | else throw("Strict value is not equal to itself.") | |
1500 | 1586 | } | |
1501 | 1587 | else throw("Strict value is not equal to itself.") | |
1502 | 1588 | } | |
1503 | 1589 | ||
1504 | 1590 | ||
1505 | 1591 | ||
1506 | - | @Callable(eY) | |
1507 | - | func get () = { | |
1508 | - | let ec = eX(eY) | |
1509 | - | let hE = ec._1 | |
1510 | - | let dG = ec._2 | |
1511 | - | let fa = ec._3 | |
1512 | - | let do = ec._4 | |
1513 | - | let dK = ec._5 | |
1514 | - | let eF = ey(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1515 | - | if ((eF == eF)) | |
1592 | + | @Callable(eW) | |
1593 | + | func unstakeAndGetNoLess (hy,hM,hH) = { | |
1594 | + | let hp = if (bc()) | |
1595 | + | then true | |
1596 | + | else (bp == n) | |
1597 | + | let fQ = [if (!(hp)) | |
1598 | + | then true | |
1599 | + | else throw("get operation is blocked by admin"), if ((size(eW.payments) == 0)) | |
1600 | + | then true | |
1601 | + | else throw("no payments are expected")] | |
1602 | + | if ((fQ == fQ)) | |
1516 | 1603 | then { | |
1517 | - | let | |
1518 | - | if (( | |
1604 | + | let eD = ew(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1605 | + | if ((eD == eD)) | |
1519 | 1606 | then { | |
1520 | - | let hG = eG(-(hE), -(dG), 0) | |
1521 | - | let gX = hG._1 | |
1522 | - | let ex = hG._2 | |
1523 | - | let gY = eK(eF, ex) | |
1524 | - | if ((gY == gY)) | |
1525 | - | then (dK ++ gX) | |
1526 | - | else throw("Strict value is not equal to itself.") | |
1527 | - | } | |
1528 | - | else throw("Strict value is not equal to itself.") | |
1529 | - | } | |
1530 | - | else throw("Strict value is not equal to itself.") | |
1531 | - | } | |
1532 | - | ||
1533 | - | ||
1534 | - | ||
1535 | - | @Callable(eY) | |
1536 | - | func getNoLess (hH,hI) = { | |
1537 | - | let ec = eX(eY) | |
1538 | - | let dF = ec._1 | |
1539 | - | let dG = ec._2 | |
1540 | - | let fa = ec._3 | |
1541 | - | let do = ec._4 | |
1542 | - | let dK = ec._5 | |
1543 | - | if ((hH > dF)) | |
1544 | - | then throw(((("noLessThenAmtAsset failed: " + toString(dF)) + " < ") + toString(hH))) | |
1545 | - | else if ((hI > dG)) | |
1546 | - | then throw(((("noLessThenPriceAsset failed: " + toString(dG)) + " < ") + toString(hI))) | |
1547 | - | else { | |
1548 | - | let eF = ey(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1549 | - | if ((eF == eF)) | |
1550 | - | then { | |
1551 | - | let hF = invoke(aV, "burn", [fa], [AttachedPayment(do, fa)]) | |
1552 | - | if ((hF == hF)) | |
1553 | - | then { | |
1554 | - | let hJ = eG(-(dF), -(dG), 0) | |
1555 | - | let gX = hJ._1 | |
1556 | - | let ex = hJ._2 | |
1557 | - | let gY = eK(eF, ex) | |
1558 | - | if ((gY == gY)) | |
1559 | - | then (dK ++ gX) | |
1560 | - | else throw("Strict value is not equal to itself.") | |
1561 | - | } | |
1562 | - | else throw("Strict value is not equal to itself.") | |
1563 | - | } | |
1564 | - | else throw("Strict value is not equal to itself.") | |
1565 | - | } | |
1566 | - | } | |
1567 | - | ||
1568 | - | ||
1569 | - | ||
1570 | - | @Callable(eY) | |
1571 | - | func unstakeAndGet (ca) = { | |
1572 | - | let hK = if ((size(eY.payments) != 0)) | |
1573 | - | then throw("No payments are expected") | |
1574 | - | else true | |
1575 | - | if ((hK == hK)) | |
1576 | - | then { | |
1577 | - | let dd = be() | |
1578 | - | let dq = fromBase58String(dd[q]) | |
1579 | - | let eF = ey(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1580 | - | if ((eF == eF)) | |
1581 | - | then { | |
1582 | - | let hA = invoke(bw, "unstake", [toBase58String(dq), ca], nil) | |
1583 | - | if ((hA == hA)) | |
1607 | + | let hz = invoke(bw, "unstake", [toBase58String(bq), hy], nil) | |
1608 | + | if ((hz == hz)) | |
1584 | 1609 | then { | |
1585 | - | let ec = dm(toBase58String(eY.transactionId), toBase58String(dq), ca, eY.caller) | |
1586 | - | let dF = ec._1 | |
1587 | - | let dG = ec._2 | |
1588 | - | let dt = parseIntValue(ec._9) | |
1589 | - | let dK = ec._10 | |
1590 | - | let hL = if (if (bc()) | |
1610 | + | let ea = dl(toBase58String(eW.transactionId), toBase58String(bq), hy, eW.caller) | |
1611 | + | let dE = ea._1 | |
1612 | + | let dF = ea._2 | |
1613 | + | let dI = ea._10 | |
1614 | + | let hN = [if ((dE >= hM)) | |
1591 | 1615 | then true | |
1592 | - | else ( | |
1593 | - | then | |
1594 | - | else | |
1595 | - | if (( | |
1616 | + | else throw(makeString(["amount asset amount to receive is less than ", toString(hM)], "")), if ((dF >= hH)) | |
1617 | + | then true | |
1618 | + | else throw(makeString(["price asset amount to receive is less than ", toString(hH)], ""))] | |
1619 | + | if ((hN == hN)) | |
1596 | 1620 | then { | |
1597 | - | let | |
1598 | - | if (( | |
1621 | + | let hE = invoke(aV, "burn", [hy], [AttachedPayment(bq, hy)]) | |
1622 | + | if ((hE == hE)) | |
1599 | 1623 | then { | |
1600 | - | let | |
1601 | - | let | |
1602 | - | let | |
1603 | - | let | |
1604 | - | if (( | |
1605 | - | then ( | |
1624 | + | let hO = eE(-(dE), -(dF), 0) | |
1625 | + | let gV = hO._1 | |
1626 | + | let ev = hO._2 | |
1627 | + | let gW = eI(eD, ev) | |
1628 | + | if ((gW == gW)) | |
1629 | + | then (dI ++ gV) | |
1606 | 1630 | else throw("Strict value is not equal to itself.") | |
1607 | 1631 | } | |
1608 | 1632 | else throw("Strict value is not equal to itself.") | |
1609 | 1633 | } | |
1610 | 1634 | else throw("Strict value is not equal to itself.") | |
1611 | 1635 | } | |
1612 | 1636 | else throw("Strict value is not equal to itself.") | |
1613 | 1637 | } | |
1614 | 1638 | else throw("Strict value is not equal to itself.") | |
1615 | 1639 | } | |
1616 | 1640 | else throw("Strict value is not equal to itself.") | |
1617 | 1641 | } | |
1618 | 1642 | ||
1619 | 1643 | ||
1620 | 1644 | ||
1621 | - | @Callable(eY) | |
1622 | - | func unstakeAndGetNoLess (hz,hN,hI) = { | |
1623 | - | let hq = if (bc()) | |
1624 | - | then true | |
1625 | - | else (bp == n) | |
1626 | - | let fS = [if (!(hq)) | |
1627 | - | then true | |
1628 | - | else throw("get operation is blocked by admin"), if ((size(eY.payments) == 0)) | |
1629 | - | then true | |
1630 | - | else throw("no payments are expected")] | |
1631 | - | if ((fS == fS)) | |
1645 | + | @Callable(eW) | |
1646 | + | func activate (hP,hQ) = if ((toString(eW.caller) != toString(aV))) | |
1647 | + | then throw("permissions denied") | |
1648 | + | else $Tuple2([StringEntry(ae(), hP), StringEntry(af(), hQ)], "success") | |
1649 | + | ||
1650 | + | ||
1651 | + | ||
1652 | + | @Callable(eW) | |
1653 | + | func refreshKLp () = { | |
1654 | + | let hR = valueOrElse(getInteger(ak), 0) | |
1655 | + | let hS = if (((height - hR) >= an)) | |
1656 | + | then unit | |
1657 | + | else aS(makeString([toString(an), " blocks have not passed since the previous call"], "")) | |
1658 | + | if ((hS == hS)) | |
1632 | 1659 | then { | |
1633 | - | let eF = ey(toBigInt(0), toBigInt(0), toBigInt(0)) | |
1634 | - | if ((eF == eF)) | |
1635 | - | then { | |
1636 | - | let hA = invoke(bw, "unstake", [toBase58String(bq), hz], nil) | |
1637 | - | if ((hA == hA)) | |
1638 | - | then { | |
1639 | - | let ec = dm(toBase58String(eY.transactionId), toBase58String(bq), hz, eY.caller) | |
1640 | - | let dF = ec._1 | |
1641 | - | let dG = ec._2 | |
1642 | - | let dK = ec._10 | |
1643 | - | let hO = [if ((dF >= hN)) | |
1644 | - | then true | |
1645 | - | else throw(makeString(["amount asset amount to receive is less than ", toString(hN)], "")), if ((dG >= hI)) | |
1646 | - | then true | |
1647 | - | else throw(makeString(["price asset amount to receive is less than ", toString(hI)], ""))] | |
1648 | - | if ((hO == hO)) | |
1649 | - | then { | |
1650 | - | let hF = invoke(aV, "burn", [hz], [AttachedPayment(bq, hz)]) | |
1651 | - | if ((hF == hF)) | |
1652 | - | then { | |
1653 | - | let hP = eG(-(dF), -(dG), 0) | |
1654 | - | let gX = hP._1 | |
1655 | - | let ex = hP._2 | |
1656 | - | let gY = eK(eF, ex) | |
1657 | - | if ((gY == gY)) | |
1658 | - | then (dK ++ gX) | |
1659 | - | else throw("Strict value is not equal to itself.") | |
1660 | - | } | |
1661 | - | else throw("Strict value is not equal to itself.") | |
1662 | - | } | |
1663 | - | else throw("Strict value is not equal to itself.") | |
1664 | - | } | |
1665 | - | else throw("Strict value is not equal to itself.") | |
1666 | - | } | |
1667 | - | else throw("Strict value is not equal to itself.") | |
1660 | + | let eP = valueOrErrorMessage(parseBigInt(valueOrElse(getString(this, aj), "0")), aU("invalid kLp")) | |
1661 | + | let hT = eE(0, 0, 0) | |
1662 | + | let hU = hT._1 | |
1663 | + | let ev = hT._2 | |
1664 | + | let eH = if ((eP != ev)) | |
1665 | + | then hU | |
1666 | + | else aS("nothing to refresh") | |
1667 | + | $Tuple2(eH, toString(ev)) | |
1668 | 1668 | } | |
1669 | 1669 | else throw("Strict value is not equal to itself.") | |
1670 | 1670 | } | |
1671 | 1671 | ||
1672 | 1672 | ||
1673 | 1673 | ||
1674 | - | @Callable(eY) | |
1675 | - | func activate (hQ,hR) = if ((toString(eY.caller) != toString(aV))) | |
1676 | - | then throw("permissions denied") | |
1677 | - | else $Tuple2([StringEntry(ae(), hQ), StringEntry(af(), hR)], "success") | |
1674 | + | @Callable(eW) | |
1675 | + | func getPoolConfigWrapperREADONLY () = $Tuple2(nil, be()) | |
1678 | 1676 | ||
1679 | 1677 | ||
1680 | 1678 | ||
1681 | - | @Callable(eY) | |
1682 | - | func refreshKLp () = { | |
1683 | - | let hS = valueOrElse(getInteger(ak), 0) | |
1684 | - | let hT = if (((height - hS) >= an)) | |
1685 | - | then unit | |
1686 | - | else aS(makeString([toString(an), " blocks have not passed since the previous call"], "")) | |
1687 | - | if ((hT == hT)) | |
1688 | - | then { | |
1689 | - | let eR = valueOrErrorMessage(parseBigInt(valueOrElse(getString(this, aj), "0")), aU("invalid kLp")) | |
1690 | - | let hU = eG(0, 0, 0) | |
1691 | - | let hV = hU._1 | |
1692 | - | let ex = hU._2 | |
1693 | - | let eJ = if ((eR != ex)) | |
1694 | - | then hV | |
1695 | - | else aS("nothing to refresh") | |
1696 | - | $Tuple2(eJ, toString(ex)) | |
1697 | - | } | |
1698 | - | else throw("Strict value is not equal to itself.") | |
1679 | + | @Callable(eW) | |
1680 | + | func getAccBalanceWrapperREADONLY (ar) = $Tuple2(nil, bN(ar)) | |
1681 | + | ||
1682 | + | ||
1683 | + | ||
1684 | + | @Callable(eW) | |
1685 | + | func calcPricesWrapperREADONLY (cW,cX,db) = { | |
1686 | + | let dk = da(cW, cX, db) | |
1687 | + | $Tuple2(nil, [toString(dk[0]), toString(dk[1]), toString(dk[2])]) | |
1699 | 1688 | } | |
1700 | 1689 | ||
1701 | 1690 | ||
1702 | 1691 | ||
1703 | - | @Callable( | |
1704 | - | func | |
1692 | + | @Callable(eW) | |
1693 | + | func toX18WrapperREADONLY (E,F) = $Tuple2(nil, toString(D(E, F))) | |
1705 | 1694 | ||
1706 | 1695 | ||
1707 | 1696 | ||
1708 | - | @Callable( | |
1709 | - | func | |
1697 | + | @Callable(eW) | |
1698 | + | func fromX18WrapperREADONLY (I,J) = $Tuple2(nil, H(parseBigIntValue(I), J)) | |
1710 | 1699 | ||
1711 | 1700 | ||
1712 | 1701 | ||
1713 | - | @Callable(eY) | |
1714 | - | func calcPricesWrapperREADONLY (cX,cY,dc) = { | |
1715 | - | let dl = db(cX, cY, dc) | |
1716 | - | $Tuple2(nil, [toString(dl[0]), toString(dl[1]), toString(dl[2])]) | |
1702 | + | @Callable(eW) | |
1703 | + | func calcPriceBigIntWrapperREADONLY (bR,bS) = $Tuple2(nil, toString(bQ(parseBigIntValue(bR), parseBigIntValue(bS)))) | |
1704 | + | ||
1705 | + | ||
1706 | + | ||
1707 | + | @Callable(eW) | |
1708 | + | func estimatePutOperationWrapperREADONLY (dm,dK,dL,dM,dN,dO,ab,dP,dQ) = $Tuple2(nil, dJ(dm, dK, dL, dM, dN, dO, ab, dP, dQ)) | |
1709 | + | ||
1710 | + | ||
1711 | + | ||
1712 | + | @Callable(eW) | |
1713 | + | func estimateGetOperationWrapperREADONLY (dm,dn,do,ab) = { | |
1714 | + | let ea = dl(dm, dn, do, addressFromStringValue(ab)) | |
1715 | + | $Tuple2(nil, $Tuple10(ea._1, ea._2, ea._3, ea._4, ea._5, ea._6, ea._7, toString(ea._8), ea._9, ea._10)) | |
1717 | 1716 | } | |
1718 | 1717 | ||
1719 | 1718 | ||
1720 | 1719 | ||
1721 | - | @Callable(eY) | |
1722 | - | func toX18WrapperREADONLY (E,F) = $Tuple2(nil, toString(D(E, F))) | |
1723 | - | ||
1724 | - | ||
1725 | - | ||
1726 | - | @Callable(eY) | |
1727 | - | func fromX18WrapperREADONLY (I,J) = $Tuple2(nil, H(parseBigIntValue(I), J)) | |
1728 | - | ||
1729 | - | ||
1730 | - | ||
1731 | - | @Callable(eY) | |
1732 | - | func calcPriceBigIntWrapperREADONLY (bR,bS) = $Tuple2(nil, toString(bQ(parseBigIntValue(bR), parseBigIntValue(bS)))) | |
1733 | - | ||
1734 | - | ||
1735 | - | ||
1736 | - | @Callable(eY) | |
1737 | - | func estimatePutOperationWrapperREADONLY (dn,dM,dN,dO,dP,dQ,ab,dR,dS) = $Tuple2(nil, dL(dn, dM, dN, dO, dP, dQ, ab, dR, dS)) | |
1738 | - | ||
1739 | - | ||
1740 | - | ||
1741 | - | @Callable(eY) | |
1742 | - | func estimateGetOperationWrapperREADONLY (dn,do,dp,ab) = { | |
1743 | - | let ec = dm(dn, do, dp, addressFromStringValue(ab)) | |
1744 | - | $Tuple2(nil, $Tuple10(ec._1, ec._2, ec._3, ec._4, ec._5, ec._6, ec._7, toString(ec._8), ec._9, ec._10)) | |
1720 | + | @Callable(eW) | |
1721 | + | func statsREADONLY () = { | |
1722 | + | let dc = be() | |
1723 | + | let dp = fromBase58String(dc[q]) | |
1724 | + | let hV = dc[r] | |
1725 | + | let hW = dc[s] | |
1726 | + | let dT = dc[v] | |
1727 | + | let dU = dc[w] | |
1728 | + | let dd = parseIntValue(dc[t]) | |
1729 | + | let de = parseIntValue(dc[u]) | |
1730 | + | let hX = valueOrErrorMessage(assetInfo(dp), (("Asset " + toBase58String(dp)) + " doesn't exist")).quantity | |
1731 | + | let hY = bN(hV) | |
1732 | + | let hZ = bN(hW) | |
1733 | + | let ia = if ((hX == 0)) | |
1734 | + | then [e, e, e] | |
1735 | + | else da(hY, hZ, hX) | |
1736 | + | let dz = 0 | |
1737 | + | let ib = H(ia[1], b) | |
1738 | + | let ic = H(ia[2], b) | |
1739 | + | let id = value(getInteger(aV, aF(toString(this)))) | |
1740 | + | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d", toString(hY), toString(hZ), toString(hX), toString(dz), toString(ib), toString(ic), toString(id)], j)) | |
1745 | 1741 | } | |
1746 | 1742 | ||
1747 | 1743 | ||
1748 | 1744 | ||
1749 | - | @Callable(eY) | |
1750 | - | func statsREADONLY () = { | |
1751 | - | let dd = be() | |
1752 | - | let dq = fromBase58String(dd[q]) | |
1753 | - | let hW = dd[r] | |
1754 | - | let hX = dd[s] | |
1755 | - | let dV = dd[v] | |
1756 | - | let dW = dd[w] | |
1757 | - | let de = parseIntValue(dd[t]) | |
1758 | - | let df = parseIntValue(dd[u]) | |
1759 | - | let hY = valueOrErrorMessage(assetInfo(dq), (("Asset " + toBase58String(dq)) + " doesn't exist")).quantity | |
1760 | - | let hZ = bN(hW) | |
1761 | - | let ia = bN(hX) | |
1762 | - | let ib = if ((hY == 0)) | |
1763 | - | then [e, e, e] | |
1764 | - | else db(hZ, ia, hY) | |
1765 | - | let dA = 0 | |
1766 | - | let ic = H(ib[1], b) | |
1767 | - | let id = H(ib[2], b) | |
1768 | - | let ie = value(getInteger(aV, aF(toString(this)))) | |
1769 | - | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d", toString(hZ), toString(ia), toString(hY), toString(dA), toString(ic), toString(id), toString(ie)], j)) | |
1745 | + | @Callable(eW) | |
1746 | + | func evaluatePutByAmountAssetREADONLY (dL) = { | |
1747 | + | let dc = be() | |
1748 | + | let dp = fromBase58String(dc[q]) | |
1749 | + | let dR = dc[r] | |
1750 | + | let dq = fromBase58String(dR) | |
1751 | + | let dS = dc[s] | |
1752 | + | let dr = fromBase58String(dS) | |
1753 | + | let dd = parseIntValue(dc[t]) | |
1754 | + | let de = parseIntValue(dc[u]) | |
1755 | + | let ds = dc[p] | |
1756 | + | let hX = valueOrErrorMessage(assetInfo(dp), (("Asset " + toBase58String(dp)) + " doesn't exist")).quantity | |
1757 | + | let hY = bN(dR) | |
1758 | + | let hZ = bN(dS) | |
1759 | + | let cY = D(hY, dd) | |
1760 | + | let cZ = D(hZ, de) | |
1761 | + | let dy = if ((hX == 0)) | |
1762 | + | then e | |
1763 | + | else bQ(cZ, cY) | |
1764 | + | let dX = D(dL, dd) | |
1765 | + | let dY = fraction(dX, dy, d) | |
1766 | + | let dN = H(dY, de) | |
1767 | + | let fc = dJ("", 500000, dL, dq, dN, dr, "", true, false) | |
1768 | + | let ei = fc._1 | |
1769 | + | let ie = fc._3 | |
1770 | + | let du = fc._4 | |
1771 | + | let dw = fc._5 | |
1772 | + | let dt = fc._6 | |
1773 | + | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d%d", toString(ei), toString(H(dy, b)), toString(du), toString(dw), toString(dt), ds, toString(dL), toString(dN)], j)) | |
1770 | 1774 | } | |
1771 | 1775 | ||
1772 | 1776 | ||
1773 | 1777 | ||
1774 | - | @Callable( | |
1775 | - | func | |
1776 | - | let | |
1777 | - | let | |
1778 | - | let | |
1779 | - | let | |
1780 | - | let | |
1781 | - | let | |
1782 | - | let | |
1783 | - | let | |
1784 | - | let | |
1785 | - | let | |
1786 | - | let | |
1787 | - | let | |
1788 | - | let | |
1789 | - | let | |
1790 | - | let | |
1778 | + | @Callable(eW) | |
1779 | + | func evaluatePutByPriceAssetREADONLY (dN) = { | |
1780 | + | let dc = be() | |
1781 | + | let dp = fromBase58String(dc[q]) | |
1782 | + | let dR = dc[r] | |
1783 | + | let dq = fromBase58String(dR) | |
1784 | + | let dS = dc[s] | |
1785 | + | let dr = fromBase58String(dS) | |
1786 | + | let dd = parseIntValue(dc[t]) | |
1787 | + | let de = parseIntValue(dc[u]) | |
1788 | + | let ds = dc[p] | |
1789 | + | let hX = valueOrErrorMessage(assetInfo(dp), (("Asset " + toBase58String(dp)) + " doesn't exist")).quantity | |
1790 | + | let if = bN(dR) | |
1791 | + | let ig = bN(dS) | |
1792 | + | let ih = D(if, dd) | |
1793 | + | let ii = D(ig, de) | |
1794 | + | let dy = if ((hX == 0)) | |
1791 | 1795 | then e | |
1792 | - | else bQ( | |
1793 | - | let | |
1794 | - | let | |
1795 | - | let | |
1796 | - | let | |
1797 | - | let | |
1798 | - | let | |
1799 | - | let | |
1800 | - | let | |
1801 | - | let | |
1802 | - | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d%d", toString( | |
1796 | + | else bQ(ii, ih) | |
1797 | + | let dY = D(dN, de) | |
1798 | + | let dX = fraction(dY, d, dy) | |
1799 | + | let dL = H(dX, dd) | |
1800 | + | let fc = dJ("", 500000, dL, dq, dN, dr, "", true, false) | |
1801 | + | let ei = fc._1 | |
1802 | + | let ie = fc._3 | |
1803 | + | let du = fc._4 | |
1804 | + | let dw = fc._5 | |
1805 | + | let dt = fc._6 | |
1806 | + | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d%d", toString(ei), toString(H(dy, b)), toString(du), toString(dw), toString(dt), ds, toString(dL), toString(dN)], j)) | |
1803 | 1807 | } | |
1804 | 1808 | ||
1805 | 1809 | ||
1806 | 1810 | ||
1807 | - | @Callable(eY) | |
1808 | - | func evaluatePutByPriceAssetREADONLY (dP) = { | |
1809 | - | let dd = be() | |
1810 | - | let dq = fromBase58String(dd[q]) | |
1811 | - | let dT = dd[r] | |
1812 | - | let dr = fromBase58String(dT) | |
1813 | - | let dU = dd[s] | |
1814 | - | let ds = fromBase58String(dU) | |
1815 | - | let de = parseIntValue(dd[t]) | |
1816 | - | let df = parseIntValue(dd[u]) | |
1817 | - | let dt = dd[p] | |
1818 | - | let hY = valueOrErrorMessage(assetInfo(dq), (("Asset " + toBase58String(dq)) + " doesn't exist")).quantity | |
1819 | - | let ig = bN(dT) | |
1820 | - | let ih = bN(dU) | |
1821 | - | let ii = D(ig, de) | |
1822 | - | let ij = D(ih, df) | |
1823 | - | let dz = if ((hY == 0)) | |
1824 | - | then e | |
1825 | - | else bQ(ij, ii) | |
1826 | - | let ea = D(dP, df) | |
1827 | - | let dZ = fraction(ea, d, dz) | |
1828 | - | let dN = H(dZ, de) | |
1829 | - | let fe = dL("", 500000, dN, dr, dP, ds, "", true, false) | |
1830 | - | let ek = fe._1 | |
1831 | - | let if = fe._3 | |
1832 | - | let dv = fe._4 | |
1833 | - | let dx = fe._5 | |
1834 | - | let du = fe._6 | |
1835 | - | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d%d", toString(ek), toString(H(dz, b)), toString(dv), toString(dx), toString(du), dt, toString(dN), toString(dP)], j)) | |
1811 | + | @Callable(eW) | |
1812 | + | func evaluateGetREADONLY (ij,ik) = { | |
1813 | + | let ea = dl("", ij, ik, this) | |
1814 | + | let dE = ea._1 | |
1815 | + | let dF = ea._2 | |
1816 | + | let du = ea._5 | |
1817 | + | let dw = ea._6 | |
1818 | + | let dt = ea._7 | |
1819 | + | let dz = ea._8 | |
1820 | + | let ds = parseIntValue(ea._9) | |
1821 | + | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d", toString(dE), toString(dF), toString(du), toString(dw), toString(dt), toString(dz), toString(ds)], j)) | |
1836 | 1822 | } | |
1837 | 1823 | ||
1838 | 1824 | ||
1839 | - | ||
1840 | - | @Callable(eY) | |
1841 | - | func evaluateGetREADONLY (ik,il) = { | |
1842 | - | let ec = dm("", ik, il, this) | |
1843 | - | let dF = ec._1 | |
1844 | - | let dG = ec._2 | |
1845 | - | let dv = ec._5 | |
1846 | - | let dx = ec._6 | |
1847 | - | let du = ec._7 | |
1848 | - | let dA = ec._8 | |
1849 | - | let dt = parseIntValue(ec._9) | |
1850 | - | $Tuple2(nil, makeString(["%d%d%d%d%d%d%d", toString(dF), toString(dG), toString(dv), toString(dx), toString(du), toString(dA), toString(dt)], j)) | |
1851 | - | } | |
1852 | - | ||
1853 | - | ||
1854 | - | @Verifier(im) | |
1855 | - | func in () = { | |
1856 | - | let io = { | |
1857 | - | let bX = gk() | |
1825 | + | @Verifier(il) | |
1826 | + | func im () = { | |
1827 | + | let in = { | |
1828 | + | let bX = gi() | |
1858 | 1829 | if ($isInstanceOf(bX, "ByteVector")) | |
1859 | 1830 | then { | |
1860 | - | let | |
1861 | - | | |
1831 | + | let gm = bX | |
1832 | + | gm | |
1862 | 1833 | } | |
1863 | 1834 | else if ($isInstanceOf(bX, "Unit")) | |
1864 | - | then | |
1835 | + | then il.senderPublicKey | |
1865 | 1836 | else throw("Match error") | |
1866 | 1837 | } | |
1867 | - | let bX = | |
1838 | + | let bX = il | |
1868 | 1839 | if ($isInstanceOf(bX, "Order")) | |
1869 | 1840 | then { | |
1870 | - | let | |
1871 | - | let | |
1872 | - | let | |
1873 | - | let aK = | |
1874 | - | let aL = | |
1875 | - | let aM = sigVerify( | |
1876 | - | let aN = sigVerify( | |
1841 | + | let eL = bX | |
1842 | + | let io = bd() | |
1843 | + | let ip = eK(eL) | |
1844 | + | let aK = ip._1 | |
1845 | + | let aL = ip._2 | |
1846 | + | let aM = sigVerify(eL.bodyBytes, eL.proofs[0], eL.senderPublicKey) | |
1847 | + | let aN = sigVerify(eL.bodyBytes, eL.proofs[1], io) | |
1877 | 1848 | if (if (if (aK) | |
1878 | 1849 | then aM | |
1879 | 1850 | else false) | |
1880 | 1851 | then aN | |
1881 | 1852 | else false) | |
1882 | 1853 | then true | |
1883 | 1854 | else aJ(aK, aL, aM, aN) | |
1884 | 1855 | } | |
1885 | 1856 | else if ($isInstanceOf(bX, "SetScriptTransaction")) | |
1886 | 1857 | then { | |
1887 | - | let | |
1888 | - | if (sigVerify( | |
1858 | + | let gj = bX | |
1859 | + | if (sigVerify(il.bodyBytes, il.proofs[0], in)) | |
1889 | 1860 | then true | |
1890 | 1861 | else { | |
1891 | - | let | |
1892 | - | let | |
1893 | - | let | |
1894 | - | if (( | |
1895 | - | then ( | |
1862 | + | let iq = blake2b256(value(gj.script)) | |
1863 | + | let ir = fromBase64String(value(getString(aV, aH()))) | |
1864 | + | let is = scriptHash(this) | |
1865 | + | if ((ir == iq)) | |
1866 | + | then (is != iq) | |
1896 | 1867 | else false | |
1897 | 1868 | } | |
1898 | 1869 | } | |
1899 | - | else sigVerify( | |
1870 | + | else sigVerify(il.bodyBytes, il.proofs[0], in) | |
1900 | 1871 | } | |
1901 | 1872 |
github/deemru/w8io/169f3d6 425.10 ms ◑![]()