tx · Aw2Cx2EUJnM5xy3E7RWtxHDEXMRNm8mMeBLtBARuJxF2

3MsNhK6uve98J6DeqbuwGFBRh9GoHPGUFgp:  -0.02300000 Waves

2023.08.17 16:34 [2714660] smart account 3MsNhK6uve98J6DeqbuwGFBRh9GoHPGUFgp > SELF 0.00000000 Waves

{ "type": 13, "id": "Aw2Cx2EUJnM5xy3E7RWtxHDEXMRNm8mMeBLtBARuJxF2", "fee": 2300000, "feeAssetId": null, "timestamp": 1692279248233, "version": 2, "chainId": 84, "sender": "3MsNhK6uve98J6DeqbuwGFBRh9GoHPGUFgp", "senderPublicKey": "86RHVxKovtU7yKnepY8wKsd8niDxGAsiwuA1XA1DNqrS", "proofs": [ "2NougJbyAemHZYsu5b43kAjSTnx1mzzJGqEhzrCQ1gbumx8Yvc4yuiKKQY67YjWBsG5xDNkoWsHvHArzY61M6L3T" ], "script": "base64:BgLpIAgCEgMKAQgSAwoBCBIECgIICBIJCgcBERERGAgYEgcKBRERERgIEgcKBQEBAQgIEgASAwoBCBIECgIIARIECgIIARIECgIIARIDCgEIEgYKBAgBCAESBQoDARgYEgMKARgiBlNDQUxFOCIFTVVMVDgiB1NDQUxFMTgiBk1VTFQxOCIDU0VQIg5QT09MV0VJR0hUTVVMVCIKemVyb0JpZ0ludCIOaWR4UG9vbEFkZHJlc3MiDWlkeFBvb2xTdGF0dXMiEGlkeFBvb2xMUEFzc2V0SWQiDWlkeEFtdEFzc2V0SWQiD2lkeFByaWNlQXNzZXRJZCIOaWR4QW10QXNzZXREY20iEGlkeFByaWNlQXNzZXREY20iDmlkeElBbXRBc3NldElkIhBpZHhJUHJpY2VBc3NldElkIg1pZHhMUEFzc2V0RGNtIg9nZXRTdHJpbmdPckZhaWwiA2tleSIYZ2V0U3RyaW5nQnlBZGRyZXNzT3JGYWlsIgdhZGRyZXNzIgxnZXRJbnRPclplcm8iDGdldEludE9yRmFpbCIJYXNBbnlMaXN0IgN2YWwiByRtYXRjaDAiCnZhbEFueUx5c3QiBWFzSW50IgZ2YWxJbnQiCGFzU3RyaW5nIgZ2YWxTdHIiEWtleUZhY3RvcnlBZGRyZXNzIhhJZHhGYWN0b3J5Q2ZnU3Rha2luZ0RhcHAiGUlkeEZhY3RvcnlDZmdCb29zdGluZ0RhcHAiFElkeEZhY3RvcnlDZmdJZG9EYXBwIhVJZHhGYWN0b3J5Q2ZnVGVhbURhcHAiGUlkeEZhY3RvcnlDZmdFbWlzc2lvbkRhcHAiFUlkeEZhY3RvcnlDZmdSZXN0RGFwcCIZSWR4RmFjdG9yeUNmZ1NsaXBwYWdlRGFwcCIaSWR4RmFjdG9yeUNmZ0d3eFJld2FyZERhcHAiDWtleUZhY3RvcnlDZmciGmtleUZhY3RvcnlMcDJBc3NldHNNYXBwaW5nIgpscEFzc2V0U3RyIhBrZXlGYWN0b3J5THBMaXN0IiZrZXlGYWN0b3J5THBBc3NldFRvUG9vbENvbnRyYWN0QWRkcmVzcyIUa2V5RmFjdG9yeVBvb2xXZWlnaHQiD2NvbnRyYWN0QWRkcmVzcyIWa2V5TWFuYWdlclZhdWx0QWRkcmVzcyITa2V5TWFuYWdlclB1YmxpY0tleSIYcmVhZEZhY3RvcnlBZGRyZXNzT3JGYWlsIgpyZWFkTHBMaXN0IhRyZWFkRmFjdG9yeUNmZ09yRmFpbCIHZmFjdG9yeSIYZ2V0Qm9vc3RpbmdBZGRyZXNzT3JGYWlsIgRmQ2ZnIhhnZXRFbWlzc2lvbkFkZHJlc3NPckZhaWwiF2dldFN0YWtpbmdBZGRyZXNzT3JGYWlsIhlnZXRHd3hSZXdhcmRBZGRyZXNzT3JGYWlsIhxnZXRNYW5hZ2VyVmF1bHRBZGRyZXNzT3JUaGlzIgFzIgtrZXlCb29zdENmZyIfa2V5Qm9vc3RpbmdMb2NrUGFyYW1Ub3RhbEFtb3VudCIoa2V5Qm9vc3RpbmdTdGF0c0xvY2tzRHVyYXRpb25TdW1JbkJsb2NrcyIaa2V5Qm9vc3RpbmdTdGF0c0xvY2tzQ291bnQiGmtleUJvb3N0aW5nU3RhdHNVc2Vyc0NvdW50IhJrZXlVc2VyMk51bU1hcHBpbmciC3VzZXJBZGRyZXNzIhJrZXlOdW0yVXNlck1hcHBpbmciA251bSIWa2V5TG9ja1BhcmFtVXNlckFtb3VudCIHdXNlck51bSIWa2V5TG9ja1BhcmFtU3RhcnRCbG9jayIUa2V5TG9ja1BhcmFtRHVyYXRpb24iDWtleUxvY2tQYXJhbUsiDWtleUxvY2tQYXJhbUIiFWtleUxvY2tQYXJhbUJ5UGVyaW9kSyIGcGVyaW9kIhVrZXlMb2NrUGFyYW1CeVBlcmlvZEIiIGtleVVzZXJCb29zdEVtaXNzaW9uTGFzdElOVEVHUkFMIhdrZXlVc2VyTWF4Qm9vc3RJTlRFR1JBTCIYa2V5VG90YWxNYXhCb29zdElOVEVHUkFMIiFrZXlVc2VyQm9vc3RBdmFsYWlibGVUb0NsYWltVG90YWwiE2tleVVzZXJCb29zdENsYWltZWQiEWtleVRvdGFsQ2FjaGVkR3d4Ig9rZXlTdGFrZWRCeVVzZXIiDnVzZXJBZGRyZXNzU3RyIgxscEFzc2V0SWRTdHIiDmtleVN0YWtlZFRvdGFsIhBrZXlDbGFpbWVkQnlVc2VyIhlrZXlDbGFpbWVkQnlVc2VyTWluUmV3YXJkIhtrZXlDbGFpbWVkQnlVc2VyQm9vc3RSZXdhcmQiCnJlYWRTdGFrZWQiC3N0YWtpbmdEYXBwIh5rZXlFbWlzc2lvblJhdGVQZXJCbG9ja0N1cnJlbnQiIWtleUVtaXNzaW9uUmF0ZVBlckJsb2NrTWF4Q3VycmVudCIVa2V5RW1pc3Npb25TdGFydEJsb2NrIhtrZXlFbWlzc2lvbkR1cmF0aW9uSW5CbG9ja3MiE2tleUVtaXNzaW9uRW5kQmxvY2siC2ZhY3RvcnlEYXBwIgpmYWN0b3J5Q2ZnIgxlbWlzc2lvbkRhcHAiDWd3eFJld2FyZERhcHAiDGJvb3N0aW5nRGFwcCIMZ2V0UG9vbEluRmVlIgtwb29sQWRkcmVzcyIBQCINZ2V0UG9vbE91dEZlZSIZaW50ZXJuYWxDdXJyZW50UmV3YXJkUmF0ZSIJbHBBc3NldElkIg5wb29sQWRkcmVzc1N0ciIOcG9vbFdlaWdodE11bHQiCnBvb2xXZWlnaHQiEnd4RW1pc3Npb25QZXJCbG9jayIVd3hFbWlzc2lvblBlckJsb2NrTWF4Ig1ib29zdE1heENvZWZmIhZwb29sV3hFbWlzc2lvblBlckJsb2NrIhlwb29sV3hFbWlzc2lvblBlckJsb2NrTWF4IgltYXhGYWN0b3IiDXRvdGFsTHBTdGFrZWQiGmNhbGNHd3hBbW91bnRTdGFydFJFQURPTkxZIgpsb2NrQW1vdW50Igxsb2NrRHVyYXRpb24iD21heExvY2tEdXJhdGlvbiIHY29lZmZYOCIOZ1d4QW1vdW50U3RhcnQiBmdldEtleSIEYWRkciIEdHlwZSIWbWFuYWdlclB1YmxpY0tleU9yVW5pdCITbWFuYWdlclZhdWx0QWRkcmVzcyIJaXNNYW5hZ2VyIgFpIgJwayILbXVzdE1hbmFnZXIiDmZhY3RvcnlBZGRyZXNzIgtjaGVja0NhbGxlciIKcmV3YXJkRGF0YSISdm90aW5nUmVzdWx0U3Rha2VkIg5scFN0YWtlZEJ5VXNlciINdXNlckNsYWltSW5mbyINbWluUmV3YXJkUGFydCIPYm9vc3RSZXdhcmRQYXJ0IgVkZWJ1ZyINYm9vc3RpbmdQb3dlciILY3VycmVudEl0ZXIiEWRlbHRhV3hBbW91bnRCdWxrIhtkZWx0YUxvY2tQZXJpb2RJbkJsb2Nrc0J1bGsiEWRlbHRhTHBBbW91bnRCdWxrIhBscEFzc2V0SWRPcHRCdWxrIg51c2VyQWRkcmVzc09wdCIGcmVzQWNjIg1kZWx0YVd4QW1vdW50IhdkZWx0YUxvY2tQZXJpb2RJbkJsb2NrcyINZGVsdGFMcEFtb3VudCIMbHBBc3NldElkT3B0IgRpbmZvIgNyZXMiA2ludiIKYm9vc3RDb2VmZiIIbWF0aERhcHAiCEVNUFRZU1RSIhdtYXhMb2NrRHVyYXRpb25JbkJsb2NrcyIKdXNlck51bVN0ciIKdXNlckFtb3VudCIJbG9ja1N0YXJ0Igdsb2NrRW5kIhFyZW1haW5pbmdEdXJhdGlvbiINdXNlckFtb3VudE5ldyIPbG9ja0R1cmF0aW9uTmV3IhF1c2VyQ3VycmdXeEFtb3VudCIRZ1d4QW1vdW50U3RhcnROZXciDnRvdGFsQ2FjaGVkR3d4IgVNVUxUMyIUd3hFbWlzc2lvblBlckJsb2NrWDMiD3N0YWtlZEJ5VXNlcktFWSIOc3Rha2VkVG90YWxLRVkiDHN0YWtlZEJ5VXNlciILc3Rha2VkVG90YWwiGHBvb2xXeEVtaXNzaW9uUGVyQmxvY2tYMyIJd3hQZXJMcFgzIhB1c2VyV3hQZXJCbG9ja1gzIhdib29zdEVtaXNzaW9uUGVyQmxvY2tYMyIWdG1wVXNlckJvb3N0UGVyQmxvY2tYMyITdXNlckJvb3N0UGVyQmxvY2tYMyIOdXNlckJvb3N0Q29lZmYiB09ORU1VTFQiA09ORSISZW1pc3Npb25TdGFydEJsb2NrIgxwYXNzZWRCbG9ja3MiDnRlYW1FbUR1cmF0aW9uIgl0ZWFtRW1NYXgiBnRlYW1FbSIPdG90YWxXeFJlbGVhc2VkIg10b3RhbFd4TG9ja2VkIhhsb2Nrc0R1cmF0aW9uU3VtSW5CbG9ja3MiCmxvY2tzQ291bnQiB2xwQXNzZXQiBnN0YXR1cyIDdHBsIgNjZmciCmFtdEFzc2V0SWQiDHByaWNlQXNzZXRJZCILaUFtdEFzc2V0SWQiDWlQcmljZUFzc2V0SWQiC2FtdEFzc2V0RGNtIg1wcmljZUFzc2V0RGNtIg1wb29sTFBCYWxhbmNlIhJhY2NBbXRBc3NldEJhbGFuY2UiFGFjY1ByaWNlQXNzZXRCYWxhbmNlIgpwcmljZXNMaXN0IghjdXJQcmljZSIPbHBBbXRBc3NldFNoYXJlIhFscFByaWNlQXNzZXRTaGFyZSIFaW5GZWUiBm91dEZlZSIecG9vbE9uZVRva2VuT3BlcmF0aW9uc0Rpc2FibGVkIh1wb29sT25lVG9rZW5PcGVyYXRpb25zRW5hYmxlZCIMaW5BbUFzc2V0QW10IgxhbUFzc2V0SWRTdHIiCWFtQXNzZXRJZCIMcHJBc3NldElkU3RyIglwckFzc2V0SWQiCnBvb2xTdGF0dXMiDmFtdEFzc2V0QW10WDE4IhBwcmljZUFzc2V0QW10WDE4IgtjdXJQcmljZVgxOCIPaW5BbUFzc2V0QW10WDE4Ig9pblByQXNzZXRBbXRYMTgiDGluUHJBc3NldEFtdCINJHQwMjI2OTEyMzA0NCIJY2FsY0xwQW10IgxjdXJQcmljZUNhbGMiCWFtQmFsYW5jZSIJcHJCYWxhbmNlIgpscEVtaXNzaW9uIgxhbUJhbGFuY2VSYXciDHByQmFsYW5jZVJhdyIPYW1CYWxhbmNlUmF3WDE4Ig9wckJhbGFuY2VSYXdYMTgiDSR0MDI1NjE3MjU5NzAiEHBheW1lbnRMcEFzc2V0SWQiDHBheW1lbnRMcEFtdCINJHQwMjY2NjUyNzA4MiIIb3V0QW1BbXQiCG91dFByQW10Ig9nd3hVc2VySW5mb0xJU1QiCWd3eEFtb3VudCINdW5zdGFrZUFtb3VudCIKb3V0QXNzZXRJZCIMbWluT3V0QW1vdW50IgRrZXlzIgFrIgJ0eCIGdmVyaWZ5Ig90YXJnZXRQdWJsaWNLZXldAAFhAAgAAWIAgMLXLwABYwASAAFkCQC2AgEAgICQu7rWrfANAAFlAgJfXwABZgUBYgABZwkAtgIBAAAAAWgAAQABaQACAAFqAAMAAWsABAABbAAFAAFtAAYAAW4ABwABbwAIAAFwAAkAAXEACgEBcgEBcwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCiCAEFAXMJAKwCAgkArAICAg9tYW5kYXRvcnkgdGhpcy4FAXMCDyBpcyBub3QgZGVmaW5lZAEBdAIBdQFzCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUBdQUBcwkArAICCQCsAgIJAKwCAgkArAICAgptYW5kYXRvcnkgCQClCAEFAXUCAS4FAXMCDyBpcyBub3QgZGVmaW5lZAEBdgIBdQFzCQELdmFsdWVPckVsc2UCCQCaCAIFAXUFAXMAAAEBdwIBdQFzCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUBdQUBcwkArAICCQCsAgICD21hbmRhdG9yeSB0aGlzLgUBcwIPIGlzIG5vdCBkZWZpbmVkAQF4AQF5BAF6BQF5AwkAAQIFAXoCCUxpc3RbQW55XQQBQQUBegUBQQkAAgECG2ZhaWwgdG8gY2FzdCBpbnRvIExpc3RbQW55XQEBQgEBeQQBegUBeQMJAAECBQF6AgNJbnQEAUMFAXoFAUMJAAIBAhVmYWlsIHRvIGNhc3QgaW50byBJbnQBAUQBAXkEAXoFAXkDCQABAgUBegIGU3RyaW5nBAFFBQF6BQFFCQACAQIYZmFpbCB0byBjYXN0IGludG8gU3RyaW5nAQFGAAIcJXMlc19fY29uZmlnX19mYWN0b3J5QWRkcmVzcwABRwABAAFIAAIAAUkAAwABSgAEAAFLAAUAAUwABgABTQAHAAFOAAgBAU8AAhElc19fZmFjdG9yeUNvbmZpZwEBUAEBUQkAuQkCCQDMCAICBiVzJXMlcwkAzAgCBQFRCQDMCAICHm1hcHBpbmdzX19scEFzc2V0MlBvb2xDb250cmFjdAUDbmlsBQFlAQFSAAIQJXNfX2xwVG9rZW5zTGlzdAEBUwEBUQkAuQkCCQDMCAICBiVzJXMlcwkAzAgCBQFRCQDMCAICHm1hcHBpbmdzX19scEFzc2V0MlBvb2xDb250cmFjdAUDbmlsBQFlAQFUAQFVCQC5CQIJAMwIAgIEJXMlcwkAzAgCAgpwb29sV2VpZ2h0CQDMCAIFAVUFA25pbAUBZQEBVgACFyVzX19tYW5hZ2VyVmF1bHRBZGRyZXNzAQFXAAIUJXNfX21hbmFnZXJQdWJsaWNLZXkBAVgACQERQGV4dHJOYXRpdmUoMTA2MikBCQEBcgEJAQFGAAEBWQAJALUJAgkBC3ZhbHVlT3JFbHNlAgkAnQgCCQEBWAAJAQFSAAIABQFlAQFaAQJhYQkAtQkCCQEBdAIFAmFhCQEBTwAFAWUBAmFiAQJhYwkBEUBleHRyTmF0aXZlKDEwNjIpAQkAkQMCBQJhYwUBSAECYWQBAmFjCQERQGV4dHJOYXRpdmUoMTA2MikBCQCRAwIFAmFjBQFLAQJhZQECYWMJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAJEDAgUCYWMFAUcBAmFmAQJhYwkBEUBleHRyTmF0aXZlKDEwNjIpAQkAkQMCBQJhYwUBTgECYWcABAF6CQCiCAEJAQFWAAMJAAECBQF6AgZTdHJpbmcEAmFoBQF6CQERQGV4dHJOYXRpdmUoMTA2MikBBQJhaAUEdGhpcwECYWkAAgolc19fY29uZmlnAQJhagACHiVzJXNfX3N0YXRzX19hY3RpdmVUb3RhbExvY2tlZAECYWsAAiUlcyVzX19zdGF0c19fbG9ja3NEdXJhdGlvblN1bUluQmxvY2tzAQJhbAACFyVzJXNfX3N0YXRzX19sb2Nrc0NvdW50AQJhbQACHSVzJXNfX3N0YXRzX19hY3RpdmVVc2Vyc0NvdW50AQJhbgECYW8JALkJAgkAzAgCAhklcyVzJXNfX21hcHBpbmdfX3VzZXIybnVtCQDMCAIFAmFvBQNuaWwFAWUBAmFwAQJhcQkAuQkCCQDMCAICGSVzJXMlc19fbWFwcGluZ19fbnVtMnVzZXIJAMwIAgUCYXEFA25pbAUBZQECYXIBAmFzCQC5CQIJAMwIAgIWJXMlZCVzX19wYXJhbUJ5VXNlck51bQkAzAgCBQJhcwkAzAgCAgZhbW91bnQFA25pbAUBZQECYXQBAmFzCQC5CQIJAMwIAgIWJXMlZCVzX19wYXJhbUJ5VXNlck51bQkAzAgCBQJhcwkAzAgCAgVzdGFydAUDbmlsBQFlAQJhdQECYXMJALkJAgkAzAgCAhYlcyVkJXNfX3BhcmFtQnlVc2VyTnVtCQDMCAIFAmFzCQDMCAICCGR1cmF0aW9uBQNuaWwFAWUBAmF2AQJhcwkAuQkCCQDMCAICFiVzJWQlc19fcGFyYW1CeVVzZXJOdW0JAMwIAgUCYXMJAMwIAgIBawUDbmlsBQFlAQJhdwECYXMJALkJAgkAzAgCAhYlcyVkJXNfX3BhcmFtQnlVc2VyTnVtCQDMCAIFAmFzCQDMCAICAWIFA25pbAUBZQECYXgCAmFzAmF5CQC5CQIJAMwIAgIXJXMlZCVzJWRfX3BhcmFtQnlQZXJpb2QJAMwIAgUCYXMJAMwIAgIBawkAzAgCBQJheQUDbmlsBQFlAQJhegICYXMCYXkJALkJAgkAzAgCAhclcyVkJXMlZF9fcGFyYW1CeVBlcmlvZAkAzAgCBQJhcwkAzAgCAgFiCQDMCAIFAmF5BQNuaWwFAWUBAmFBAQJhcwkAuQkCCQDMCAICHiVzJWRfX3VzZXJCb29zdEVtaXNzaW9uTGFzdEludAkAzAgCBQJhcwUDbmlsBQFlAQJhQgECYXMJALkJAgkAzAgCAhElcyVkX19tYXhCb29zdEludAkAzAgCBQJhcwUDbmlsBQFlAQJhQwACGCVzJXNfX21heEJvb3N0SW50X190b3RhbAECYUQBAmFzCQC5CQIJAMwIAgIkJXMlZF9fdXNlckJvb3N0QXZhbGlhYmxlVG9DbGFpbVRvdGFsCQDMCAIFAmFzBQNuaWwFAWUBAmFFAQJhcwkAuQkCCQDMCAICFiVzJWRfX3VzZXJCb29zdENsYWltZWQJAMwIAgUCYXMFA25pbAUBZQECYUYAAhYlcyVzX19nd3hDYWNoZWRfX3RvdGFsAQJhRwICYUgCYUkJALkJAgkAzAgCAg4lcyVzJXNfX3N0YWtlZAkAzAgCBQJhSAkAzAgCBQJhSQUDbmlsBQFlAQJhSgECYUkJAKwCAgIXJXMlcyVzX19zdGFrZWRfX3RvdGFsX18FAmFJAQJhSwICYUkCYUgJALkJAgkAzAgCAg8lcyVzJXNfX2NsYWltZWQJAMwIAgUCYUgJAMwIAgUCYUkFA25pbAUBZQECYUwCAmFJAmFICQC5CQIJAMwIAgIYJXMlcyVzX19jbGFpbWVkTWluUmV3YXJkCQDMCAIFAmFICQDMCAIFAmFJBQNuaWwFAWUBAmFNAgJhSQJhSAkAuQkCCQDMCAICGiVzJXMlc19fY2xhaW1lZEJvb3N0UmV3YXJkCQDMCAIFAmFICQDMCAIFAmFJBQNuaWwFAWUBAmFOAgJhTwFzCQELdmFsdWVPckVsc2UCCQCaCAIFAmFPBQFzAAABAmFQAAIbJXMlc19fcmF0ZVBlckJsb2NrX19jdXJyZW50AQJhUQACHiVzJXNfX3JhdGVQZXJCbG9ja01heF9fY3VycmVudAECYVIAAholcyVzX19lbWlzc2lvbl9fc3RhcnRCbG9jawECYVMAAhglcyVzX19lbWlzc2lvbl9fZHVyYXRpb24BAmFUAAIYJXMlc19fZW1pc3Npb25fX2VuZEJsb2NrAAJhVQkBAVgAAAJhVgkBAVoBBQJhVQACYVcJAQJhZAEFAmFWAAJhTwkBAmFlAQUCYVYAAmFYCQECYWYBBQJhVgACYVkJAQJhYgEFAmFWAQJhWgECYmEKAAJiYgkA/AcEBQJhVQIQZ2V0SW5GZWVSRUFET05MWQkAzAgCCQClCAEFAmJhBQNuaWwFA25pbAMJAAECBQJiYgIDSW50BQJiYgkAAgEJAKwCAgkAAwEFAmJiAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQBAmJjAQJiYQoAAmJiCQD8BwQFAmFVAhFnZXRPdXRGZWVSRUFET05MWQkAzAgCCQClCAEFAmJhBQNuaWwFA25pbAMJAAECBQJiYgIDSW50BQJiYgkAAgEJAKwCAgkAAwEFAmJiAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQBAmJkAQJiZQQCYmYJAQF0AgUCYVUJAQFTAQUCYmUEAmJnBQFiBAJiaAkBEUBleHRyTmF0aXZlKDEwNTApAgUCYVUJAQFUAQUCYmYEAmJpCQEBdwIFAmFXCQECYVAABAJiagkBAXcCBQJhVwkBAmFRAAQCYmsKAAJiYgkA/AcEBQJhVwIVZ2V0Qm9vc3RDb2VmZlJFQURPTkxZBQNuaWwFA25pbAMJAAECBQJiYgIDSW50BQJiYgkAAgEJAKwCAgkAAwEFAmJiAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQEAmJsCQBpAgkAawMFAmJpBQJiaAUCYmcFAmJrBAJibQkAawMFAmJqBQJiaAUCYmcEAmJuCQBoAgUCYmsFAWIEAmJvCQEBdgIFAmFPCQECYUoBBQJiZQkAzAgCBQJibAkAzAgCBQJibgkAzAgCBQJibwUDbmlsAQJicAMCYnECYnICYnMEAmJ0CQBrAwUCYnIFAWIFAmJzBAJidQkAawMFAmJxBQJidAUBYgkAzAgCBQJidQUDbmlsAQJidgMCYncBcwJieAMJAAACBQJieAIGc3RyaW5nCQERQGV4dHJOYXRpdmUoMTA1MykCBQJidwUBcwMJAAACBQJieAIHaW50ZWdlcgkApAMBCQERQGV4dHJOYXRpdmUoMTA1MCkCBQJidwUBcwMJAAACBQJieAIHYm9vbGVhbgkApQMBCQERQGV4dHJOYXRpdmUoMTA1MSkCBQJidwUBcwkAAgECLXVua25vd24gdHlwZS4gZXhwZWN0ZWQgc3RyaW5nL2ludGVnZXIvYm9vbGVhbgECYnkABAJiegkBAmFnAAQBegkAnQgCBQJiegkBAVcAAwkAAQIFAXoCBlN0cmluZwQCYWgFAXoJANkEAQUCYWgDCQABAgUBegIEVW5pdAUEdW5pdAkAAgECC01hdGNoIGVycm9yAQJiQQECYkIEAXoJAQJieQADCQABAgUBegIKQnl0ZVZlY3RvcgQCYkMFAXoJAAACCAUCYkIPY2FsbGVyUHVibGljS2V5BQJiQwMJAAECBQF6AgRVbml0CQAAAggFAmJCBmNhbGxlcgUEdGhpcwkAAgECC01hdGNoIGVycm9yAQJiRAECYkIDCQECYkEBBQJiQgYJAAIBAhFwZXJtaXNzaW9uIGRlbmllZA8CYkIBC2NvbnN0cnVjdG9yAQJiRQQCYkYJAQJiRAEFAmJCAwkAAAIFAmJGBQJiRgkAzAgCCQELU3RyaW5nRW50cnkCCQEBRgAFAmJFBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYkIBGWN1cnJlbnRSZXdhcmRSYXRlUkVBRE9OTFkBAmJlBAJiRwkBAmJkAQUCYmUEAmJpCQCRAwIFAmJHAAAEAmJuCQCRAwIFAmJHAAEEAmJvCQCRAwIFAmJHAAIEAmJICgACYmIJAPwHBAUCYVkCHWdldFZvdGluZ1Jlc3VsdFN0YWtlZFJFQURPTkxZCQDMCAIFAmJlBQNuaWwFA25pbAMJAAECBQJiYgIDSW50BQJiYgkAAgEJAKwCAgkAAwEFAmJiAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQJAJQKAgUDbmlsCQC5CQIJAMwIAgIIJWQlZCVkJWQJAMwIAgkApAMBBQJiaQkAzAgCCQCkAwEFAmJuCQDMCAIJAKQDAQUCYm8JAMwIAgkApAMBBQJiSAUDbmlsBQFlAmJCAR1jdXJyZW50VXNlclJld2FyZFJhdGVSRUFET05MWQICYmUCYW8EAmJHCQECYmQBBQJiZQQCYmkJAJEDAgUCYkcAAAQCYm4JAJEDAgUCYkcAAQQCYm8JAJEDAgUCYkcAAgQCYkkJAQF2AgUCYU8JAQJhRwIFAmFvBQJiZQQCYkoJALUJAgkBAUQBCQD8BwQFAmFPAg9jbGFpbVd4UkVBRE9OTFkJAMwIAgUCYmUJAMwIAgUCYW8FA25pbAUDbmlsBQFlBAJiSwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQC2CQEJAJEDAgUCYkoABQIcY291bGRuJ3QgcGFyc2UgbWluUmV3YXJkUGFydAQCYkwJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAtgkBCQCRAwIFAmJKAAYCHmNvdWxkbid0IHBhcnNlIGJvb3N0UmV3YXJkUGFydAQCYk0JAJEDAgUCYkoABwQCYk4DCQAAAgUCYkwAAAkAaAIAAQUBYgkAawMJAGQCBQJiSwUCYkwFAWIFAmJLCQCUCgIFA25pbAkAuQkCCQDMCAICDCVkJWQlZCVkJWQlcwkAzAgCCQCkAwEFAmJpCQDMCAIJAKQDAQUCYm4JAMwIAgkApAMBBQJibwkAzAgCCQCkAwEFAmJJCQDMCAIJAKQDAQUCYk4JAMwIAgUCYk0FA25pbAUBZQJiQgEdY2FsY0Jvb3N0QnVsa0ludGVybmFsUkVBRE9OTFkHAmJPAmJQAmJRAmJSAmJTAmJUAmJVAwkAAAIFAmJPCQCQAwEFAmJQCQCUCgIFA25pbAUCYlUEAmJWCQCRAwIFAmJQBQJiTwQCYlcJAJEDAgUCYlEFAmJPBAJiWAkAkQMCBQJiUgUCYk8EAmJZCQCRAwIFAmJTBQJiTwQCYloKAAJiYgkA/AcEBQR0aGlzAhFjYWxjQm9vc3RSRUFET05MWQkAzAgCBQJiVgkAzAgCBQJiVwkAzAgCBQJiWAkAzAgCBQJiWQkAzAgCBQJiVAUDbmlsBQNuaWwDCQABAgUCYmICBlN0cmluZwUCYmIJAAIBCQCsAgIJAAMBBQJiYgIbIGNvdWxkbid0IGJlIGNhc3QgdG8gU3RyaW5nBAJjYQkAzQgCBQJiVQUCYloEAmNiCgACYmIJAPwHBAUEdGhpcwIdY2FsY0Jvb3N0QnVsa0ludGVybmFsUkVBRE9OTFkJAMwIAgkAZAIFAmJPAAEJAMwIAgUCYlAJAMwIAgUCYlEJAMwIAgUCYlIJAMwIAgUCYlMJAMwIAgUCYlQJAMwIAgUCY2EFA25pbAUDbmlsAwkAAQIFAmJiAglMaXN0W0FueV0FAmJiCQACAQkArAICCQADAQUCYmICHiBjb3VsZG4ndCBiZSBjYXN0IHRvIExpc3RbQW55XQMJAAACBQJjYgUCY2IJAJQKAgUDbmlsBQJjYgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJiQgEVY2FsY0Jvb3N0QnVsa1JFQURPTkxZBQJiVgJiVwJiWAJiWQJiVAQCY2EJAPwHBAUEdGhpcwIdY2FsY0Jvb3N0QnVsa0ludGVybmFsUkVBRE9OTFkJAMwIAgAACQDMCAIFAmJWCQDMCAIFAmJXCQDMCAIFAmJYCQDMCAIFAmJZCQDMCAIFAmJUCQDMCAIFA25pbAUDbmlsBQNuaWwJAJQKAgUDbmlsBQJjYQJiQgERY2FsY0Jvb3N0UkVBRE9OTFkFAmJWAmJXAmJYAmJZAmJUBAJjYwoAAmJiCQD8BwQFAmFXAhVnZXRCb29zdENvZWZmUkVBRE9OTFkFA25pbAUDbmlsAwkAAQIFAmJiAgNJbnQFAmJiCQACAQkArAICCQADAQUCYmICGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAQCY2QFAmFYBAJjZQIFZW1wdHkEAmNmCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgkAtQkCCQEBdAIFAmFZCQECYWkABQFlAAQEAmFJAwkAAAIFAmJZAgAFAmNlBQJiWQQCYUgDCQAAAgUCYlQCAAUCY2UFAmJUBAJjZwkBC3ZhbHVlT3JFbHNlAgkAnQgCBQJhWQkBAmFuAQUCYlQFAmNlBAJjaAkBC3ZhbHVlT3JFbHNlAgkAmggCBQJhWQkBAmFyAQUCY2cAAAQCY2kJAQt2YWx1ZU9yRWxzZQIJAJoIAgUCYVkJAQJhdAEFAmNnBQZoZWlnaHQEAmJyCQELdmFsdWVPckVsc2UCCQCaCAIFAmFZCQECYXUBBQJjZwAABAJjagkAZAIFAmNpBQJicgQCY2sJAJYDAQkAzAgCCQBlAgUCY2oFBmhlaWdodAkAzAgCAAAFA25pbAQCY2wJAGQCBQJjaAUCYlYEAmNtCQCXAwEJAMwIAgkAZAIFAmNrBQJiVwkAzAgCBQJjZgUDbmlsBAJjbgkBAUIBCQCRAwIJAQF4AQkA/AcEBQJhWQITZ3d4VXNlckluZm9SRUFET05MWQkAzAgCBQJhSAUDbmlsBQNuaWwAAAQCY28JAJEDAgkBAmJwAwUCY2wFAmNtBQJjZgAABAJjcAoAAmJiCQD8BwQFAmFZAhlnZXRUb3RhbENhY2hlZEd3eFJFQURPTkxZBQNuaWwFA25pbAMJAAECBQJiYgIDSW50BQJiYgkAAgEJAKwCAgkAAwEFAmJiAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQEAmNxAOgHBAJjcgkAaAIJAQF3AgUCYVcJAQJhUAAFAmNxBAJjcwkBAmFHAgUCYUgFAmFJBAJjdAkBAmFKAQUCYUkEAmN1CQECYU4CBQJhTwUCY3MEAmN2CQECYU4CBQJhTwUCY3QEAmJoAwkBAiE9AgUCYUkFAmNlBAJiZgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFAmFVCQEBUAEFAmFJCQCsAgICFXVuc3VwcG9ydGVkIGxwIGFzc2V0IAUCYUkJARFAZXh0ck5hdGl2ZSgxMDUwKQIFAmFVCQEBVAEFAmJmAAAEAmN3CQBrAwUCY3IFAmJoCQBoAgUBZgUCY2MEAmN4AwkBAiE9AgUCY3YAAAkAawMFAmN3BQFiBQJjdgAABAJjeQkAawMFAmN4BQJjdQUBYgQCY3oJAGgCBQJjdwkAZQIFAmNjAAEEAmNBCQBrAwUCY24FAmN6BQJjcAQCY0IJAJcDAQkAzAgCBQJjQQkAzAgCCQBoAgUCY3kJAGUCBQJjYwABBQNuaWwEAmNDAwkAAAIFAmN5AAAJAGgCAAEFAWIJAGsDCQBkAgUCY0IFAmN5BQFiBQJjeQkAlAoCBQNuaWwJALkJAgkAzAgCAgYlZCVkJXMJAMwIAgkApAMBBQJjbwkAzAgCCQCkAwEFAmNDCQDMCAICAWQFA25pbAUBZQJiQgEXd3hFbWlzc2lvblN0YXRzUkVBRE9OTFkABAJjRAkApAMBBQFiBAJjRQIBMQQCYmkJAQF3AgUCYVcJAQJhUAAEAmNGCQEBdwIFAmFXCQECYVIABAJjRwMJAGYCBQJjRgUGaGVpZ2h0AAAJAGUCBQZoZWlnaHQFAmNGBAJjSAkAaAIAoAsA7QIEAmNJCQBoAgDAiOxfBQFiBAJjSgMJAGYCBQJjRwUCY0gFAmNJCQBrAwUCY0kFAmNHBQJjSAQCY0sJAGQCCQBoAgUCYmkFAmNHBQJjSgQCY0wJAQF2AgUCYVkJAQJhagAEAmNNCQEBdgIFAmFZCQECYWsABAJjTgkBAXYCBQJhWQkBAmFsAAkAlAoCBQNuaWwJALkJAgkAzAgCAgglZCVkJWQlZAkAzAgCCQCkAwEFAmNLCQDMCAIJAKQDAQUCY0wJAMwIAgkApAMBBQJjTQkAzAgCCQCkAwEFAmNOBQNuaWwFAWUCYkIBEXBvb2xTdGF0c1JFQURPTkxZAQJjTwQCYmEJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQF0AgUCYVUJAQFTAQUCY08EAmNQCgACYmIJAPwHBAUCYVUCFWdldFBvb2xTdGF0dXNSRUFET05MWQkAzAgCCQClCAEFAmJhBQNuaWwFA25pbAMJAAECBQJiYgIDSW50BQJiYgkAAgEJAKwCAgkAAwEFAmJiAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQEAmNRAhQlZCVkJWQlZCVkJWQlZCVkJWQlcwMJAAACBQJjUAAECQCUCgIFA25pbAkAuQkCCQDMCAIFAmNRCQDMCAIJAKQDAQAACQDMCAIJAKQDAQAACQDMCAIJAKQDAQAACQDMCAIJAKQDAQAACQDMCAIJAKQDAQAACQDMCAIJAKQDAQAACQDMCAIJAKQDAQAACQDMCAIJAKQDAQAACQDMCAIJAKQDAQAACQDMCAIJAKUDAQcFA25pbAUBZQQCY1IJAQF4AQkA/AcEBQJiYQIcZ2V0UG9vbENvbmZpZ1dyYXBwZXJSRUFET05MWQUDbmlsBQNuaWwEAmJlCQDZBAEJAQFEAQkAkQMCBQJjUgUBagQCY1MJAQFEAQkAkQMCBQJjUgUBawQCY1QJAQFEAQkAkQMCBQJjUgUBbAQCY1UJAQFEAQkAkQMCBQJjUgUBbwQCY1YJAQFEAQkAkQMCBQJjUgUBcAQCY1cJAQ1wYXJzZUludFZhbHVlAQkBAUQBCQCRAwIFAmNSBQFtBAJjWAkBDXBhcnNlSW50VmFsdWUBCQEBRAEJAJEDAgUCY1IFAW4EAmNZCAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQDsBwEFAmJlCQCsAgIJAKwCAgIGQXNzZXQgCQDYBAEFAmJlAg4gZG9lc24ndCBleGlzdAhxdWFudGl0eQQCY1oJAQFCAQkA/AcEBQJiYQIcZ2V0QWNjQmFsYW5jZVdyYXBwZXJSRUFET05MWQkAzAgCBQJjUwUDbmlsBQNuaWwEAmRhCQEBQgEJAPwHBAUCYmECHGdldEFjY0JhbGFuY2VXcmFwcGVyUkVBRE9OTFkJAMwIAgUCY1QFA25pbAUDbmlsBAJkYgMJAAACBQJjWQAACQDMCAIJAKYDAQUBZwkAzAgCCQCmAwEFAWcJAMwIAgkApgMBBQFnBQNuaWwJAQF4AQkA/AcEBQJiYQIZY2FsY1ByaWNlc1dyYXBwZXJSRUFET05MWQkAzAgCBQJjWgkAzAgCBQJkYQkAzAgCBQJjWQUDbmlsBQNuaWwEAmRjAAAEAmRkCQEBQgEJAPwHBAUCYmECFmZyb21YMThXcmFwcGVyUkVBRE9OTFkJAMwIAgkAkQMCBQJkYgABCQDMCAIFAWIFA25pbAUDbmlsBAJkZQkBAUIBCQD8BwQFAmJhAhZmcm9tWDE4V3JhcHBlclJFQURPTkxZCQDMCAIJAJEDAgUCZGIAAgkAzAgCBQFiBQNuaWwFA25pbAQCYmgJARFAZXh0ck5hdGl2ZSgxMDUwKQIFAmFVCQEBVAEJAKUIAQUCYmEEAmRmCQECYVoBBQJiYQQCZGcJAQJiYwEFAmJhBAJkaAoAAmJiCQD8BwQFAmFVAihpc1Bvb2xPbmVUb2tlbk9wZXJhdGlvbnNEaXNhYmxlZFJFQURPTkxZCQDMCAIJAKUIAQUCYmEFA25pbAUDbmlsAwkAAQIFAmJiAgdCb29sZWFuBQJiYgkAAgEJAKwCAgkAAwEFAmJiAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuBAJkaQkBASEBBQJkaAkAlAoCBQNuaWwJALkJAgkAzAgCBQJjUQkAzAgCCQCkAwEFAmNaCQDMCAIJAKQDAQUCZGEJAMwIAgkApAMBBQJjWQkAzAgCCQCkAwEFAmRjCQDMCAIJAKQDAQUCZGQJAMwIAgkApAMBBQJkZQkAzAgCCQCkAwEFAmJoCQDMCAIJAKQDAQUCZGYJAMwIAgkApAMBBQJkZwkAzAgCCQClAwEFAmRpBQNuaWwFAWUCYkIBJHBvb2xFdmFsdWF0ZVB1dEJ5QW1vdW50QXNzZXRSRUFET05MWQICY08CZGoEAmJhCQERQGV4dHJOYXRpdmUoMTA2MikBCQEBdAIFAmFVCQEBUwEFAmNPBAJjUgkBAXgBCQD8BwQFAmJhAhxnZXRQb29sQ29uZmlnV3JhcHBlclJFQURP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Al8yBAJkeQgFAmRJAl8zBAJkeggFAmRJAl80BAJkQQgFAmRJAl81BAJkYwgFAmRJAl82BAJkbwgFAmRJAl83CQCUCgIFA25pbAkAuQkCCQDMCAICDiVkJWQlZCVkJWQlZCVkCQDMCAIJAKQDAQUCZEoJAMwIAgkApAMBBQJkSwkAzAgCCQCkAwEFAmR5CQDMCAIJAKQDAQUCZHoJAMwIAgkApAMBBQJkQQkAzAgCBQJkYwkAzAgCBQJkbwUDbmlsBQFlAmJCARNnd3hVc2VySW5mb1JFQURPTkxZAQJhbwQCZEwJAQF4AQkA/AcEBQJhWQITZ3d4VXNlckluZm9SRUFET05MWQkAzAgCBQJhbwUDbmlsBQNuaWwEAmRNCQEBQgEJAJEDAgUCZEwAAAkAlAoCBQNuaWwJALkJAgkAzAgCAgIlZAkAzAgCCQCkAwEFAmRNBQNuaWwFAWUCYkIBFXVuc3Rha2VBbmRHZXRPbmVUa25WMgQCYmECZE4CZE8CZFAEAmNiCQD8BwQJARFAZXh0ck5hdGl2ZSgxMDYyKQEFAmJhAhV1bnN0YWtlQW5kR2V0T25lVGtuVjIJAMwIAgUCZE4JAMwIAgUCZE8JAMwIAgUCZFAFA25pbAUDbmlsAwkAAAIFAmNiBQJjYgkAlAoCBQNuaWwFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYkIBE2dldEtleXNCdWxrSW50ZXJuYWwDAmJPAmRRAmJVAwkAAAIFAmJPCQCQAwEFAmRRCQCUCgIFA25pbAUCYlUEAmRSCQC1CQIJAJEDAgUCZFEFAmJPAgIrKwQCYncJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAJEDAgUCZFIAAAQBcwkAkQMCBQJkUgABBAJieAkAkQMCBQJkUgACBAF5CQECYnYDBQJidwUBcwUCYngEAmNhCQDNCAIFAmJVBQF5BAJjYgkA/AcEBQR0aGlzAhNnZXRLZXlzQnVsa0ludGVybmFsCQDMCAIJAGQCBQJiTwABCQDMCAIFAmRRCQDMCAIFAmNhBQNuaWwFA25pbAMJAAACBQJjYgUCY2IJAJQKAgUDbmlsBQJjYgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJiQgELZ2V0S2V5c0J1bGsBAmRRBAJjYQkA/AcEBQR0aGlzAhNnZXRLZXlzQnVsa0ludGVybmFsCQDMCAIAAAkAzAgCBQJkUQkAzAgCBQNuaWwFA25pbAUDbmlsCQCUCgIFA25pbAUCY2EBAmRTAQJkVAAEAmRVBAF6CQECYnkAAwkAAQIFAXoCCkJ5dGVWZWN0b3IEAmJDBQF6BQJiQwMJAAECBQF6AgRVbml0CAUCZFMPc2VuZGVyUHVibGljS2V5CQACAQILTWF0Y2ggZXJyb3IJAPQDAwgFAmRTCWJvZHlCeXRlcwkAkQMCCAUCZFMGcHJvb2ZzAAAFAmRVKlLymg==", "height": 2714660, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 42L6Tm7NcZbaCt25UUHwfcTAmvW37Ms7U5GhsX5KJPLY Next: 9Y4qWsaqmDnRcXxdJeSz8TRMwAcVs45ZfvDm2Rh7RwdT Diff:
OldNewDifferences
531531 else throw(($getType(@) + " couldn't be cast to Boolean"))
532532 }
533533 let poolOneTokenOperationsEnabled = !(poolOneTokenOperationsDisabled)
534- let poolSwapEnabled = !({
535- let @ = invoke(factoryDapp, "isPoolSwapDisabledREADONLY", [toString(poolAddress)], nil)
536- if ($isInstanceOf(@, "Boolean"))
537- then @
538- else throw(($getType(@) + " couldn't be cast to Boolean"))
539- })
540- $Tuple2(nil, makeString([tpl, toString(accAmtAssetBalance), toString(accPriceAssetBalance), toString(poolLPBalance), toString(curPrice), toString(lpAmtAssetShare), toString(lpPriceAssetShare), toString(poolWeight), toString(inFee), toString(outFee), toString(poolOneTokenOperationsEnabled), toString(poolSwapEnabled)], SEP))
534+ $Tuple2(nil, makeString([tpl, toString(accAmtAssetBalance), toString(accPriceAssetBalance), toString(poolLPBalance), toString(curPrice), toString(lpAmtAssetShare), toString(lpPriceAssetShare), toString(poolWeight), toString(inFee), toString(outFee), toString(poolOneTokenOperationsEnabled)], SEP))
541535 }
542536 }
543537
568562 let inPrAssetAmtX18 = fraction(inAmAssetAmtX18, curPriceX18, MULT18)
569563 let inPrAssetAmt = asInt(invoke(poolAddress, "fromX18WrapperREADONLY", [toString(inPrAssetAmtX18), priceAssetDcm], nil))
570564 let res = invoke(poolAddress, "estimatePutOperationWrapperREADONLY", ["", 500000, inAmAssetAmt, amAssetId, inPrAssetAmt, prAssetId, "", true, false], nil)
571- let $t02285123204 = match res {
565+ let $t02269123044 = match res {
572566 case _ =>
573567 if (if (if ($isInstanceOf($match0._1, "Int"))
574568 then if ($isInstanceOf($match0._3, "Int"))
591585 }
592586 else throw("Couldn't cast types")
593587 }
594- let calcLpAmt = $t02285123204._1
595- let curPriceCalc = $t02285123204._2
596- let amBalance = $t02285123204._3
597- let prBalance = $t02285123204._4
598- let lpEmission = $t02285123204._5
588+ let calcLpAmt = $t02269123044._1
589+ let curPriceCalc = $t02269123044._2
590+ let amBalance = $t02269123044._3
591+ let prBalance = $t02269123044._4
592+ let lpEmission = $t02269123044._5
599593 $Tuple2(nil, makeString(["%d%d%d%d%d%d%d%d", toString(calcLpAmt), toString(curPrice), toString(amBalance), toString(prBalance), toString(lpEmission), poolStatus, toString(inAmAssetAmt), toString(inPrAssetAmt)], SEP))
600594 }
601595
626620 let inAmAssetAmtX18 = fraction(inPrAssetAmtX18, MULT18, curPriceX18)
627621 let inAmAssetAmt = asInt(invoke(poolAddress, "fromX18WrapperREADONLY", [toString(inAmAssetAmtX18), amtAssetDcm], nil))
628622 let res = invoke(poolAddress, "estimatePutOperationWrapperREADONLY", ["", 500000, inAmAssetAmt, amAssetId, inPrAssetAmt, prAssetId, "", true, false], nil)
629- let $t02577726130 = match res {
623+ let $t02561725970 = match res {
630624 case _ =>
631625 if (if (if ($isInstanceOf($match0._1, "Int"))
632626 then if ($isInstanceOf($match0._3, "Int"))
649643 }
650644 else throw("Couldn't cast types")
651645 }
652- let calcLpAmt = $t02577726130._1
653- let curPriceCalc = $t02577726130._2
654- let amBalance = $t02577726130._3
655- let prBalance = $t02577726130._4
656- let lpEmission = $t02577726130._5
646+ let calcLpAmt = $t02561725970._1
647+ let curPriceCalc = $t02561725970._2
648+ let amBalance = $t02561725970._3
649+ let prBalance = $t02561725970._4
650+ let lpEmission = $t02561725970._5
657651 $Tuple2(nil, makeString(["%d%d%d%d%d%d%d%d", toString(calcLpAmt), toString(curPrice), toString(amBalance), toString(prBalance), toString(lpEmission), poolStatus, toString(inAmAssetAmt), toString(inPrAssetAmt)], SEP))
658652 }
659653
663657 func poolEvaluateGetREADONLY (paymentLpAssetId,paymentLpAmt) = {
664658 let poolAddress = addressFromStringValue(getStringByAddressOrFail(factoryDapp, keyFactoryLpAssetToPoolContractAddress(paymentLpAssetId)))
665659 let res = invoke(poolAddress, "estimateGetOperationWrapperREADONLY", ["", paymentLpAssetId, paymentLpAmt, toString(poolAddress)], nil)
666- let $t02682527242 = match res {
660+ let $t02666527082 = match res {
667661 case _ =>
668662 if (if (if ($isInstanceOf($match0._1, "Int"))
669663 then if ($isInstanceOf($match0._2, "Int"))
692686 }
693687 else throw("Couldn't cast types")
694688 }
695- let outAmAmt = $t02682527242._1
696- let outPrAmt = $t02682527242._2
697- let amBalance = $t02682527242._3
698- let prBalance = $t02682527242._4
699- let lpEmission = $t02682527242._5
700- let curPrice = $t02682527242._6
701- let poolStatus = $t02682527242._7
689+ let outAmAmt = $t02666527082._1
690+ let outPrAmt = $t02666527082._2
691+ let amBalance = $t02666527082._3
692+ let prBalance = $t02666527082._4
693+ let lpEmission = $t02666527082._5
694+ let curPrice = $t02666527082._6
695+ let poolStatus = $t02666527082._7
702696 $Tuple2(nil, makeString(["%d%d%d%d%d%d%d", toString(outAmAmt), toString(outPrAmt), toString(amBalance), toString(prBalance), toString(lpEmission), curPrice, poolStatus], SEP))
703697 }
704698
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let SCALE8 = 8
55
66 let MULT8 = 100000000
77
88 let SCALE18 = 18
99
1010 let MULT18 = toBigInt(1000000000000000000)
1111
1212 let SEP = "__"
1313
1414 let POOLWEIGHTMULT = MULT8
1515
1616 let zeroBigInt = toBigInt(0)
1717
1818 let idxPoolAddress = 1
1919
2020 let idxPoolStatus = 2
2121
2222 let idxPoolLPAssetId = 3
2323
2424 let idxAmtAssetId = 4
2525
2626 let idxPriceAssetId = 5
2727
2828 let idxAmtAssetDcm = 6
2929
3030 let idxPriceAssetDcm = 7
3131
3232 let idxIAmtAssetId = 8
3333
3434 let idxIPriceAssetId = 9
3535
3636 let idxLPAssetDcm = 10
3737
3838 func getStringOrFail (key) = valueOrErrorMessage(getString(key), (("mandatory this." + key) + " is not defined"))
3939
4040
4141 func getStringByAddressOrFail (address,key) = valueOrErrorMessage(getString(address, key), (((("mandatory " + toString(address)) + ".") + key) + " is not defined"))
4242
4343
4444 func getIntOrZero (address,key) = valueOrElse(getInteger(address, key), 0)
4545
4646
4747 func getIntOrFail (address,key) = valueOrErrorMessage(getInteger(address, key), (("mandatory this." + key) + " is not defined"))
4848
4949
5050 func asAnyList (val) = match val {
5151 case valAnyLyst: List[Any] =>
5252 valAnyLyst
5353 case _ =>
5454 throw("fail to cast into List[Any]")
5555 }
5656
5757
5858 func asInt (val) = match val {
5959 case valInt: Int =>
6060 valInt
6161 case _ =>
6262 throw("fail to cast into Int")
6363 }
6464
6565
6666 func asString (val) = match val {
6767 case valStr: String =>
6868 valStr
6969 case _ =>
7070 throw("fail to cast into String")
7171 }
7272
7373
7474 func keyFactoryAddress () = "%s%s__config__factoryAddress"
7575
7676
7777 let IdxFactoryCfgStakingDapp = 1
7878
7979 let IdxFactoryCfgBoostingDapp = 2
8080
8181 let IdxFactoryCfgIdoDapp = 3
8282
8383 let IdxFactoryCfgTeamDapp = 4
8484
8585 let IdxFactoryCfgEmissionDapp = 5
8686
8787 let IdxFactoryCfgRestDapp = 6
8888
8989 let IdxFactoryCfgSlippageDapp = 7
9090
9191 let IdxFactoryCfgGwxRewardDapp = 8
9292
9393 func keyFactoryCfg () = "%s__factoryConfig"
9494
9595
9696 func keyFactoryLp2AssetsMapping (lpAssetStr) = makeString(["%s%s%s", lpAssetStr, "mappings__lpAsset2PoolContract"], SEP)
9797
9898
9999 func keyFactoryLpList () = "%s__lpTokensList"
100100
101101
102102 func keyFactoryLpAssetToPoolContractAddress (lpAssetStr) = makeString(["%s%s%s", lpAssetStr, "mappings__lpAsset2PoolContract"], SEP)
103103
104104
105105 func keyFactoryPoolWeight (contractAddress) = makeString(["%s%s", "poolWeight", contractAddress], SEP)
106106
107107
108108 func keyManagerVaultAddress () = "%s__managerVaultAddress"
109109
110110
111111 func keyManagerPublicKey () = "%s__managerPublicKey"
112112
113113
114114 func readFactoryAddressOrFail () = addressFromStringValue(getStringOrFail(keyFactoryAddress()))
115115
116116
117117 func readLpList () = split(valueOrElse(getString(readFactoryAddressOrFail(), keyFactoryLpList()), ""), SEP)
118118
119119
120120 func readFactoryCfgOrFail (factory) = split(getStringByAddressOrFail(factory, keyFactoryCfg()), SEP)
121121
122122
123123 func getBoostingAddressOrFail (fCfg) = addressFromStringValue(fCfg[IdxFactoryCfgBoostingDapp])
124124
125125
126126 func getEmissionAddressOrFail (fCfg) = addressFromStringValue(fCfg[IdxFactoryCfgEmissionDapp])
127127
128128
129129 func getStakingAddressOrFail (fCfg) = addressFromStringValue(fCfg[IdxFactoryCfgStakingDapp])
130130
131131
132132 func getGwxRewardAddressOrFail (fCfg) = addressFromStringValue(fCfg[IdxFactoryCfgGwxRewardDapp])
133133
134134
135135 func getManagerVaultAddressOrThis () = match getString(keyManagerVaultAddress()) {
136136 case s: String =>
137137 addressFromStringValue(s)
138138 case _ =>
139139 this
140140 }
141141
142142
143143 func keyBoostCfg () = "%s__config"
144144
145145
146146 func keyBoostingLockParamTotalAmount () = "%s%s__stats__activeTotalLocked"
147147
148148
149149 func keyBoostingStatsLocksDurationSumInBlocks () = "%s%s__stats__locksDurationSumInBlocks"
150150
151151
152152 func keyBoostingStatsLocksCount () = "%s%s__stats__locksCount"
153153
154154
155155 func keyBoostingStatsUsersCount () = "%s%s__stats__activeUsersCount"
156156
157157
158158 func keyUser2NumMapping (userAddress) = makeString(["%s%s%s__mapping__user2num", userAddress], SEP)
159159
160160
161161 func keyNum2UserMapping (num) = makeString(["%s%s%s__mapping__num2user", num], SEP)
162162
163163
164164 func keyLockParamUserAmount (userNum) = makeString(["%s%d%s__paramByUserNum", userNum, "amount"], SEP)
165165
166166
167167 func keyLockParamStartBlock (userNum) = makeString(["%s%d%s__paramByUserNum", userNum, "start"], SEP)
168168
169169
170170 func keyLockParamDuration (userNum) = makeString(["%s%d%s__paramByUserNum", userNum, "duration"], SEP)
171171
172172
173173 func keyLockParamK (userNum) = makeString(["%s%d%s__paramByUserNum", userNum, "k"], SEP)
174174
175175
176176 func keyLockParamB (userNum) = makeString(["%s%d%s__paramByUserNum", userNum, "b"], SEP)
177177
178178
179179 func keyLockParamByPeriodK (userNum,period) = makeString(["%s%d%s%d__paramByPeriod", userNum, "k", period], SEP)
180180
181181
182182 func keyLockParamByPeriodB (userNum,period) = makeString(["%s%d%s%d__paramByPeriod", userNum, "b", period], SEP)
183183
184184
185185 func keyUserBoostEmissionLastINTEGRAL (userNum) = makeString(["%s%d__userBoostEmissionLastInt", userNum], SEP)
186186
187187
188188 func keyUserMaxBoostINTEGRAL (userNum) = makeString(["%s%d__maxBoostInt", userNum], SEP)
189189
190190
191191 func keyTotalMaxBoostINTEGRAL () = "%s%s__maxBoostInt__total"
192192
193193
194194 func keyUserBoostAvalaibleToClaimTotal (userNum) = makeString(["%s%d__userBoostAvaliableToClaimTotal", userNum], SEP)
195195
196196
197197 func keyUserBoostClaimed (userNum) = makeString(["%s%d__userBoostClaimed", userNum], SEP)
198198
199199
200200 func keyTotalCachedGwx () = "%s%s__gwxCached__total"
201201
202202
203203 func keyStakedByUser (userAddressStr,lpAssetIdStr) = makeString(["%s%s%s__staked", userAddressStr, lpAssetIdStr], SEP)
204204
205205
206206 func keyStakedTotal (lpAssetIdStr) = ("%s%s%s__staked__total__" + lpAssetIdStr)
207207
208208
209209 func keyClaimedByUser (lpAssetIdStr,userAddressStr) = makeString(["%s%s%s__claimed", userAddressStr, lpAssetIdStr], SEP)
210210
211211
212212 func keyClaimedByUserMinReward (lpAssetIdStr,userAddressStr) = makeString(["%s%s%s__claimedMinReward", userAddressStr, lpAssetIdStr], SEP)
213213
214214
215215 func keyClaimedByUserBoostReward (lpAssetIdStr,userAddressStr) = makeString(["%s%s%s__claimedBoostReward", userAddressStr, lpAssetIdStr], SEP)
216216
217217
218218 func readStaked (stakingDapp,key) = valueOrElse(getInteger(stakingDapp, key), 0)
219219
220220
221221 func keyEmissionRatePerBlockCurrent () = "%s%s__ratePerBlock__current"
222222
223223
224224 func keyEmissionRatePerBlockMaxCurrent () = "%s%s__ratePerBlockMax__current"
225225
226226
227227 func keyEmissionStartBlock () = "%s%s__emission__startBlock"
228228
229229
230230 func keyEmissionDurationInBlocks () = "%s%s__emission__duration"
231231
232232
233233 func keyEmissionEndBlock () = "%s%s__emission__endBlock"
234234
235235
236236 let factoryDapp = readFactoryAddressOrFail()
237237
238238 let factoryCfg = readFactoryCfgOrFail(factoryDapp)
239239
240240 let emissionDapp = getEmissionAddressOrFail(factoryCfg)
241241
242242 let stakingDapp = getStakingAddressOrFail(factoryCfg)
243243
244244 let gwxRewardDapp = getGwxRewardAddressOrFail(factoryCfg)
245245
246246 let boostingDapp = getBoostingAddressOrFail(factoryCfg)
247247
248248 func getPoolInFee (poolAddress) = {
249249 let @ = invoke(factoryDapp, "getInFeeREADONLY", [toString(poolAddress)], nil)
250250 if ($isInstanceOf(@, "Int"))
251251 then @
252252 else throw(($getType(@) + " couldn't be cast to Int"))
253253 }
254254
255255
256256 func getPoolOutFee (poolAddress) = {
257257 let @ = invoke(factoryDapp, "getOutFeeREADONLY", [toString(poolAddress)], nil)
258258 if ($isInstanceOf(@, "Int"))
259259 then @
260260 else throw(($getType(@) + " couldn't be cast to Int"))
261261 }
262262
263263
264264 func internalCurrentRewardRate (lpAssetId) = {
265265 let poolAddressStr = getStringByAddressOrFail(factoryDapp, keyFactoryLpAssetToPoolContractAddress(lpAssetId))
266266 let poolWeightMult = MULT8
267267 let poolWeight = getIntegerValue(factoryDapp, keyFactoryPoolWeight(poolAddressStr))
268268 let wxEmissionPerBlock = getIntOrFail(emissionDapp, keyEmissionRatePerBlockCurrent())
269269 let wxEmissionPerBlockMax = getIntOrFail(emissionDapp, keyEmissionRatePerBlockMaxCurrent())
270270 let boostMaxCoeff = {
271271 let @ = invoke(emissionDapp, "getBoostCoeffREADONLY", nil, nil)
272272 if ($isInstanceOf(@, "Int"))
273273 then @
274274 else throw(($getType(@) + " couldn't be cast to Int"))
275275 }
276276 let poolWxEmissionPerBlock = (fraction(wxEmissionPerBlock, poolWeight, poolWeightMult) / boostMaxCoeff)
277277 let poolWxEmissionPerBlockMax = fraction(wxEmissionPerBlockMax, poolWeight, poolWeightMult)
278278 let maxFactor = (boostMaxCoeff * MULT8)
279279 let totalLpStaked = getIntOrZero(stakingDapp, keyStakedTotal(lpAssetId))
280280 [poolWxEmissionPerBlock, maxFactor, totalLpStaked]
281281 }
282282
283283
284284 func calcGwxAmountStartREADONLY (lockAmount,lockDuration,maxLockDuration) = {
285285 let coeffX8 = fraction(lockDuration, MULT8, maxLockDuration)
286286 let gWxAmountStart = fraction(lockAmount, coeffX8, MULT8)
287287 [gWxAmountStart]
288288 }
289289
290290
291291 func getKey (addr,key,type) = if ((type == "string"))
292292 then getStringValue(addr, key)
293293 else if ((type == "integer"))
294294 then toString(getIntegerValue(addr, key))
295295 else if ((type == "boolean"))
296296 then toString(getBooleanValue(addr, key))
297297 else throw("unknown type. expected string/integer/boolean")
298298
299299
300300 func managerPublicKeyOrUnit () = {
301301 let managerVaultAddress = getManagerVaultAddressOrThis()
302302 match getString(managerVaultAddress, keyManagerPublicKey()) {
303303 case s: String =>
304304 fromBase58String(s)
305305 case _: Unit =>
306306 unit
307307 case _ =>
308308 throw("Match error")
309309 }
310310 }
311311
312312
313313 func isManager (i) = match managerPublicKeyOrUnit() {
314314 case pk: ByteVector =>
315315 (i.callerPublicKey == pk)
316316 case _: Unit =>
317317 (i.caller == this)
318318 case _ =>
319319 throw("Match error")
320320 }
321321
322322
323323 func mustManager (i) = if (isManager(i))
324324 then true
325325 else throw("permission denied")
326326
327327
328328 @Callable(i)
329329 func constructor (factoryAddress) = {
330330 let checkCaller = mustManager(i)
331331 if ((checkCaller == checkCaller))
332332 then [StringEntry(keyFactoryAddress(), factoryAddress)]
333333 else throw("Strict value is not equal to itself.")
334334 }
335335
336336
337337
338338 @Callable(i)
339339 func currentRewardRateREADONLY (lpAssetId) = {
340340 let rewardData = internalCurrentRewardRate(lpAssetId)
341341 let wxEmissionPerBlock = rewardData[0]
342342 let maxFactor = rewardData[1]
343343 let totalLpStaked = rewardData[2]
344344 let votingResultStaked = {
345345 let @ = invoke(boostingDapp, "getVotingResultStakedREADONLY", [lpAssetId], nil)
346346 if ($isInstanceOf(@, "Int"))
347347 then @
348348 else throw(($getType(@) + " couldn't be cast to Int"))
349349 }
350350 $Tuple2(nil, makeString(["%d%d%d%d", toString(wxEmissionPerBlock), toString(maxFactor), toString(totalLpStaked), toString(votingResultStaked)], SEP))
351351 }
352352
353353
354354
355355 @Callable(i)
356356 func currentUserRewardRateREADONLY (lpAssetId,userAddress) = {
357357 let rewardData = internalCurrentRewardRate(lpAssetId)
358358 let wxEmissionPerBlock = rewardData[0]
359359 let maxFactor = rewardData[1]
360360 let totalLpStaked = rewardData[2]
361361 let lpStakedByUser = getIntOrZero(stakingDapp, keyStakedByUser(userAddress, lpAssetId))
362362 let userClaimInfo = split(asString(invoke(stakingDapp, "claimWxREADONLY", [lpAssetId, userAddress], nil)), SEP)
363363 let minRewardPart = valueOrErrorMessage(parseInt(userClaimInfo[5]), "couldn't parse minRewardPart")
364364 let boostRewardPart = valueOrErrorMessage(parseInt(userClaimInfo[6]), "couldn't parse boostRewardPart")
365365 let debug = userClaimInfo[7]
366366 let boostingPower = if ((boostRewardPart == 0))
367367 then (1 * MULT8)
368368 else fraction((minRewardPart + boostRewardPart), MULT8, minRewardPart)
369369 $Tuple2(nil, makeString(["%d%d%d%d%d%s", toString(wxEmissionPerBlock), toString(maxFactor), toString(totalLpStaked), toString(lpStakedByUser), toString(boostingPower), debug], SEP))
370370 }
371371
372372
373373
374374 @Callable(i)
375375 func calcBoostBulkInternalREADONLY (currentIter,deltaWxAmountBulk,deltaLockPeriodInBlocksBulk,deltaLpAmountBulk,lpAssetIdOptBulk,userAddressOpt,resAcc) = if ((currentIter == size(deltaWxAmountBulk)))
376376 then $Tuple2(nil, resAcc)
377377 else {
378378 let deltaWxAmount = deltaWxAmountBulk[currentIter]
379379 let deltaLockPeriodInBlocks = deltaLockPeriodInBlocksBulk[currentIter]
380380 let deltaLpAmount = deltaLpAmountBulk[currentIter]
381381 let lpAssetIdOpt = lpAssetIdOptBulk[currentIter]
382382 let info = {
383383 let @ = invoke(this, "calcBoostREADONLY", [deltaWxAmount, deltaLockPeriodInBlocks, deltaLpAmount, lpAssetIdOpt, userAddressOpt], nil)
384384 if ($isInstanceOf(@, "String"))
385385 then @
386386 else throw(($getType(@) + " couldn't be cast to String"))
387387 }
388388 let res = (resAcc :+ info)
389389 let inv = {
390390 let @ = invoke(this, "calcBoostBulkInternalREADONLY", [(currentIter + 1), deltaWxAmountBulk, deltaLockPeriodInBlocksBulk, deltaLpAmountBulk, lpAssetIdOptBulk, userAddressOpt, res], nil)
391391 if ($isInstanceOf(@, "List[Any]"))
392392 then @
393393 else throw(($getType(@) + " couldn't be cast to List[Any]"))
394394 }
395395 if ((inv == inv))
396396 then $Tuple2(nil, inv)
397397 else throw("Strict value is not equal to itself.")
398398 }
399399
400400
401401
402402 @Callable(i)
403403 func calcBoostBulkREADONLY (deltaWxAmount,deltaLockPeriodInBlocks,deltaLpAmount,lpAssetIdOpt,userAddressOpt) = {
404404 let res = invoke(this, "calcBoostBulkInternalREADONLY", [0, deltaWxAmount, deltaLockPeriodInBlocks, deltaLpAmount, lpAssetIdOpt, userAddressOpt, nil], nil)
405405 $Tuple2(nil, res)
406406 }
407407
408408
409409
410410 @Callable(i)
411411 func calcBoostREADONLY (deltaWxAmount,deltaLockPeriodInBlocks,deltaLpAmount,lpAssetIdOpt,userAddressOpt) = {
412412 let boostCoeff = {
413413 let @ = invoke(emissionDapp, "getBoostCoeffREADONLY", nil, nil)
414414 if ($isInstanceOf(@, "Int"))
415415 then @
416416 else throw(($getType(@) + " couldn't be cast to Int"))
417417 }
418418 let mathDapp = gwxRewardDapp
419419 let EMPTYSTR = "empty"
420420 let maxLockDurationInBlocks = parseIntValue(split(getStringByAddressOrFail(boostingDapp, keyBoostCfg()), SEP)[4])
421421 let lpAssetIdStr = if ((lpAssetIdOpt == ""))
422422 then EMPTYSTR
423423 else lpAssetIdOpt
424424 let userAddressStr = if ((userAddressOpt == ""))
425425 then EMPTYSTR
426426 else userAddressOpt
427427 let userNumStr = valueOrElse(getString(boostingDapp, keyUser2NumMapping(userAddressOpt)), EMPTYSTR)
428428 let userAmount = valueOrElse(getInteger(boostingDapp, keyLockParamUserAmount(userNumStr)), 0)
429429 let lockStart = valueOrElse(getInteger(boostingDapp, keyLockParamStartBlock(userNumStr)), height)
430430 let lockDuration = valueOrElse(getInteger(boostingDapp, keyLockParamDuration(userNumStr)), 0)
431431 let lockEnd = (lockStart + lockDuration)
432432 let remainingDuration = max([(lockEnd - height), 0])
433433 let userAmountNew = (userAmount + deltaWxAmount)
434434 let lockDurationNew = min([(remainingDuration + deltaLockPeriodInBlocks), maxLockDurationInBlocks])
435435 let userCurrgWxAmount = asInt(asAnyList(invoke(boostingDapp, "gwxUserInfoREADONLY", [userAddressStr], nil))[0])
436436 let gWxAmountStartNew = calcGwxAmountStartREADONLY(userAmountNew, lockDurationNew, maxLockDurationInBlocks)[0]
437437 let totalCachedGwx = {
438438 let @ = invoke(boostingDapp, "getTotalCachedGwxREADONLY", nil, nil)
439439 if ($isInstanceOf(@, "Int"))
440440 then @
441441 else throw(($getType(@) + " couldn't be cast to Int"))
442442 }
443443 let MULT3 = 1000
444444 let wxEmissionPerBlockX3 = (getIntOrFail(emissionDapp, keyEmissionRatePerBlockCurrent()) * MULT3)
445445 let stakedByUserKEY = keyStakedByUser(userAddressStr, lpAssetIdStr)
446446 let stakedTotalKEY = keyStakedTotal(lpAssetIdStr)
447447 let stakedByUser = readStaked(stakingDapp, stakedByUserKEY)
448448 let stakedTotal = readStaked(stakingDapp, stakedTotalKEY)
449449 let poolWeight = if ((lpAssetIdStr != EMPTYSTR))
450450 then {
451451 let poolAddressStr = valueOrErrorMessage(getString(factoryDapp, keyFactoryLp2AssetsMapping(lpAssetIdStr)), ("unsupported lp asset " + lpAssetIdStr))
452452 getIntegerValue(factoryDapp, keyFactoryPoolWeight(poolAddressStr))
453453 }
454454 else 0
455455 let poolWxEmissionPerBlockX3 = fraction(wxEmissionPerBlockX3, poolWeight, (POOLWEIGHTMULT * boostCoeff))
456456 let wxPerLpX3 = if ((stakedTotal != 0))
457457 then fraction(poolWxEmissionPerBlockX3, MULT8, stakedTotal)
458458 else 0
459459 let userWxPerBlockX3 = fraction(wxPerLpX3, stakedByUser, MULT8)
460460 let boostEmissionPerBlockX3 = (poolWxEmissionPerBlockX3 * (boostCoeff - 1))
461461 let tmpUserBoostPerBlockX3 = fraction(userCurrgWxAmount, boostEmissionPerBlockX3, totalCachedGwx)
462462 let userBoostPerBlockX3 = min([tmpUserBoostPerBlockX3, (userWxPerBlockX3 * (boostCoeff - 1))])
463463 let userBoostCoeff = if ((userWxPerBlockX3 == 0))
464464 then (1 * MULT8)
465465 else fraction((userBoostPerBlockX3 + userWxPerBlockX3), MULT8, userWxPerBlockX3)
466466 $Tuple2(nil, makeString(["%d%d%s", toString(gWxAmountStartNew), toString(userBoostCoeff), "d"], SEP))
467467 }
468468
469469
470470
471471 @Callable(i)
472472 func wxEmissionStatsREADONLY () = {
473473 let ONEMULT = toString(MULT8)
474474 let ONE = "1"
475475 let wxEmissionPerBlock = getIntOrFail(emissionDapp, keyEmissionRatePerBlockCurrent())
476476 let emissionStartBlock = getIntOrFail(emissionDapp, keyEmissionStartBlock())
477477 let passedBlocks = if ((emissionStartBlock > height))
478478 then 0
479479 else (height - emissionStartBlock)
480480 let teamEmDuration = (1440 * 365)
481481 let teamEmMax = (201000000 * MULT8)
482482 let teamEm = if ((passedBlocks > teamEmDuration))
483483 then teamEmMax
484484 else fraction(teamEmMax, passedBlocks, teamEmDuration)
485485 let totalWxReleased = ((wxEmissionPerBlock * passedBlocks) + teamEm)
486486 let totalWxLocked = getIntOrZero(boostingDapp, keyBoostingLockParamTotalAmount())
487487 let locksDurationSumInBlocks = getIntOrZero(boostingDapp, keyBoostingStatsLocksDurationSumInBlocks())
488488 let locksCount = getIntOrZero(boostingDapp, keyBoostingStatsLocksCount())
489489 $Tuple2(nil, makeString(["%d%d%d%d", toString(totalWxReleased), toString(totalWxLocked), toString(locksDurationSumInBlocks), toString(locksCount)], SEP))
490490 }
491491
492492
493493
494494 @Callable(i)
495495 func poolStatsREADONLY (lpAsset) = {
496496 let poolAddress = addressFromStringValue(getStringByAddressOrFail(factoryDapp, keyFactoryLpAssetToPoolContractAddress(lpAsset)))
497497 let status = {
498498 let @ = invoke(factoryDapp, "getPoolStatusREADONLY", [toString(poolAddress)], nil)
499499 if ($isInstanceOf(@, "Int"))
500500 then @
501501 else throw(($getType(@) + " couldn't be cast to Int"))
502502 }
503503 let tpl = "%d%d%d%d%d%d%d%d%d%s"
504504 if ((status == 4))
505505 then $Tuple2(nil, makeString([tpl, toString(0), toString(0), toString(0), toString(0), toString(0), toString(0), toString(0), toString(0), toString(0), toString(false)], SEP))
506506 else {
507507 let cfg = asAnyList(invoke(poolAddress, "getPoolConfigWrapperREADONLY", nil, nil))
508508 let lpAssetId = fromBase58String(asString(cfg[idxPoolLPAssetId]))
509509 let amtAssetId = asString(cfg[idxAmtAssetId])
510510 let priceAssetId = asString(cfg[idxPriceAssetId])
511511 let iAmtAssetId = asString(cfg[idxIAmtAssetId])
512512 let iPriceAssetId = asString(cfg[idxIPriceAssetId])
513513 let amtAssetDcm = parseIntValue(asString(cfg[idxAmtAssetDcm]))
514514 let priceAssetDcm = parseIntValue(asString(cfg[idxPriceAssetDcm]))
515515 let poolLPBalance = valueOrErrorMessage(assetInfo(lpAssetId), (("Asset " + toBase58String(lpAssetId)) + " doesn't exist")).quantity
516516 let accAmtAssetBalance = asInt(invoke(poolAddress, "getAccBalanceWrapperREADONLY", [amtAssetId], nil))
517517 let accPriceAssetBalance = asInt(invoke(poolAddress, "getAccBalanceWrapperREADONLY", [priceAssetId], nil))
518518 let pricesList = if ((poolLPBalance == 0))
519519 then [toString(zeroBigInt), toString(zeroBigInt), toString(zeroBigInt)]
520520 else asAnyList(invoke(poolAddress, "calcPricesWrapperREADONLY", [accAmtAssetBalance, accPriceAssetBalance, poolLPBalance], nil))
521521 let curPrice = 0
522522 let lpAmtAssetShare = asInt(invoke(poolAddress, "fromX18WrapperREADONLY", [pricesList[1], MULT8], nil))
523523 let lpPriceAssetShare = asInt(invoke(poolAddress, "fromX18WrapperREADONLY", [pricesList[2], MULT8], nil))
524524 let poolWeight = getIntegerValue(factoryDapp, keyFactoryPoolWeight(toString(poolAddress)))
525525 let inFee = getPoolInFee(poolAddress)
526526 let outFee = getPoolOutFee(poolAddress)
527527 let poolOneTokenOperationsDisabled = {
528528 let @ = invoke(factoryDapp, "isPoolOneTokenOperationsDisabledREADONLY", [toString(poolAddress)], nil)
529529 if ($isInstanceOf(@, "Boolean"))
530530 then @
531531 else throw(($getType(@) + " couldn't be cast to Boolean"))
532532 }
533533 let poolOneTokenOperationsEnabled = !(poolOneTokenOperationsDisabled)
534- let poolSwapEnabled = !({
535- let @ = invoke(factoryDapp, "isPoolSwapDisabledREADONLY", [toString(poolAddress)], nil)
536- if ($isInstanceOf(@, "Boolean"))
537- then @
538- else throw(($getType(@) + " couldn't be cast to Boolean"))
539- })
540- $Tuple2(nil, makeString([tpl, toString(accAmtAssetBalance), toString(accPriceAssetBalance), toString(poolLPBalance), toString(curPrice), toString(lpAmtAssetShare), toString(lpPriceAssetShare), toString(poolWeight), toString(inFee), toString(outFee), toString(poolOneTokenOperationsEnabled), toString(poolSwapEnabled)], SEP))
534+ $Tuple2(nil, makeString([tpl, toString(accAmtAssetBalance), toString(accPriceAssetBalance), toString(poolLPBalance), toString(curPrice), toString(lpAmtAssetShare), toString(lpPriceAssetShare), toString(poolWeight), toString(inFee), toString(outFee), toString(poolOneTokenOperationsEnabled)], SEP))
541535 }
542536 }
543537
544538
545539
546540 @Callable(i)
547541 func poolEvaluatePutByAmountAssetREADONLY (lpAsset,inAmAssetAmt) = {
548542 let poolAddress = addressFromStringValue(getStringByAddressOrFail(factoryDapp, keyFactoryLpAssetToPoolContractAddress(lpAsset)))
549543 let cfg = asAnyList(invoke(poolAddress, "getPoolConfigWrapperREADONLY", nil, nil))
550544 let lpAssetId = fromBase58String(asString(cfg[idxPoolLPAssetId]))
551545 let amAssetIdStr = asString(cfg[idxAmtAssetId])
552546 let amAssetId = fromBase58String(amAssetIdStr)
553547 let prAssetIdStr = asString(cfg[idxPriceAssetId])
554548 let prAssetId = fromBase58String(prAssetIdStr)
555549 let amtAssetDcm = parseIntValue(asString(cfg[idxAmtAssetDcm]))
556550 let priceAssetDcm = parseIntValue(asString(cfg[idxPriceAssetDcm]))
557551 let poolStatus = asString(cfg[idxPoolStatus])
558552 let poolLPBalance = valueOrErrorMessage(assetInfo(lpAssetId), (("Asset " + toBase58String(lpAssetId)) + " doesn't exist")).quantity
559553 let accAmtAssetBalance = asInt(invoke(poolAddress, "getAccBalanceWrapperREADONLY", [amAssetIdStr], nil))
560554 let accPriceAssetBalance = asInt(invoke(poolAddress, "getAccBalanceWrapperREADONLY", [prAssetIdStr], nil))
561555 let amtAssetAmtX18 = parseBigIntValue(asString(invoke(poolAddress, "toX18WrapperREADONLY", [accAmtAssetBalance, amtAssetDcm], nil)))
562556 let priceAssetAmtX18 = parseBigIntValue(asString(invoke(poolAddress, "toX18WrapperREADONLY", [accPriceAssetBalance, priceAssetDcm], nil)))
563557 let curPriceX18 = if ((poolLPBalance == 0))
564558 then zeroBigInt
565559 else parseBigIntValue(asString(invoke(poolAddress, "calcPriceBigIntWrapperREADONLY", [toString(priceAssetAmtX18), toString(amtAssetAmtX18)], nil)))
566560 let curPrice = asInt(invoke(poolAddress, "fromX18WrapperREADONLY", [toString(curPriceX18), MULT8], nil))
567561 let inAmAssetAmtX18 = parseBigIntValue(asString(invoke(poolAddress, "toX18WrapperREADONLY", [inAmAssetAmt, amtAssetDcm], nil)))
568562 let inPrAssetAmtX18 = fraction(inAmAssetAmtX18, curPriceX18, MULT18)
569563 let inPrAssetAmt = asInt(invoke(poolAddress, "fromX18WrapperREADONLY", [toString(inPrAssetAmtX18), priceAssetDcm], nil))
570564 let res = invoke(poolAddress, "estimatePutOperationWrapperREADONLY", ["", 500000, inAmAssetAmt, amAssetId, inPrAssetAmt, prAssetId, "", true, false], nil)
571- let $t02285123204 = match res {
565+ let $t02269123044 = match res {
572566 case _ =>
573567 if (if (if ($isInstanceOf($match0._1, "Int"))
574568 then if ($isInstanceOf($match0._3, "Int"))
575569 then if ($isInstanceOf($match0._4, "Int"))
576570 then if ($isInstanceOf($match0._5, "Int"))
577571 then $isInstanceOf($match0._6, "Int")
578572 else false
579573 else false
580574 else false
581575 else false)
582576 then (size($match0) == 13)
583577 else false)
584578 then {
585579 let calcLpAmt = $match0._1
586580 let curPriceCalc = $match0._3
587581 let amBalance = $match0._4
588582 let prBalance = $match0._5
589583 let lpEmission = $match0._6
590584 $Tuple5(calcLpAmt, curPriceCalc, amBalance, prBalance, lpEmission)
591585 }
592586 else throw("Couldn't cast types")
593587 }
594- let calcLpAmt = $t02285123204._1
595- let curPriceCalc = $t02285123204._2
596- let amBalance = $t02285123204._3
597- let prBalance = $t02285123204._4
598- let lpEmission = $t02285123204._5
588+ let calcLpAmt = $t02269123044._1
589+ let curPriceCalc = $t02269123044._2
590+ let amBalance = $t02269123044._3
591+ let prBalance = $t02269123044._4
592+ let lpEmission = $t02269123044._5
599593 $Tuple2(nil, makeString(["%d%d%d%d%d%d%d%d", toString(calcLpAmt), toString(curPrice), toString(amBalance), toString(prBalance), toString(lpEmission), poolStatus, toString(inAmAssetAmt), toString(inPrAssetAmt)], SEP))
600594 }
601595
602596
603597
604598 @Callable(i)
605599 func poolEvaluatePutByPriceAssetREADONLY (lpAsset,inPrAssetAmt) = {
606600 let poolAddress = addressFromStringValue(getStringByAddressOrFail(factoryDapp, keyFactoryLpAssetToPoolContractAddress(lpAsset)))
607601 let cfg = asAnyList(invoke(poolAddress, "getPoolConfigWrapperREADONLY", nil, nil))
608602 let lpAssetId = fromBase58String(asString(cfg[idxPoolLPAssetId]))
609603 let amAssetIdStr = asString(cfg[idxAmtAssetId])
610604 let amAssetId = fromBase58String(amAssetIdStr)
611605 let prAssetIdStr = asString(cfg[idxPriceAssetId])
612606 let prAssetId = fromBase58String(prAssetIdStr)
613607 let amtAssetDcm = parseIntValue(asString(cfg[idxAmtAssetDcm]))
614608 let priceAssetDcm = parseIntValue(asString(cfg[idxPriceAssetDcm]))
615609 let poolStatus = asString(cfg[idxPoolStatus])
616610 let poolLPBalance = valueOrErrorMessage(assetInfo(lpAssetId), (("Asset " + toBase58String(lpAssetId)) + " doesn't exist")).quantity
617611 let amBalanceRaw = asInt(invoke(poolAddress, "getAccBalanceWrapperREADONLY", [amAssetIdStr], nil))
618612 let prBalanceRaw = asInt(invoke(poolAddress, "getAccBalanceWrapperREADONLY", [prAssetIdStr], nil))
619613 let amBalanceRawX18 = parseBigIntValue(asString(invoke(poolAddress, "toX18WrapperREADONLY", [amBalanceRaw, amtAssetDcm], nil)))
620614 let prBalanceRawX18 = parseBigIntValue(asString(invoke(poolAddress, "toX18WrapperREADONLY", [prBalanceRaw, priceAssetDcm], nil)))
621615 let curPriceX18 = if ((poolLPBalance == 0))
622616 then zeroBigInt
623617 else parseBigIntValue(asString(invoke(poolAddress, "calcPriceBigIntWrapperREADONLY", [toString(prBalanceRawX18), toString(amBalanceRawX18)], nil)))
624618 let curPrice = asInt(invoke(poolAddress, "fromX18WrapperREADONLY", [toString(curPriceX18), MULT8], nil))
625619 let inPrAssetAmtX18 = parseBigIntValue(asString(invoke(poolAddress, "toX18WrapperREADONLY", [inPrAssetAmt, priceAssetDcm], nil)))
626620 let inAmAssetAmtX18 = fraction(inPrAssetAmtX18, MULT18, curPriceX18)
627621 let inAmAssetAmt = asInt(invoke(poolAddress, "fromX18WrapperREADONLY", [toString(inAmAssetAmtX18), amtAssetDcm], nil))
628622 let res = invoke(poolAddress, "estimatePutOperationWrapperREADONLY", ["", 500000, inAmAssetAmt, amAssetId, inPrAssetAmt, prAssetId, "", true, false], nil)
629- let $t02577726130 = match res {
623+ let $t02561725970 = match res {
630624 case _ =>
631625 if (if (if ($isInstanceOf($match0._1, "Int"))
632626 then if ($isInstanceOf($match0._3, "Int"))
633627 then if ($isInstanceOf($match0._4, "Int"))
634628 then if ($isInstanceOf($match0._5, "Int"))
635629 then $isInstanceOf($match0._6, "Int")
636630 else false
637631 else false
638632 else false
639633 else false)
640634 then (size($match0) == 13)
641635 else false)
642636 then {
643637 let calcLpAmt = $match0._1
644638 let curPriceCalc = $match0._3
645639 let amBalance = $match0._4
646640 let prBalance = $match0._5
647641 let lpEmission = $match0._6
648642 $Tuple5(calcLpAmt, curPriceCalc, amBalance, prBalance, lpEmission)
649643 }
650644 else throw("Couldn't cast types")
651645 }
652- let calcLpAmt = $t02577726130._1
653- let curPriceCalc = $t02577726130._2
654- let amBalance = $t02577726130._3
655- let prBalance = $t02577726130._4
656- let lpEmission = $t02577726130._5
646+ let calcLpAmt = $t02561725970._1
647+ let curPriceCalc = $t02561725970._2
648+ let amBalance = $t02561725970._3
649+ let prBalance = $t02561725970._4
650+ let lpEmission = $t02561725970._5
657651 $Tuple2(nil, makeString(["%d%d%d%d%d%d%d%d", toString(calcLpAmt), toString(curPrice), toString(amBalance), toString(prBalance), toString(lpEmission), poolStatus, toString(inAmAssetAmt), toString(inPrAssetAmt)], SEP))
658652 }
659653
660654
661655
662656 @Callable(i)
663657 func poolEvaluateGetREADONLY (paymentLpAssetId,paymentLpAmt) = {
664658 let poolAddress = addressFromStringValue(getStringByAddressOrFail(factoryDapp, keyFactoryLpAssetToPoolContractAddress(paymentLpAssetId)))
665659 let res = invoke(poolAddress, "estimateGetOperationWrapperREADONLY", ["", paymentLpAssetId, paymentLpAmt, toString(poolAddress)], nil)
666- let $t02682527242 = match res {
660+ let $t02666527082 = match res {
667661 case _ =>
668662 if (if (if ($isInstanceOf($match0._1, "Int"))
669663 then if ($isInstanceOf($match0._2, "Int"))
670664 then if ($isInstanceOf($match0._5, "Int"))
671665 then if ($isInstanceOf($match0._6, "Int"))
672666 then if ($isInstanceOf($match0._7, "Int"))
673667 then if ($isInstanceOf($match0._8, "String"))
674668 then $isInstanceOf($match0._9, "String")
675669 else false
676670 else false
677671 else false
678672 else false
679673 else false
680674 else false)
681675 then (size($match0) == 10)
682676 else false)
683677 then {
684678 let outAmAmt = $match0._1
685679 let outPrAmt = $match0._2
686680 let amBalance = $match0._5
687681 let prBalance = $match0._6
688682 let lpEmission = $match0._7
689683 let curPrice = $match0._8
690684 let poolStatus = $match0._9
691685 $Tuple7(outAmAmt, outPrAmt, amBalance, prBalance, lpEmission, curPrice, poolStatus)
692686 }
693687 else throw("Couldn't cast types")
694688 }
695- let outAmAmt = $t02682527242._1
696- let outPrAmt = $t02682527242._2
697- let amBalance = $t02682527242._3
698- let prBalance = $t02682527242._4
699- let lpEmission = $t02682527242._5
700- let curPrice = $t02682527242._6
701- let poolStatus = $t02682527242._7
689+ let outAmAmt = $t02666527082._1
690+ let outPrAmt = $t02666527082._2
691+ let amBalance = $t02666527082._3
692+ let prBalance = $t02666527082._4
693+ let lpEmission = $t02666527082._5
694+ let curPrice = $t02666527082._6
695+ let poolStatus = $t02666527082._7
702696 $Tuple2(nil, makeString(["%d%d%d%d%d%d%d", toString(outAmAmt), toString(outPrAmt), toString(amBalance), toString(prBalance), toString(lpEmission), curPrice, poolStatus], SEP))
703697 }
704698
705699
706700
707701 @Callable(i)
708702 func gwxUserInfoREADONLY (userAddress) = {
709703 let gwxUserInfoLIST = asAnyList(invoke(boostingDapp, "gwxUserInfoREADONLY", [userAddress], nil))
710704 let gwxAmount = asInt(gwxUserInfoLIST[0])
711705 $Tuple2(nil, makeString(["%d", toString(gwxAmount)], SEP))
712706 }
713707
714708
715709
716710 @Callable(i)
717711 func unstakeAndGetOneTknV2 (poolAddress,unstakeAmount,outAssetId,minOutAmount) = {
718712 let inv = invoke(addressFromStringValue(poolAddress), "unstakeAndGetOneTknV2", [unstakeAmount, outAssetId, minOutAmount], nil)
719713 if ((inv == inv))
720714 then $Tuple2(nil, unit)
721715 else throw("Strict value is not equal to itself.")
722716 }
723717
724718
725719
726720 @Callable(i)
727721 func getKeysBulkInternal (currentIter,keys,resAcc) = if ((currentIter == size(keys)))
728722 then $Tuple2(nil, resAcc)
729723 else {
730724 let k = split(keys[currentIter], "++")
731725 let addr = addressFromStringValue(k[0])
732726 let key = k[1]
733727 let type = k[2]
734728 let val = getKey(addr, key, type)
735729 let res = (resAcc :+ val)
736730 let inv = invoke(this, "getKeysBulkInternal", [(currentIter + 1), keys, res], nil)
737731 if ((inv == inv))
738732 then $Tuple2(nil, inv)
739733 else throw("Strict value is not equal to itself.")
740734 }
741735
742736
743737
744738 @Callable(i)
745739 func getKeysBulk (keys) = {
746740 let res = invoke(this, "getKeysBulkInternal", [0, keys, nil], nil)
747741 $Tuple2(nil, res)
748742 }
749743
750744
751745 @Verifier(tx)
752746 func verify () = {
753747 let targetPublicKey = match managerPublicKeyOrUnit() {
754748 case pk: ByteVector =>
755749 pk
756750 case _: Unit =>
757751 tx.senderPublicKey
758752 case _ =>
759753 throw("Match error")
760754 }
761755 sigVerify(tx.bodyBytes, tx.proofs[0], targetPublicKey)
762756 }
763757

github/deemru/w8io/873ac7e 
93.88 ms