tx · uk9XpgyRJakcqC8UTmpmAfEpfVAEawkQiT1oKuvhL8U

3N1dMZiRHyPfV3HE1UP73tMqZyrajT8s7Gd:  -0.03500000 Waves

2022.12.08 10:11 [2351055] smart account 3N1dMZiRHyPfV3HE1UP73tMqZyrajT8s7Gd > SELF 0.00000000 Waves

{ "type": 13, "id": "uk9XpgyRJakcqC8UTmpmAfEpfVAEawkQiT1oKuvhL8U", "fee": 3500000, "feeAssetId": null, "timestamp": 1670483197164, "version": 1, "sender": "3N1dMZiRHyPfV3HE1UP73tMqZyrajT8s7Gd", "senderPublicKey": "5nXNn4nUrku3ormf7LVLKqY9doTY1LZWZ3uDiDHre72C", "proofs": [ "4miRqczVPPQEuR763JcxxnZ8zyrhHDNFHEHmxePnqs2ZFekiDuW2msaNZLcYacMu9qxeYA2mY2SsypU4kS7oSamX" ], "script": "base64:BgKDLQgCEgMKAQgSABIECgIBBBIDCgEBEgQKAgEEEgQKAggBEgQKAggBEgQKAggBEgUKAwEIARIAEgQKAgEBEgMKAQESBQoDAQEBEgQKAggIEgASABIDCgEIEgUKAwEBARIECgIBARIECgIIARIECgIICBILCgkIAQECAQIIBAQSBgoECAgBCBIAEgMKAQESAwoBARIECgIIASIKbFBkZWNpbWFscyIGc2NhbGU4IgxzY2FsZThCaWdJbnQiB3NjYWxlMTgiCnplcm9CaWdJbnQiBGJpZzAiBGJpZzEiBGJpZzIiC3dhdmVzU3RyaW5nIgNTRVAiClBvb2xBY3RpdmUiD1Bvb2xQdXREaXNhYmxlZCITUG9vbE1hdGNoZXJEaXNhYmxlZCIMUG9vbFNodXRkb3duIg5pZHhQb29sQWRkcmVzcyINaWR4UG9vbFN0YXR1cyIQaWR4UG9vbExQQXNzZXRJZCINaWR4QW10QXNzZXRJZCIPaWR4UHJpY2VBc3NldElkIg5pZHhBbXRBc3NldERjbSIQaWR4UHJpY2VBc3NldERjbSIOaWR4SUFtdEFzc2V0SWQiEGlkeElQcmljZUFzc2V0SWQiDWlkeExQQXNzZXREY20iEmlkeFBvb2xBbXRBc3NldEFtdCIUaWR4UG9vbFByaWNlQXNzZXRBbXQiEWlkeFBvb2xMUEFzc2V0QW10IhlpZHhGYWN0b3J5U3Rha2luZ0NvbnRyYWN0IhppZHhGYWN0b3J5U2xpcHBhZ2VDb250cmFjdCIFdG9YMTgiB29yaWdWYWwiDW9yaWdTY2FsZU11bHQiB2Zyb21YMTgiA3ZhbCIPcmVzdWx0U2NhbGVNdWx0Igxmcm9tWDE4Um91bmQiBXJvdW5kIgd0b1NjYWxlIgNhbXQiCHJlc1NjYWxlIghjdXJTY2FsZSIDYWJzIglhYnNCaWdJbnQiAmZjIgNtcGsiBHBtcGsiAnBsIgJwaCIBaCIJdGltZXN0YW1wIgNwYXUiC3VzZXJBZGRyZXNzIgR0eElkIgNnYXUiAmFhIgJwYSIGa2V5RmVlIgpmZWVEZWZhdWx0IgNmZWUiBmtleUtMcCIVa2V5S0xwUmVmcmVzaGVkSGVpZ2h0IhJrZXlLTHBSZWZyZXNoRGVsYXkiFmtMcFJlZnJlc2hEZWxheURlZmF1bHQiD2tMcFJlZnJlc2hEZWxheSIQa2V5RmFjdG9yeUNvbmZpZyINa2V5TWF0Y2hlclB1YiIpa2V5TWFwcGluZ1Bvb2xDb250cmFjdEFkZHJlc3NUb1Bvb2xBc3NldHMiE3Bvb2xDb250cmFjdEFkZHJlc3MiDWtleVBvb2xDb25maWciCWlBbXRBc3NldCILaVByaWNlQXNzZXQiH2tleU1hcHBpbmdzQmFzZUFzc2V0MmludGVybmFsSWQiDGJhc2VBc3NldFN0ciITa2V5QWxsUG9vbHNTaHV0ZG93biINa2V5UG9vbFdlaWdodCIPY29udHJhY3RBZGRyZXNzIhZrZXlBbGxvd2VkTHBTY3JpcHRIYXNoIhZrZXlGZWVDb2xsZWN0b3JBZGRyZXNzIg90aHJvd09yZGVyRXJyb3IiCm9yZGVyVmFsaWQiC3NlbmRlclZhbGlkIgxtYXRjaGVyVmFsaWQiD2dldFN0cmluZ09yRmFpbCIHYWRkcmVzcyIDa2V5IgxnZXRJbnRPckZhaWwiCHRocm93RXJyIgNtc2ciBmZtdEVyciIPZmFjdG9yeUNvbnRyYWN0IhNmZWVDb2xsZWN0b3JBZGRyZXNzIhBpc0dsb2JhbFNodXRkb3duIhNnZXRNYXRjaGVyUHViT3JGYWlsIg1nZXRQb29sQ29uZmlnIghhbXRBc3NldCIKcHJpY2VBc3NldCIMcGFyc2VBc3NldElkIgVpbnB1dCIPYXNzZXRJZFRvU3RyaW5nIg9wYXJzZVBvb2xDb25maWciCnBvb2xDb25maWciEHBvb2xDb25maWdQYXJzZWQiCyR0MDgwNjM4MjI5Ig5jZmdQb29sQWRkcmVzcyINY2ZnUG9vbFN0YXR1cyIMY2ZnTHBBc3NldElkIhBjZmdBbW91bnRBc3NldElkIg9jZmdQcmljZUFzc2V0SWQiFmNmZ0Ftb3VudEFzc2V0RGVjaW1hbHMiFWNmZ1ByaWNlQXNzZXREZWNpbWFscyIQZ2V0RmFjdG9yeUNvbmZpZyIPc3Rha2luZ0NvbnRyYWN0IhBzbGlwcGFnZUNvbnRyYWN0IhFkYXRhUHV0QWN0aW9uSW5mbyINaW5BbXRBc3NldEFtdCIPaW5QcmljZUFzc2V0QW10IghvdXRMcEFtdCIFcHJpY2UiHXNsaXBwYWdlVG9sZXJhbmNlUGFzc2VkQnlVc2VyIhVzbGlwcGFnZVRvbGVyYW5jZVJlYWwiCHR4SGVpZ2h0Igt0eFRpbWVzdGFtcCISc2xpcGFnZUFtdEFzc2V0QW10IhRzbGlwYWdlUHJpY2VBc3NldEFtdCIRZGF0YUdldEFjdGlvbkluZm8iDm91dEFtdEFzc2V0QW10IhBvdXRQcmljZUFzc2V0QW10IgdpbkxwQW10Ig1nZXRBY2NCYWxhbmNlIgdhc3NldElkIg9jYWxjUHJpY2VCaWdJbnQiCHByQW10WDE4IghhbUFtdFgxOCIUY2FsY1ByaWNlQmlnSW50Um91bmQiEHByaXZhdGVDYWxjUHJpY2UiCmFtQXNzZXREY20iCnByQXNzZXREY20iBWFtQW10IgVwckFtdCIOYW10QXNzZXRBbXRYMTgiEHByaWNlQXNzZXRBbXRYMTgiCmNhbGNQcmljZXMiBWxwQW10IgNjZmciC2FtdEFzc2V0RGNtIg1wcmljZUFzc2V0RGNtIghwcmljZVgxOCIIbHBBbXRYMTgiE2xwUHJpY2VJbkFtQXNzZXRYMTgiE2xwUHJpY2VJblByQXNzZXRYMTgiD2NhbGN1bGF0ZVByaWNlcyIGcHJpY2VzIhRlc3RpbWF0ZUdldE9wZXJhdGlvbiIGdHhJZDU4IgpwbXRBc3NldElkIghwbXRMcEFtdCIJbHBBc3NldElkIglhbUFzc2V0SWQiCXByQXNzZXRJZCIKcG9vbFN0YXR1cyIKbHBFbWlzc2lvbiIJYW1CYWxhbmNlIgxhbUJhbGFuY2VYMTgiCXByQmFsYW5jZSIMcHJCYWxhbmNlWDE4IgtjdXJQcmljZVgxOCIIY3VyUHJpY2UiC3BtdExwQW10WDE4Ig1scEVtaXNzaW9uWDE4IgtvdXRBbUFtdFgxOCILb3V0UHJBbXRYMTgiCG91dEFtQW10IghvdXRQckFtdCIFc3RhdGUiFGVzdGltYXRlUHV0T3BlcmF0aW9uIhFzbGlwcGFnZVRvbGVyYW5jZSIMaW5BbUFzc2V0QW10IgtpbkFtQXNzZXRJZCIMaW5QckFzc2V0QW10IgtpblByQXNzZXRJZCIKaXNFdmFsdWF0ZSIGZW1pdExwIgxhbUFzc2V0SWRTdHIiDHByQXNzZXRJZFN0ciILaUFtdEFzc2V0SWQiDWlQcmljZUFzc2V0SWQiDmluQW1Bc3NldElkU3RyIg5pblByQXNzZXRJZFN0ciIPaW5BbUFzc2V0QW10WDE4Ig9pblByQXNzZXRBbXRYMTgiDHVzZXJQcmljZVgxOCIDcmVzIgtzbGlwcGFnZVgxOCIUc2xpcHBhZ2VUb2xlcmFuY2VYMTgiCnByVmlhQW1YMTgiCmFtVmlhUHJYMTgiDGV4cGVjdGVkQW10cyIRZXhwQW10QXNzZXRBbXRYMTgiE2V4cFByaWNlQXNzZXRBbXRYMTgiCWNhbGNMcEFtdCIOY2FsY0FtQXNzZXRQbXQiDmNhbGNQckFzc2V0UG10IgxzbGlwcGFnZUNhbGMiCWVtaXRMcEFtdCIGYW1EaWZmIgZwckRpZmYiC2NvbW1vblN0YXRlIgdjYWxjS0xwIg1hbW91bnRCYWxhbmNlIgxwcmljZUJhbGFuY2UiCnVwZGF0ZWRLTHAiDmNhbGNDdXJyZW50S0xwIhBhbW91bnRBc3NldERlbHRhIg9wcmljZUFzc2V0RGVsdGEiFGxwQXNzZXRFbWlzc2lvbkRlbHRhIhJhbW91bnRBc3NldEJhbGFuY2UiEXByaWNlQXNzZXRCYWxhbmNlIg9scEFzc2V0RW1pc3Npb24iCmN1cnJlbnRLTHAiEnJlZnJlc2hLTHBJbnRlcm5hbCIXYW1vdW50QXNzZXRCYWxhbmNlRGVsdGEiFnByaWNlQXNzZXRCYWxhbmNlRGVsdGEiB2FjdGlvbnMiEnZhbGlkYXRlVXBkYXRlZEtMcCIGb2xkS0xwIht2YWxpZGF0ZU1hdGNoZXJPcmRlckFsbG93ZWQiBW9yZGVyIhFhbW91bnRBc3NldEFtb3VudCIQcHJpY2VBc3NldEFtb3VudCINJHQwMjA4MDMyMTAxNSIDa0xwIg0kdDAyMTQ4NjIxNTg2Ig11bnVzZWRBY3Rpb25zIgZrTHBOZXciDGlzT3JkZXJWYWxpZCIJY29tbW9uR2V0IgFpIgNwbXQiBnBtdEFtdCIJY29tbW9uUHV0IgphbUFzc2V0UG10IgpwckFzc2V0UG10IgZlc3RQdXQiBGVtaXQiBmFtb3VudCIHZW1pdEludiINZW1pdEludkxlZ2FjeSIHJG1hdGNoMCIVbGVnYWN5RmFjdG9yeUNvbnRyYWN0Igd0YWtlRmVlIglmZWVBbW91bnQiD2NhbGNQdXRPbmVUb2tlbiIQcGF5bWVudEFtb3VudFJhdyIOcGF5bWVudEFzc2V0SWQiBmlzRXZhbCIQYW1vdW50QmFsYW5jZVJhdyIPcHJpY2VCYWxhbmNlUmF3IhRwYXltZW50SW5BbW91bnRBc3NldCINJHQwMjQyNzEyNDU2NCIQYW1vdW50QmFsYW5jZU9sZCIPcHJpY2VCYWxhbmNlT2xkIg0kdDAyNDU2ODI0NzE3IhRhbW91bnRBc3NldEFtb3VudFJhdyITcHJpY2VBc3NldEFtb3VudFJhdyINJHQwMjQ4MzkyNDg5OCINcGF5bWVudEFtb3VudCIQYW1vdW50QmFsYW5jZU5ldyIPcHJpY2VCYWxhbmNlTmV3IgtwcmljZU5ld1gxOCIIcHJpY2VOZXciDnBheW1lbnRCYWxhbmNlIhRwYXltZW50QmFsYW5jZUJpZ0ludCIMc3VwcGx5QmlnSW50IgtjaGVjaFN1cHBseSINZGVwb3NpdEJpZ0ludCILaXNzdWVBbW91bnQiC3ByaWNlT2xkWDE4IghwcmljZU9sZCIEbG9zcyINJHQwMjYzNzUyNjU0MiIHYmFsYW5jZSIPaXNzdWVBbW91bnRCb3RoIg9jYWxjR2V0T25lVG9rZW4iCm91dEFzc2V0SWQiBmNoZWNrcyIQb3V0SW5BbW91bnRBc3NldCINYmFsYW5jZUJpZ0ludCIMYW1CYWxhbmNlT2xkIgxwckJhbGFuY2VPbGQiCm91dEJhbGFuY2UiEG91dEJhbGFuY2VCaWdJbnQiDnJlZGVlbWVkQmlnSW50IglhbW91bnRSYXciDSR0MDI4MTQ0MjgxOTQiC3RvdGFsQW1vdW50Ig0kdDAyODE5ODI4NDI0IgtvdXRBbUFtb3VudCILb3V0UHJBbW91bnQiDGFtQmFsYW5jZU5ldyIMcHJCYWxhbmNlTmV3IhhhbW91bnRCb3RoSW5QYXltZW50QXNzZXQiFm1hbmFnZXJQdWJsaWNLZXlPclVuaXQiAXMiHXBlbmRpbmdNYW5hZ2VyUHVibGljS2V5T3JVbml0Iglpc01hbmFnZXIiAnBrIgttdXN0TWFuYWdlciICcGQiF3BlbmRpbmdNYW5hZ2VyUHVibGljS2V5IgtjaGVja0NhbGxlciIVY2hlY2tNYW5hZ2VyUHVibGljS2V5IgJwbSIFaGFzUE0iB2NoZWNrUE0iD3Nob3VsZEF1dG9TdGFrZSIEYW1JZCIEcHJJZCIMc2xpcHBhZ2VBSW52IgxzbGlwcGFnZVBJbnYiCmxwVHJhbnNmZXIiC3NscFN0YWtlSW52Ig0kdDAzMjk1MjMzNDE0IhFyZWZyZXNoS0xwQWN0aW9ucyIRaXNVcGRhdGVkS0xwVmFsaWQiC21heFNsaXBwYWdlIg0kdDAzMzk3NjM0MDQxIgxtaW5PdXRBbW91bnQiCWF1dG9TdGFrZSIgaXNQb29sT25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWQiAUAiDWlzUHV0RGlzYWJsZWQiB3BheW1lbnQiDSR0MDM1MjI2MzUzNzgiBWJvbnVzIhNlbWl0QW1vdW50RXN0aW1hdGVkIgplbWl0QW1vdW50IghzdGFrZUludiIHc2VuZEZlZSINJHQwMzU5NjQzNjE2MSINJHQwMzYxNjQzNjI3MiINJHQwMzY1NzgzNjczNSINb3V0QXNzZXRJZFN0ciINaXNHZXREaXNhYmxlZCINJHQwMzc2MjkzNzc4MiIPYW1vdW50RXN0aW1hdGVkIgdidXJuSW52Ig1hc3NldFRyYW5zZmVyIg0kdDAzODI4MjM4NTI5IhBmZWVBbW91bnRGb3JDYWxjIg0kdDAzODUzMjM4NjQwIg0kdDAzODg5NzM5MDUzIg11bnN0YWtlQW1vdW50Igp1bnN0YWtlSW52Ig0kdDAzOTk1NTQwMTA2Ig0kdDA0MDYwMTQwODQ4Ig0kdDA0MDg1MTQwOTU5IglvdXRBbXRBbXQiFGJ1cm5MUEFzc2V0T25GYWN0b3J5Ig0kdDA0MTkwNzQxOTg5IhJub0xlc3NUaGVuQW10QXNzZXQiFG5vTGVzc1RoZW5QcmljZUFzc2V0Ig0kdDA0Mjk0MDQzMDIxIg1jaGVja1BheW1lbnRzIg9jaGVja1Bvb2xTdGF0dXMiDSR0MDQ0MTQ0NDQyMjUiFW5vTGVzc1RoZW5BbW91bnRBc3NldCIMY2hlY2tBbW91bnRzIg0kdDA0NTUxNzQ1NTk4IgthbXRBc3NldFN0ciINcHJpY2VBc3NldFN0ciIYbGFzdFJlZnJlc2hlZEJsb2NrSGVpZ2h0Ih1jaGVja0xhc3RSZWZyZXNoZWRCbG9ja0hlaWdodCINJHQwNDY3ODU0Njg0OSIQa0xwVXBkYXRlQWN0aW9ucyIKYW10QXNzZXRJZCIMcHJpY2VBc3NldElkIg1wb29sTFBCYWxhbmNlIhJhY2NBbXRBc3NldEJhbGFuY2UiFGFjY1ByaWNlQXNzZXRCYWxhbmNlIgpwcmljZXNMaXN0Ig9scEFtdEFzc2V0U2hhcmUiEWxwUHJpY2VBc3NldFNoYXJlIgpwb29sV2VpZ2h0IgxjdXJQcmljZUNhbGMiDGFtQmFsYW5jZVJhdyIMcHJCYWxhbmNlUmF3Ig9hbUJhbGFuY2VSYXdYMTgiD3ByQmFsYW5jZVJhd1gxOCIQcGF5bWVudExwQXNzZXRJZCIMcGF5bWVudExwQW10IgJ0eCIGdmVyaWZ5Ig90YXJnZXRQdWJsaWNLZXkiCm1hdGNoZXJQdWIiB25ld0hhc2giC2FsbG93ZWRIYXNoIgtjdXJyZW50SGFzaG8AAWEACAABYgCAwtcvAAFjCQC2AgEAgMLXLwABZAkAtgIBAICAkLu61q3wDQABZQkAtgIBAAAAAWYJALYCAQAAAAFnCQC2AgEAAQABaAkAtgIBAAIAAWkCBVdBVkVTAAFqAgJfXwABawABAAFsAAIAAW0AAwABbgAEAAFvAAEAAXAAAgABcQADAAFyAAQAAXMABQABdAAGAAF1AAcAAXYACAABdwAJAAF4AAoAAXkAAQABegACAAFBAAMAAUIAAQABQwAHAQFEAgFFAUYJALwCAwkAtgIBBQFFBQFkCQC2AgEFAUYBAUcCAUgBSQkAoAMBCQC8AgMFAUgJALYCAQUBSQUBZAEBSgMBSAFJAUsJAKADAQkAvQIEBQFICQC2AgEFAUkFAWQFAUsBAUwDAU0BTgFPCQBrAwUBTQUBTgUBTwEBUAEBSAMJAGYCAAAFAUgJAQEtAQUBSAUBSAEBUQEBSAMJAL8CAgUBZQUBSAkAvgIBBQFIBQFIAQFSAAITJXNfX2ZhY3RvcnlDb250cmFjdAEBUwACFCVzX19tYW5hZ2VyUHVibGljS2V5AQFUAAIbJXNfX3BlbmRpbmdNYW5hZ2VyUHVibGljS2V5AQFVAAIRJXMlc19fcHJpY2VfX2xhc3QBAVYCAVcBWAkAuQkCCQDMCAICGCVzJXMlZCVkX19wcmljZV9faGlzdG9yeQkAzAgCCQCkAwEFAVcJAMwIAgkApAMBBQFYBQNuaWwFAWoBAVkCAVoCYWEJAKwCAgkArAICCQCsAgICCyVzJXMlc19fUF9fBQFaAgJfXwUCYWEBAmFiAgFaAmFhCQCsAgIJAKwCAgkArAICAgslcyVzJXNfX0dfXwUBWgICX18FAmFhAQJhYwACDyVzX19hbW91bnRBc3NldAECYWQAAg4lc19fcHJpY2VBc3NldAACYWUCByVzX19mZWUAAmFmCQBrAwAKBQFiAJBOAAJhZwkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQJhZQUCYWYAAmFoCQC5CQIJAMwIAgICJXMJAMwIAgIDa0xwBQNuaWwFAWoAAmFpCQC5CQIJAMwIAgICJXMJAMwIAgISa0xwUmVmcmVzaGVkSGVpZ2h0BQNuaWwFAWoAAmFqCQC5CQIJAMwIAgICJXMJAMwIAgIPcmVmcmVzaEtMcERlbGF5BQNuaWwFAWoAAmFrAB4AAmFsCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFAmFqBQJhawECYW0AAhElc19fZmFjdG9yeUNvbmZpZwECYW4AAhglcyVzX19tYXRjaGVyX19wdWJsaWNLZXkBAmFvAQJhcAkArAICCQCsAgICCCVzJXMlc19fBQJhcAIgX19tYXBwaW5nc19fcG9vbENvbnRyYWN0MkxwQXNzZXQBAmFxAgJhcgJhcwkArAICCQCsAgIJAKwCAgkArAICAgglZCVkJXNfXwUCYXICAl9fBQJhcwIIX19jb25maWcBAmF0AQJhdQkArAICAiglcyVzJXNfX21hcHBpbmdzX19iYXNlQXNzZXQyaW50ZXJuYWxJZF9fBQJhdQECYXYAAgwlc19fc2h1dGRvd24BAmF3AQJheAkArAICAhIlcyVzX19wb29sV2VpZ2h0X18FAmF4AQJheQACFyVzX19hbGxvd2VkTHBTY3JpcHRIYXNoAAJhegIXJXNfX2ZlZUNvbGxlY3RvckFkZHJlc3MBAmFBAwJhQgJhQwJhRAkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAiRvcmRlciB2YWxpZGF0aW9uIGZhaWxlZDogb3JkZXJWYWxpZD0JAKUDAQUCYUICDSBzZW5kZXJWYWxpZD0JAKUDAQUCYUMCDiBtYXRjaGVyVmFs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AQ1wYXJzZUludFZhbHVlAQkAkQMCBQJiTgUBdQQCYlEJAQJiRQQFAmJPBQJiUAUCYkgFAmJJBAJiQwkBAUQCBQJiSAUCYk8EAmJCCQEBRAIFAmJJBQJiUAQCYlIJAQFEAgUCYk0FAWIEAmJTCQECYkECBQJiQwUCYlIEAmJUCQECYkECBQJiQgUCYlIJAMwIAgUCYlEJAMwIAgUCYlMJAMwIAgUCYlQFA25pbAECYlUDAmJIAmJJAmJNBAJiVgkBAmJMAwUCYkgFAmJJBQJiTQkAzAgCCQEBRwIJAJEDAgUCYlYAAAUBYgkAzAgCCQEBRwIJAJEDAgUCYlYAAQUBYgkAzAgCCQEBRwIJAJEDAgUCYlYAAgUBYgUDbmlsAQJiVwQCYlgCYlkCYloBWgQCYk4JAQJhUAAEAmNhCQCRAwIFAmJOBQFxBAJjYgkAkQMCBQJiTgUBcgQCY2MJAJEDAgUCYk4FAXMEAmJGCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYk4FAXQEAmJHCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYk4FAXUEAmNkCQCRAwIFAmJOBQFwBAJjZQgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBCQDZBAEFAmNhCQCsAgIJAKwCAgIGQXNzZXQgBQJjYQIOIGRvZXNuJ3QgZXhpc3QIcXVhbnRpdHkDCQECIT0CBQJjYQUCYlkJAAIBAhVJbnZhbGlkIGFzc2V0IHBhc3NlZC4EAmNmCQECYnkBBQJjYgQCY2cJAQFEAgUCY2YFAmJGBAJjaAkBAmJ5AQUCY2MEAmNpCQEBRAIFAmNoBQJiRwQCY2oJAQJiQQIFAmNpBQJjZwQCY2sJAQFHAgUCY2oFAWIEAmNsCQEBRAIFAmJaBQFiBAJjbQkBAUQCBQJjZQUBYgQCY24JALwCAwUCY2cFAmNsBQJjbQQCY28JALwCAwUCY2kFAmNsBQJjbQQCY3AJAQFHAgUCY24FAmJGBAJjcQkBAUcCBQJjbwUCYkcEAmNyAwkAAAIFAmJYAgAFA25pbAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQFaBQJjcAMJAAACBQJjYgIFV0FWRVMFBHVuaXQJANkEAQUCY2IJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUBWgUCY3EDCQAAAgUCY2MCBVdBVkVTBQR1bml0CQDZBAEFAmNjCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhYgIJAKUIAQUBWgUCYlgJAQJidQYFAmNwBQJjcQUCYloFAmNrBQZoZWlnaHQIBQlsYXN0QmxvY2sJdGltZXN0YW1wCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBVQAFAmNrCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBVgIFBmhlaWdodAgFCWxhc3RCbG9jawl0aW1lc3RhbXAFAmNrBQNuaWwJAJwKCgUCY3AFAmNxBQJjYgUCY2MFAmNmBQJjaAUCY2UFAmNqBQJjZAUCY3IBAmNzCQJiWAJjdAJjdQJjdgJjdwJjeAFaAmN5AmN6BAJiTgkBAmFQAAQCY2EJANkEAQkAkQMCBQJiTgUBcQQCY0EJAJEDAgUCYk4FAXIEAmNCCQCRAwIFAmJOBQFzBAJjQwkAkQMCBQJiTgUBdgQCY0QJAJEDAgUCYk4FAXcEAmJPCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYk4FAXQEAmJQCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYk4FAXUEAmNkCQCRAwIFAmJOBQFwBAJjZQgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBBQJjYQkArAICCQCsAgICBkFzc2V0IAkA2AQBBQJjYQIOIGRvZXNuJ3QgZXhpc3QIcXVhbnRpdHkEAmNFCQDYBAEJAQt2YWx1ZU9yRWxzZQIFAmN2CQDZBAECBVdBVkVTBAJjRgkA2AQBCQELdmFsdWVPckVsc2UCBQJjeAkA2QQBAgVXQVZFUwMDCQECIT0CBQJjQQUCY0UGCQECIT0CBQJjQgUCY0YJAAIBAiJJbnZhbGlkIGFtdCBvciBwcmljZSBhc3NldCBwYXNzZWQuBAJjZgMFAmN5CQECYnkBBQJjQQkAZQIJAQJieQEFAmNBBQJjdQQCY2gDBQJjeQkBAmJ5AQUCY0IJAGUCCQECYnkBBQJjQgUCY3cEAmNHCQEBRAIFAmN1BQJiTwQCY0gJAQFEAgUCY3cFAmJQBAJjSQkBAmJBAgUCY0gFAmNHBAJjZwkBAUQCBQJjZgUCYk8EAmNpCQEBRAIFAmNoBQJiUAQCY0oDCQAAAgUCY2UAAAQCY2oFAWUEAmNLBQFlBAJiUgkAdgYJALkCAgUCY0cFAmNIAAAJALYCAQAFAAEAAAUERE9XTgkAlwoFCQEBRwIFAmJSBQFiCQEBRwIFAmNHBQJiTwkBAUcCBQJjSAUCYlAJAQJiQQIJALcCAgUCY2kFAmNICQC3AgIFAmNnBQJjRwUCY0sEAmNqCQECYkECBQJjaQUCY2cEAmNLCQC8AgMJAQFRAQkAuAICBQJjagUCY0kFAWQFAmNqBAJjTAkBAUQCBQJjdAUBYgMDCQECIT0CBQJjagUBZQkAvwICBQJjSwUCY0wHCQACAQkArAICCQCsAgIJAKwCAgIPUHJpY2Ugc2xpcHBhZ2UgCQCmAwEFAmNLAh4gZXhjZWVkZWQgdGhlIHBhc3NlZCBsaW1pdCBvZiAJAKYDAQUCY0wEAmNtCQEBRAIFAmNlBQFiBAJjTQkAvQIEBQJjRwkBAmJEAwUCY2kFAmNnBQdDRUlMSU5HBQFkBQdDRUlMSU5HBAJjTgkAvQIEBQJjSAUBZAkBAmJEAwUCY2kFAmNnBQVGTE9PUgUHQ0VJTElORwQCY08DCQC/AgIFAmNNBQJjSAkAlAoCBQJjTgUCY0gJAJQKAgUCY0cFAmNNBAJjUAgFAmNPAl8xBAJjUQgFAmNPAl8yBAJiUgkAvQIEBQJjbQUCY1EFAmNpBQVGTE9PUgkAlwoFCQEBSgMFAmJSBQFiBQVGTE9PUgkBAUoDBQJjUAUCYk8FB0NFSUxJTkcJAQFKAwUCY1EFAmJQBQdDRUlMSU5HBQJjagUCY0sEAmNSCAUCY0oCXzEEAmNTCAUCY0oCXzIEAmNUCAUCY0oCXzMEAmNrCQEBRwIIBQJjSgJfNAUBYgQCY1UJAQFHAggFAmNKAl81BQFiAwkAZwIAAAUCY1IJAAIBAjZJbnZhbGlkIGNhbGN1bGF0aW9ucy4gTFAgY2FsY3VsYXRlZCBpcyBsZXNzIHRoYW4gemVyby4EAmNWAwkBASEBBQJjegAABQJjUgQCY1cJAGUCBQJjdQUCY1MEAmNYCQBlAgUCY3cFAmNUBAJjWQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAVUABQJjawkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAVYCBQZoZWlnaHQIBQlsYXN0QmxvY2sJdGltZXN0YW1wBQJjawkAzAgCCQELU3RyaW5nRW50cnkCCQEBWQIFAVoFAmJYCQECYmoKBQJjUwUCY1QFAmNWBQJjawUCY3QFAmNVBQZoZWlnaHQIBQlsYXN0QmxvY2sJdGltZXN0YW1wBQJjVwUCY1gFA25pbAkAnwoNBQJjUgUCY1YFAmNrBQJjZgUCY2gFAmNlBQJjYQUCY2QFAmNZBQJjVwUCY1gFAmN2BQJjeAECY1oDAmRhAmRiAmNlBAJkYwkAvAIDCQB2BgkAuQICBQJkYQUCZGIAAAkAtgIBAAUAAQASBQRET1dOBQFnBQJjZQMJAAACBQJjZQUBZgUBZgUCZGMBAmRkAwJkZQJkZgJkZwQCZGgJALgCAgkAtgIBCQECYnkBCQECYVUBBQJiYwUCZGUEAmRpCQC4AgIJALYCAQkBAmJ5AQkBAmFVAQUCYmQFAmRmBAJkagkAuAICCQC2AgEICQEFdmFsdWUBCQDsBwEFAmJiCHF1YW50aXR5BQJkZwQCZGsJAQJjWgMFAmRoBQJkaQUCZGoFAmRrAQJkbAMCZG0CZG4CZGcEAmRoCQBkAgkBAmJ5AQkBAmFVAQUCYmMFAmRtBAJkaQkAZAIJAQJieQEJAQJhVQEFAmJkBQJkbgQCZGoJAGQCCAkBBXZhbHVlAQkA7AcBBQJiYghxdWFudGl0eQUCZGcEAmRjCQECY1oDCQC2AgEFAmRoCQC2AgEFAmRpCQC2AgEFAmRqBAJkbwkAzAgCCQEMSW50ZWdlckVudHJ5AgUCYWkFBmhlaWdodAkAzAgCCQELU3RyaW5nRW50cnkCBQJhaAkApgMBBQJkYwUDbmlsCQCUCgIFAmRvBQJkYwECZHACAmRxAmRjAwkAwAICBQJkYwUCZHEGCQECYUkBCQC5CQIJAMwIAgIidXBkYXRlZCBLTHAgbG93ZXIgdGhhbiBjdXJyZW50IEtMcAkAzAgCCQCmAwEFAmRxCQDMCAIJAKYDAQUCZGMFA25pbAIBIAECZHIBAmRzBAJkdAgFAmRzBmFtb3VudAQCZHUJAG4ECAUCZHMGYW1vdW50CAUCZHMFcHJpY2UFAWIFBUZMT09SBAJkdgMJAAACCAUCZHMJb3JkZXJUeXBlBQNCdXkJAJQKAgUCZHQJAQEtAQUCZHUJAJQKAgkBAS0BBQJkdAUCZHUEAmRtCAUCZHYCXzEEAmRuCAUCZHYCXzIDAwMJAQJhTgAGCQAAAgUCYmEFAW0GCQAAAgUCYmEFAW4JAAIBAhxFeGNoYW5nZSBvcGVyYXRpb25zIGRpc2FibGVkAwMJAQIhPQIICAUCZHMJYXNzZXRQYWlyC2Ftb3VudEFzc2V0BQJiYwYJAQIhPQIICAUCZHMJYXNzZXRQYWlyCnByaWNlQXNzZXQFAmJkCQACAQITV3Jvbmcgb3JkZXIgYXNzZXRzLgQCZHcJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAqAMBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwUCYWgJAQJhSwECD2tMcCBpcyByZXF1aXJlZAkBAmFLAQILaW52YWxpZCBrTHAEAmR4CQECZGwDBQJkbQUCZG4AAAQCZHkIBQJkeAJfMQQCZHoIBQJkeAJfMgQCZEEJAMACAgUCZHoFAmR3BQJkQQECZEIBAmRDAwkBAiE9AgkAkAMBCAUCZEMIcGF5bWVudHMAAQkAAgECHWV4YWN0bHkgMSBwYXltZW50IGlzIGV4cGVjdGVkBAJkRAkBBXZhbHVlAQkAkQMCCAUCZEMIcGF5bWVudHMAAAQCYlkJAQV2YWx1ZQEIBQJkRAdhc3NldElkBAJkRQgFAmREBmFtb3VudAQCY0oJAQJiVwQJANgEAQgFAmRDDXRyYW5zYWN0aW9uSWQJANgEAQUCYlkFAmRFCAUCZEMGY2FsbGVyBAJjcAgFAmNKAl8xBAJjcQgFAmNKAl8yBAJjZAkBDXBhcnNlSW50VmFsdWUBCAUCY0oCXzkEAmNyCAUCY0oDXzEwAwMJAQJhTgAGCQAAAgUCY2QFAW4JAAIBCQCsAgICLEdldCBvcGVyYXRpb24gaXMgYmxvY2tlZCBieSBhZG1pbi4gU3RhdHVzID0gCQCkAwEFAmNkCQCXCgUFAmNwBQJjcQUCZEUFAmJZBQJjcgECZEYDAmRDAmN0AmN6AwkBAiE9AgkAkAMBCAUCZEMIcGF5bWVudHMAAgkAAgECH2V4YWN0bHkgMiBwYXltZW50cyBhcmUgZXhwZWN0ZWQEAmRHCQEFdmFsdWUBCQCRAwIIBQJkQwhwYXltZW50cwAABAJkSAkBBXZhbHVlAQkAkQMCCAUCZEMIcGF5bWVudHMAAQQCZEkJAQJjcwkJANgEAQgFAmRDDXRyYW5zYWN0aW9uSWQFAmN0CAUCZEcGYW1vdW50CAUCZEcHYXNzZXRJZAgFAmRIBmFtb3VudAgFAmRIB2Fzc2V0SWQJAKUIAQgFAmRDBmNhbGxlcgcFAmN6BAJjZAkBDXBhcnNlSW50VmFsdWUBCAUCZEkCXzgDAwMJAQJhTgAGCQAAAgUCY2QFAWwGCQAAAgUCY2QFAW4JAAIBCQCsAgICLFB1dCBvcGVyYXRpb24gaXMgYmxvY2tlZCBieSBhZG1pbi4gU3RhdHVzID0gCQCkAwEFAmNkBQJkSQECZEoBAmRLBAJkTAkA/AcEBQJhTAIEZW1pdAkAzAgCBQJkSwUDbmlsBQNuaWwDCQAAAgUCZEwFAmRMBAJkTQQCZE4FAmRMAwkAAQIFAmROAgdBZGRyZXNzBAJkTwUCZE4JAPwHBAUCZE8CBGVtaXQJAMwIAgUCZEsFA25pbAUDbmlsBQR1bml0AwkAAAIFAmRNBQJkTQUCZEsJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAmRQAQJkSwQCZFEJAGsDBQJkSwUCYWcFAWIJAJQKAgkAZQIFAmRLBQJkUQUCZFEBAmRSBAJkUwJkVAFaAmFhBAJkVQkAAAIFAmFhBQR1bml0BAJkVgkBAmJ5AQkBAmFVAQUCYmMEAmRXCQECYnkBCQECYVUBBQJiZAQCZFgDCQAAAgUCZFQFAmJjBgMJAAACBQJkVAUCYmQHCQECYUkBAg1pbnZhbGlkIGFzc2V0BAJkWQMFAmRVCQCUCgIFAmRWBQJkVwMFAmRYCQCUCgIJAGUCBQJkVgUCZFMFAmRXCQCUCgIFAmRWCQBlAgUCZFcFAmRTBAJkWggFAmRZAl8xBAJlYQgFAmRZAl8yBAJlYgMFAmRYCQCUCgIFAmRTAAAJAJQKAgAABQJkUwQCZWMIBQJlYgJfMQQCZWQIBQJlYgJfMgQCZHQICQECZFABBQJlYwJfMQQCZHUICQECZFABBQJlZAJfMQQCZWUJAQJkUAEFAmRTBAJlZggFAmVlAl8xBAJkUQgFAmVlAl8yBAJlZwkAZAIFAmRaBQJkdAQCZWgJAGQCBQJlYQUCZHUEAmVpCQECYkECCQEBRAIFAmVoBQJiZgkBAUQCBQJlZwUCYmUEAmVqCQEBRwIFAmVpBQFiBAJlawMFAmRYBQJkWgUCZWEEAmVsCQC2AgEFAmVrBAJlbQkAtgIBCAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQDsBwEFAmJiCQCsAgIJAKwCAgIGYXNzZXQgCQDYBAEFAmJiAg4gZG9lc24ndCBleGlzdAhxdWFudGl0eQQCZW4DCQC/AgIFAmVtBQFmBgkBAmFJAQIiaW5pdGlhbCBkZXBvc2l0IHJlcXVpcmVzIGFsbCBjb2lucwMJAAACBQJlbgUCZW4EAmVvCQC2AgEFAmVmBAJlcAkAlgMBCQDMCAIAAAkAzAgCCQCgAwEJALoCAgkAuQICBQJlbQkAuAICCQEKc3FydEJpZ0ludAQJALcCAgUBZAkAugICCQC5AgIFAmVvBQFkBQJlbAASABIFBERPV04FAWQFAWQFA25pbAQCY1kDBQJkVQUDbmlsCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBVQAFAmVqCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBVgIFBmhlaWdodAgFCWxhc3RCbG9jawl0aW1lc3RhbXAFAmVqCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQFZAgkApQgBCQEFdmFsdWUBBQFaCQDYBAEJAQV2YWx1ZQEFAmFhCQECYmoKBQJlYwUCZWQFAmVwBQJlagAAAAAFBmhlaWdodAgFCWxhc3RCbG9jawl0aW1lc3RhbXAAAAAABQNuaWwEAmVxCQECYkECCQEBRAIFAmVhBQJiZgkBAUQCBQJkWgUCYmUEAmVyCQEBRwIFAmVxBQFiBAJlcwQCZXQDBQJkWAkAlAoCBQJlYwUCZFoJAJQKAgUCZWQFAmVhBAJkSwgFAmV0Al8xBAJldQgFAmV0Al8yBAJldgkAoAMBCQC8AgMFAmVtCQC2AgEJAGkCBQJkSwACCQC2AgEFAmV1CQBrAwkAZQIFAmVwBQJldgUBYgUCZXYJAJcKBQUCZXAFAmNZBQJkUQUCZXMFAmRYCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJldwUCZXgCZWYCZFQBWgJhYQQCZFUJAAACBQJhYQUEdW5pdAQCZXkJAMwIAgMJAAACBQJkVAUCYmIGCQECYUkBAhBpbnZhbGlkIGxwIGFzc2V0BQNuaWwDCQAAAgUCZXkFAmV5BAJlegMJAAACBQJleAUCYmMGAwkAAAIFAmV4BQJiZAcJAQJhSQECDWludmFsaWQgYXNzZXQEAmVBAwUCZXoJALYCAQkBAmJ5AQkBAmFVAQUCYmMJALYCAQkBAmJ5AQkBAmFVAQUCYmQEAmVCCQECYnkBCQECYVUBBQJiYwQCZUMJAQJieQEJAQJhVQEFAmJkBAJlRAMFAmV6BQJlQgUCZUMEAmVFCQC2AgEFAmVEBAJlbQkAtgIBCAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQDsBwEFAmJiCQCsAgIJAKwCAgIGYXNzZXQgCQDYBAEFAmJiAg4gZG9lc24ndCBleGlzdAhxdWFudGl0eQQCZUYJALYCAQUCZWYEAmVHCQCWAwEJAMwIAgAACQDMCAIJAKADAQkAugICCQC5AgIFAmVBCQC4AgIFAWQJAHYGCQC4AgIFAWQJALoCAgkAuQICBQJlRgUBZAUCZW0AEgUBaAAAABIFBERPV04FAWQFA25pbAQCZUgJAQJkUAEFAmVHBAJlSQgFAmVIAl8xBAJkUQgFAmVIAl8yBAJlSgMFAmV6CQCWCgQFAmVJAAAJAGUCBQJlQgUCZUcFAmVDCQCWCgQAAAUCZUkFAmVCCQBlAgUCZUMFAmVHBAJlSwgFAmVKAl8xBAJlTAgFAmVKAl8yBAJlTQgFAmVKAl8zBAJlTggFAmVKAl80BAJlaQkBAmJBAgkBAUQCBQJlTgUCYmYJAQFEAgUCZU0FAmJlBAJlagkBAUcCBQJlaQUBYgQCY1kDBQJkVQUDbmlsCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhYgIJAKUIAQkBBXZhbHVlAQUBWgkA2AQBCQEFdmFsdWUBBQJhYQkBAmJ1BgUCZUsFAmVMBQJlZgUCZWoFBmhlaWdodAgFCWxhc3RCbG9jawl0aW1lc3RhbXAJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFVAAUCZWoJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFWAgUGaGVpZ2h0CAUJbGFzdEJsb2NrCXRpbWVzdGFtcAUCZWoFA25pbAQCZXEJAQJiQQIJAQFEAgUCZUMFAmJmCQEBRAIFAmVCBQJiZQQCZXIJAQFHAgUCZXEFAWIEAmVzBAJlTwkAaAIJAKADAQkAvAIDBQJlQQUCZUYFAmVtAAIJAGsDCQBlAgUCZUkFAmVPBQFiBQJlTwkAlwoFBQJlSQUCY1kFAmRRBQJlcwUCZXoJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAmVQAAQCZE4JAKIIAQkBAVMAAwkAAQIFAmROAgZTdHJpbmcEAmVRBQJkTgkA2QQBBQJlUQMJAAECBQJkTgIEVW5pdAUEdW5pdAkAAgECC01hdGNoIGVycm9yAQJlUgAEAmROCQCiCAEJAQFUAAMJAAECBQJkTgIGU3RyaW5nBAJlUQUCZE4JANkEAQUCZVEDCQABAgUCZE4CBFVuaXQFBHVuaXQJAAIBAgtNYXRjaCBlcnJvcgECZVMBAmRDBAJkTgkBAmVQAAMJAAECBQJkTgIKQnl0ZVZlY3RvcgQCZVQFAmROCQAAAggFAmRDD2NhbGxlclB1YmxpY0tleQUCZVQDCQABAgUCZE4CBFVuaXQJAAACCAUCZEMGY2FsbGVyBQR0aGlzCQACAQILTWF0Y2ggZXJyb3IBAmVVAQJkQwQCZVYJAAIBAhFQZXJtaXNzaW9uIGRlbmllZAQCZE4JAQJlUAADCQABAgUCZE4CCkJ5dGVWZWN0b3IEAmVUBQJkTgMJAAACCAUCZEMPY2FsbGVyUHVibGljS2V5BQJlVAYFAmVWAwkAAQIFAmROAgRVbml0AwkAAAIIBQJkQwZjYWxsZXIFBHRoaXMGBQJlVgkAAgECC01hdGNoIGVycm9yGwJkQwEKc2V0TWFuYWdlcgECZVcEAmVYCQECZVUBBQJkQwMJAAACBQJlWAUCZVgEAmVZCQDZBAEFAmVXAwkAAAIFAmVZBQJlWQkAzAgCCQELU3RyaW5nRW50cnkCCQEBVAAFAmVXBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CZEMBDmNvbmZpcm1NYW5hZ2VyAAQCZVoJAQJlUgAEAmZhAwkBCWlzRGVmaW5lZAEFAmVaBgkAAgECEk5vIHBlbmRpbmcgbWFuYWdlcgMJAAACBQJmYQUCZmEEAmZiAwkAAAIIBQJkQw9jYWxsZXJQdWJsaWNLZXkJAQV2YWx1ZQEFAmVaBgkAAgECG1lvdSBhcmUgbm90IHBlbmRpbmcgbWFuYWdlcgMJAAACBQJmYgUCZmIJAMwIAgkBC1N0cmluZ0VudHJ5AgkBAVMACQDYBAEJAQV2YWx1ZQEFAmVaCQDMCAIJAQtEZWxldGVFbnRyeQEJAQFUAAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmRDAQNwdXQCAmN0AmZjAwkAZgIAAAUCY3QJAAIBAiBJbnZhbGlkIHNsaXBwYWdlVG9sZXJhbmNlIHBhc3NlZAQCZEkJAQJkRgMFAmRDBQJjdAYEAmNWCAUCZEkCXzIEAmNhCAUCZEkCXzcEAmNyCAUCZEkCXzkEAmNXCAUCZEkDXzEwBAJjWAgFAmRJA18xMQQCZmQIBQJkSQNfMTIEAmZlCAUCZEkDXzEzBAJkRwkAtgIBCAkBBXZhbHVlAQkAkQMCCAUCZEMIcGF5bWVudHMAAAZhbW91bnQEAmRICQC2AgEICQEFdmFsdWUBCQCRAwIIBQJkQwhwYXltZW50cwABBmFtb3VudAQCZGsJAQJkZAMFAmRHBQJkSAkAtgIBAAADCQAAAgUCZGsFAmRrBAJkTAkA/AcEBQJhTAIEZW1pdAkAzAgCBQJjVgUDbmlsBQNuaWwDCQAAAgUCZEwFAmRMBAJkTQQCZE4FAmRMAwkAAQIFAmROAgdBZGRyZXNzBAJkTwUCZE4JAPwHBAUCZE8CBGVtaXQJAMwIAgUCY1YFA25pbAUDbmlsBQR1bml0AwkAAAIFAmRNBQJkTQQCZmYDCQBmAgUCY1cAAAkA/AcEBQJiaQIDcHV0BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFAmZkBQJjVwUDbmlsBQNuaWwDCQAAAgUCZmYFAmZmBAJmZwMJAGYCBQJjWAAACQD8BwQFAmJpAgNwdXQFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUCZmUFAmNYBQNuaWwFA25pbAMJAAACBQJmZwUCZmcEAmZoAwUCZmMEAmZpCQD8BwQFAmJoAgVzdGFrZQUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQJjYQUCY1YFA25pbAMJAAACBQJmaQUCZmkFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUCZEMGY2FsbGVyBQJjVgUCY2EFA25pbAQCZmoJAQJkbAMAAAAAAAADCQAAAgUCZmoFAmZqBAJkYwgFAmZqAl8yBAJmawgFAmZqAl8xBAJmbAkBAmRwAgUCZGsFAmRjAwkAAAIFAmZsBQJmbAkAzggCCQDOCAIFAmNyBQJmaAUCZmsJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CZEMBCnB1dEZvckZyZWUBAmZtAwkAZgIAAAUCZm0JAAIBAhRJbnZhbGlkIHZhbHVlIHBhc3NlZAQCZEkJAQJkRgMFAmRDBQJmbQcEAmNyCAUCZEkCXzkEAmRHCQC2AgEICQEFdmFsdWUBCQCRAwIIBQJkQwhwYXltZW50cwAABmFtb3VudAQCZEgJALYCAQgJAQV2YWx1ZQEJAJEDAggFAmRDCHBheW1lbnRzAAEGYW1vdW50BAJkawkBAmRkAwUCZEcFAmRICQC2AgEAAAMJAAACBQJkawUCZGsEAmZuCQECZGwDAAAAAAAABAJmawgFAmZuAl8xBAJkYwgFAmZuAl8yBAJmbAkBAmRwAgUCZGsFAmRjAwkAAAIFAmZsBQJmbAkAzggCBQJjcgUCZmsJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CZEMBCXB1dE9uZVRrbgICZm8CZnAEAmZxCgACZnIJAPwHBAUCYUwCKGlzUG9vbE9uZVRva2VuT3BlcmF0aW9uc0Rpc2FibGVkUkVBRE9OTFkJAMwIAgkApQgBBQR0aGlzBQNuaWwFA25pbAMJAAECBQJmcgIHQm9vbGVhbgUCZnIJAAIBCQCsAgIJAAMBBQJmcgIcIGNvdWxkbid0IGJlIGNhc3QgdG8gQm9vbGVhbgQCZnMDAwMJAQJhTgAGCQAAAgUCYmEFAWwGCQAAAgUCYmEFAW4GBQJmcQQCZXkJAMwIAgMDCQEBIQEFAmZzBgkBAmVTAQUCZEMGCQECYUkBAiFwdXQgb3BlcmF0aW9uIGlzIGJsb2NrZWQgYnkgYWRtaW4JAMwIAgMJAAACCQCQAwEIBQJkQwhwYXltZW50cwABBgkBAmFJAQIeZXhhY3RseSAxIHBheW1lbnQgYXJlIGV4cGVjdGVkBQNuaWwDCQAAAgUCZXkFAmV5BAJmdAkAkQMCCAUCZEMIcGF5bWVudHMAAAQCZFQIBQJmdAdhc3NldElkBAJkUwgFAmZ0BmFtb3VudAQCZGsDCQAAAgUCZFQFAmJjCQECZGQDCQC2AgEFAmRTCQC2AgEAAAkAtgIBAAADCQAAAgUCZFQFAmJkCQECZGQDCQC2AgEAAAkAtgIBBQJkUwkAtgIBAAAJAQJhSQECHnBheW1lbnQgYXNzZXQgaXMgbm90IHN1cHBvcnRlZAQBWggFAmRDBmNhbGxlcgQCYWEIBQJkQw10cmFuc2FjdGlvbklkBAJmdQkBAmRSBAUCZFMFAmRUBQFaBQJhYQMJAAACBQJmdQUCZnUEAmRYCAUCZnUCXzUEAmZ2CAUCZnUCXzQEAmRRCAUCZnUCXzMEAmNZCAUCZnUCXzIEAmZ3CAUCZnUCXzEEAmZ4AwMJAGYCBQJmbwAACQBmAgUCZm8FAmZ3BwkBAmFJAQkAuQkCCQDMCAICH2Ftb3VudCB0byByZWNlaXZlIGlzIGxlc3MgdGhhbiAJAMwIAgkApAMBBQJmbwUDbmlsAgAFAmZ3BAJkTAkBAmRKAQUCZngDCQAAAgUCZEwFAmRMBAJmaAMFAmZwBAJmeQkA/AcEBQJiaAIFc3Rha2UFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUCYmIFAmZ4BQNuaWwDCQAAAgUCZnkFAmZ5BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAmRDBmNhbGxlcgUCZngFAmJiBQNuaWwEAmZ6AwkAZgIFAmRRAAAJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUCYU0FAmRRBQJkVAUDbmlsBQNuaWwEAmZBAwkAAAIFBHRoaXMFAmFNCQCUCgIAAAAAAwUCZFgJAJQKAgkBAS0BBQJkUQAACQCUCgIAAAkBAS0BBQJkUQQCZG0IBQJmQQJfMQQCZG4IBQJmQQJfMgQCZkIJAQJkbAMFAmRtBQJkbgAABAJmawgFAmZCAl8xBAJkYwgFAmZCAl8yBAJkdwkBBXZhbHVlAQkAoggBBQJhaAQCZmwJAQJkcAIFAmRrBQJkYwMJAAACBQJmbAUCZmwJAJQKAgkAzggCCQDOCAIJAM4IAgUCY1kFAmZoBQJmegUCZmsFAmZ4CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmRDARFwdXRPbmVUa25SRUFET05MWQICZFQCZFMEAmZDCQECZFIEBQJkUwkBAmFTAQUCZFQFBHVuaXQFBHVuaXQEAmZ3CAUCZkMCXzEEAmNZCAUCZkMCXzIEAmRRCAUCZkMCXzMEAmZ2CAUCZkMCXzQEAmRYCAUCZkMCXzUJAJQKAgUDbmlsCQCVCgMFAmZ3BQJkUQUCZnYCZEMBCWdldE9uZVRrbgICZkQCZm8EAmZxCgACZnIJAPwHBAUCYUwCKGlzUG9vbE9uZVRva2VuT3BlcmF0aW9uc0Rpc2FibGVkUkVBRE9OTFkJAMwIAgkApQgBBQR0aGlzBQNuaWwFA25pbAMJAAECBQJmcgIHQm9vbGVhbgUCZnIJAAIBCQCsAgIJAAMBBQJmcgIcIGNvdWxkbid0IGJlIGNhc3QgdG8gQm9vbGVhbgQCZkUDAwkBAmFOAAYJAAACBQJiYQUBbgYFAmZx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AAAJALYCAQUCZEUEAmZUCQD8BwQFAmFMAgRidXJuCQDMCAIFAmRFBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFAmJZBQJkRQUDbmlsAwkAAAIFAmZUBQJmVAQCZlUJAQJkbAMJAQEtAQUCZlMJAQEtAQUCY3EAAAQCZmsIBQJmVQJfMQQCZGMIBQJmVQJfMgQCZmwJAQJkcAIFAmRrBQJkYwMJAAACBQJmbAUCZmwJAM4IAgUCY3IFAmZrCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmRDAQlnZXROb0xlc3MCAmZWAmZXBAJjSgkBAmRCAQUCZEMEAmNwCAUCY0oCXzEEAmNxCAUCY0oCXzIEAmRFCAUCY0oCXzMEAmJZCAUCY0oCXzQEAmNyCAUCY0oCXzUDCQBmAgUCZlYFAmNwCQACAQkArAICCQCsAgIJAKwCAgIcbm9MZXNzVGhlbkFtdEFzc2V0IGZhaWxlZDogIAkApAMBBQJjcAIDIDwgCQCkAwEFAmZWAwkAZgIFAmZXBQJjcQkAAgEJAKwCAgkArAICCQCsAgICHW5vTGVzc1RoZW5QcmljZUFzc2V0IGZhaWxlZDogCQCkAwEFAmNxAgMgPCAJAKQDAQUCZlcEAmRrCQECZGQDCQC2AgEAAAkAtgIBAAAJALYCAQUCZEUEAmZUCQD8BwQFAmFMAgRidXJuCQDMCAIFAmRFBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFAmJZBQJkRQUDbmlsAwkAAAIFAmZUBQJmVAQCZlgJAQJkbAMJAQEtAQUCY3AJAQEtAQUCY3EAAAQCZmsIBQJmWAJfMQQCZGMIBQJmWAJfMgQCZmwJAQJkcAIFAmRrBQJkYwMJAAACBQJmbAUCZmwJAM4IAgUCY3IFAmZrCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmRDAQ11bnN0YWtlQW5kR2V0AQJkSwQCZlkDCQECIT0CCQCQAwEIBQJkQwhwYXltZW50cwAACQACAQIYTm8gcGF5bWVudHMgYXJlIGV4cGVjdGVkBgMJAAACBQJmWQUCZlkEAmJOCQECYVAABAJjYQkA2QQBCQCRAwIFAmJOBQFxBAJkawkBAmRkAwkAtgIBAAAJALYCAQAACQC2AgEAAAQCZk8JAPwHBAUCYmgCB3Vuc3Rha2UJAMwIAgkA2AQBBQJjYQkAzAgCBQJkSwUDbmlsBQNuaWwDCQAAAgUCZk8FAmZPBAJjSgkBAmJXBAkA2AQBCAUCZEMNdHJhbnNhY3Rpb25JZAkA2AQBBQJjYQUCZEsIBQJkQwZjYWxsZXIEAmNwCAUCY0oCXzEEAmNxCAUCY0oCXzIEAmNkCQENcGFyc2VJbnRWYWx1ZQEIBQJjSgJfOQQCY3IIBQJjSgNfMTAEAmZaAwMJAQJhTgAGCQAAAgUCY2QFAW4JAAIBCQCsAgICLEdldCBvcGVyYXRpb24gaXMgYmxvY2tlZCBieSBhZG1pbi4gU3RhdHVzID0gCQCkAwEFAmNkBgMJAAACBQJmWgUCZloEAmZUCQD8BwQFAmFMAgRidXJuCQDMCAIFAmRLBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFAmNhBQJkSwUDbmlsAwkAAAIFAmZUBQJmVAQCZ2EJAQJkbAMJAQEtAQUCY3AJAQEtAQUCY3EAAAQCZmsIBQJnYQJfMQQCZGMIBQJnYQJfMgQCZmwJAQJkcAIFAmRrBQJkYwMJAAACBQJmbAUCZmwJAM4IAgUCY3IFAmZrCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmRDARN1bnN0YWtlQW5kR2V0Tm9MZXNzAwJmTgJnYgJmVwQCZkUDCQECYU4ABgkAAAIFAmJhBQFuBAJleQkAzAgCAwkBASEBBQJmRQYJAAIBAiFnZXQgb3BlcmF0aW9uIGlzIGJsb2NrZWQgYnkgYWRtaW4JAMwIAgMJAAACCQCQAwEIBQJkQwhwYXltZW50cwAABgkAAgECGG5vIHBheW1lbnRzIGFyZSBleHBlY3RlZAUDbmlsAwkAAAIFAmV5BQJleQQCZGsJAQJkZAMJALYCAQAACQC2AgEAAAkAtgIBAAAEAmZPCQD8BwQFAmJoAgd1bnN0YWtlCQDMCAIJANgEAQUCYmIJAMwIAgUCZk4FA25pbAUDbmlsAwkAAAIFAmZPBQJmTwQCY0oJAQJiVwQJANgEAQgFAmRDDXRyYW5zYWN0aW9uSWQJANgEAQUCYmIFAmZOCAUCZEMGY2FsbGVyBAJjcAgFAmNKAl8xBAJjcQgFAmNKAl8yBAJjcggFAmNKA18xMAQCZ2MJAMwIAgMJAGcCBQJjcAUCZ2IGCQACAQkAuQkCCQDMCAICLGFtb3VudCBhc3NldCBhbW91bnQgdG8gcmVjZWl2ZSBpcyBsZXNzIHRoYW4gCQDMCAIJAKQDAQUCZ2IFA25pbAIACQDMCAIDCQBnAgUCY3EFAmZXBgkAAgEJALkJAgkAzAgCAitwcmljZSBhc3NldCBhbW91bnQgdG8gcmVjZWl2ZSBpcyBsZXNzIHRoYW4gCQDMCAIJAKQDAQUCZlcFA25pbAIABQNuaWwDCQAAAgUCZ2MFAmdjBAJmVAkA/AcEBQJhTAIEYnVybgkAzAgCBQJmTgUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQJiYgUCZk4FA25pbAMJAAACBQJmVAUCZlQEAmdkCQECZGwDCQEBLQEFAmNwCQEBLQEFAmNxAAAEAmZrCAUCZ2QCXzEEAmRjCAUCZ2QCXzIEAmZsCQECZHACBQJkawUCZGMDCQAAAgUCZmwFAmZsCQDOCAIFAmNyBQJmawkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJkQwEIYWN0aXZh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ZCVkCQDMCAIJAKQDAQUCZ24JAMwIAgkApAMBBQJnbwkAzAgCCQCkAwEFAmdtCQDMCAIJAKQDAQUCY2sJAMwIAgkApAMBBQJncQkAzAgCCQCkAwEFAmdyCQDMCAIJAKQDAQUCZ3MFA25pbAUBagJkQwEgZXZhbHVhdGVQdXRCeUFtb3VudEFzc2V0UkVBRE9OTFkBAmN1BAJiTgkBAmFQAAQCY2EJANkEAQkAkQMCBQJiTgUBcQQCY0EJAJEDAgUCYk4FAXIEAmNiCQDZBAEFAmNBBAJjQgkAkQMCBQJiTgUBcwQCY2MJANkEAQUCY0IEAmJPCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYk4FAXQEAmJQCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYk4FAXUEAmNkCQCRAwIFAmJOBQFwBAJnbQgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBBQJjYQkArAICCQCsAgICBkFzc2V0IAkA2AQBBQJjYQIOIGRvZXNuJ3QgZXhpc3QIcXVhbnRpdHkEAmduCQECYnkBBQJjQQQCZ28JAQJieQEFAmNCBAJiSgkBAUQCBQJnbgUCYk8EAmJLCQEBRAIFAmdvBQJiUAQCY2oDCQAAAgUCZ20AAAUBZQkBAmJBAgUCYksFAmJKBAJjRwkBAUQCBQJjdQUCYk8EAmNICQC8AgMFAmNHBQJjagUBZAQCY3cJAQFHAgUCY0gFAmJQBAJkSQkBAmNzCQIAAKDCHgUCY3UFAmNiBQJjdwUCY2MCAAYHBAJjUggFAmRJAl8xBAJndAgFAmRJAl8zBAJjZggFAmRJAl80BAJjaAgFAmRJAl81BAJjZQgFAmRJAl82CQCUCgIFA25pbAkAuQkCCQDMCAICECVkJWQlZCVkJWQlZCVkJWQJAMwIAgkApAMBBQJjUgkAzAgCCQCkAwEJAQFHAgUCY2oFAWIJAMwIAgkApAMBBQJjZgkAzAgCCQCkAwEFAmNoCQDMCAIJAKQDAQUCY2UJAMwIAgUCY2QJAMwIAgkApAMBBQJjdQkAzAgCCQCkAwEFAmN3BQNuaWwFAWoCZEMBH2V2YWx1YXRlUHV0QnlQcmljZUFzc2V0UkVBRE9OTFkBAmN3BAJiTgkBAmFQAAQCY2EJANkEAQkAkQMCBQJiTgUBcQQCY0EJAJEDAgUCYk4FAXIEAmNiCQDZBAEFAmNBBAJjQgkAkQMCBQJiTgUBcwQCY2MJANkEAQUCY0IEAmJPCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYk4FAXQEAmJQCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCYk4FAXUEAmNkCQCRAwIFAmJOBQFwBAJnbQgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBBQJjYQkArAICCQCsAgICBkFzc2V0IAkA2AQBBQJjYQIOIGRvZXNuJ3QgZXhpc3QIcXVhbnRpdHkEAmd1CQECYnkBBQJjQQQCZ3YJAQJieQEFAmNCBAJndwkBAUQCBQJndQUCYk8EAmd4CQEBRAIFAmd2BQJiUAQCY2oDCQAAAgUCZ20AAAUBZQkBAmJBAgUCZ3gFAmd3BAJjSAkBAUQCBQJjdwUCYlAEAmNHCQC8AgMFAmNIBQFkBQJjagQCY3UJAQFHAgUCY0cFAmJPBAJkSQkBAmNzCQIAAKDCHgUCY3UFAmNiBQJjdwUCY2MCAAYHBAJjUggFAmRJAl8xBAJndAgFAmRJAl8zBAJjZggFAmRJAl80BAJjaAgFAmRJAl81BAJjZQgFAmRJAl82CQCUCgIFA25pbAkAuQkCCQDMCAICECVkJWQlZCVkJWQlZCVkJWQJAMwIAgkApAMBBQJjUgkAzAgCCQCkAwEJAQFHAgUCY2oFAWIJAMwIAgkApAMBBQJjZgkAzAgCCQCkAwEFAmNoCQDMCAIJAKQDAQUCY2UJAMwIAgUCY2QJAMwIAgkApAMBBQJjdQkAzAgCCQCkAwEFAmN3BQNuaWwFAWoCZEMBE2V2YWx1YXRlR2V0UkVBRE9OTFkCAmd5Amd6BAJjSgkBAmJXBAIABQJneQUCZ3oFBHRoaXMEAmNwCAUCY0oCXzEEAmNxCAUCY0oCXzIEAmNmCAUCY0oCXzUEAmNoCAUCY0oCXzYEAmNlCAUCY0oCXzcEAmNrCAUCY0oCXzgEAmNkCQENcGFyc2VJbnRWYWx1ZQEIBQJjSgJfOQkAlAoCBQNuaWwJALkJAgkAzAgCAg4lZCVkJWQlZCVkJWQlZAkAzAgCCQCkAwEFAmNwCQDMCAIJAKQDAQUCY3EJAMwIAgkApAMBBQJjZgkAzAgCCQCkAwEFAmNoCQDMCAIJAKQDAQUCY2UJAMwIAgkApgMBBQJjawkAzAgCCQCkAwEFAmNkBQNuaWwFAWoBAmdBAQJnQgAEAmdDBAJkTgkBAmVQAAMJAAECBQJkTgIKQnl0ZVZlY3RvcgQCZVQFAmROBQJlVAMJAAECBQJkTgIEVW5pdAgFAmdBD3NlbmRlclB1YmxpY0tleQkAAgECC01hdGNoIGVycm9yBAJkTgUCZ0EDCQABAgUCZE4CBU9yZGVyBAJkcwUCZE4EAmdECQECYU8ABAJhQgkBAmRyAQUCZHMEAmFDCQD0AwMIBQJkcwlib2R5Qnl0ZXMJAJEDAggFAmRzBnByb29mcwAACAUCZHMPc2VuZGVyUHVibGljS2V5BAJhRAkA9AMDCAUCZHMJYm9keUJ5dGVzCQCRAwIIBQJkcwZwcm9vZnMAAQUCZ0QDAwMFAmFCBQJhQwcFAmFEBwYJAQJhQQMFAmFCBQJhQwUCYUQDCQABAgUCZE4CFFNldFNjcmlwdFRyYW5zYWN0aW9uBAJlUQUCZE4EAmdFCQD2AwEJAQV2YWx1ZQEIBQJlUQZzY3JpcHQEAmdGCQDbBAEJAQV2YWx1ZQEJAJ0IAgUCYUwJAQJheQAEAmdHCQDxBwEFBHRoaXMDAwkAAAIFAmdGBQJnRQkBAiE9AgUCZ0cFAmdFBwYJAPQDAwgFAmdBCWJvZHlCeXRlcwkAkQMCCAUCZ0EGcHJvb2ZzAAAFAmdDCQD0AwMIBQJnQQlib2R5Qnl0ZXMJAJEDAggFAmdBBnByb29mcwAABQJnQ+X5DuM=", "chainId": 84, "height": 2351055, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: dxmDJCrZDESiMU9GoiELTCGpP2tnimtaDWJQ1qubmk2 Next: MznwNsEZS9LZCi2USSioBCnzrEVwzCBQkeSW4XDmRBv Diff:
OldNewDifferences
709709 let prId = estPut._13
710710 let amAssetPmt = toBigInt(value(i.payments[0]).amount)
711711 let prAssetPmt = toBigInt(value(i.payments[1]).amount)
712- let amountAssetBalance = (toBigInt(getAccBalance(assetIdToString(cfgAmountAssetId))) - amAssetPmt)
713- if ((amountAssetBalance == amountAssetBalance))
712+ let currentKLp = calcCurrentKLp(amAssetPmt, prAssetPmt, toBigInt(0))
713+ if ((currentKLp == currentKLp))
714714 then {
715- let priceAssetBalance = (toBigInt(getAccBalance(assetIdToString(cfgPriceAssetId))) - prAssetPmt)
716- if ((priceAssetBalance == priceAssetBalance))
715+ let emitInv = invoke(factoryContract, "emit", [emitLpAmt], nil)
716+ if ((emitInv == emitInv))
717717 then {
718- let lpAssetEmission = toBigInt(value(assetInfo(cfgLpAssetId)).quantity)
719- if ((lpAssetEmission == lpAssetEmission))
718+ let emitInvLegacy = match emitInv {
719+ case legacyFactoryContract: Address =>
720+ invoke(legacyFactoryContract, "emit", [emitLpAmt], nil)
721+ case _ =>
722+ unit
723+ }
724+ if ((emitInvLegacy == emitInvLegacy))
720725 then {
721- let currentKLp = calcCurrentKLp(amAssetPmt, prAssetPmt, toBigInt(0))
722- if ((currentKLp == currentKLp))
726+ let slippageAInv = if ((amDiff > 0))
727+ then invoke(slippageContract, "put", nil, [AttachedPayment(amId, amDiff)])
728+ else nil
729+ if ((slippageAInv == slippageAInv))
723730 then {
724- let emitInv = invoke(factoryContract, "emit", [emitLpAmt], nil)
725- if ((emitInv == emitInv))
731+ let slippagePInv = if ((prDiff > 0))
732+ then invoke(slippageContract, "put", nil, [AttachedPayment(prId, prDiff)])
733+ else nil
734+ if ((slippagePInv == slippagePInv))
726735 then {
727- let emitInvLegacy = match emitInv {
728- case legacyFactoryContract: Address =>
729- invoke(legacyFactoryContract, "emit", [emitLpAmt], nil)
730- case _ =>
731- unit
732- }
733- if ((emitInvLegacy == emitInvLegacy))
736+ let lpTransfer = if (shouldAutoStake)
734737 then {
735- let slippageAInv = if ((amDiff > 0))
736- then invoke(slippageContract, "put", nil, [AttachedPayment(amId, amDiff)])
737- else nil
738- if ((slippageAInv == slippageAInv))
739- then {
740- let slippagePInv = if ((prDiff > 0))
741- then invoke(slippageContract, "put", nil, [AttachedPayment(prId, prDiff)])
742- else nil
743- if ((slippagePInv == slippagePInv))
744- then {
745- let lpTransfer = if (shouldAutoStake)
746- then {
747- let slpStakeInv = invoke(stakingContract, "stake", nil, [AttachedPayment(lpAssetId, emitLpAmt)])
748- if ((slpStakeInv == slpStakeInv))
749- then nil
750- else throw("Strict value is not equal to itself.")
751- }
752- else [ScriptTransfer(i.caller, emitLpAmt, lpAssetId)]
753- let lpAssetEmissionAfter = value(assetInfo(cfgLpAssetId)).quantity
754- if ((lpAssetEmissionAfter == lpAssetEmissionAfter))
755- then {
756- let $t03294433012 = refreshKLpInternal(0, 0, 0)
757- if (($t03294433012 == $t03294433012))
758- then {
759- let updatedKLp = $t03294433012._2
760- let refreshKLpActions = $t03294433012._1
761- let error = throwErr(makeString([toString(amountAssetBalance), toString(priceAssetBalance), toString(lpAssetEmission), toString(currentKLp), toString(updatedKLp), toString(emitLpAmt), toString(amDiff), toString(prDiff), toString(lpAssetEmission), toString(lpAssetEmissionAfter)], " "))
762- if ((error == error))
763- then {
764- let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
765- if ((isUpdatedKLpValid == isUpdatedKLpValid))
766- then ((state ++ lpTransfer) ++ refreshKLpActions)
767- else throw("Strict value is not equal to itself.")
768- }
769- else throw("Strict value is not equal to itself.")
770- }
771- else throw("Strict value is not equal to itself.")
772- }
773- else throw("Strict value is not equal to itself.")
774- }
775- else throw("Strict value is not equal to itself.")
776- }
738+ let slpStakeInv = invoke(stakingContract, "stake", nil, [AttachedPayment(lpAssetId, emitLpAmt)])
739+ if ((slpStakeInv == slpStakeInv))
740+ then nil
741+ else throw("Strict value is not equal to itself.")
742+ }
743+ else [ScriptTransfer(i.caller, emitLpAmt, lpAssetId)]
744+ let $t03295233414 = refreshKLpInternal(0, 0, 0)
745+ if (($t03295233414 == $t03295233414))
746+ then {
747+ let updatedKLp = $t03295233414._2
748+ let refreshKLpActions = $t03295233414._1
749+ let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
750+ if ((isUpdatedKLpValid == isUpdatedKLpValid))
751+ then ((state ++ lpTransfer) ++ refreshKLpActions)
777752 else throw("Strict value is not equal to itself.")
778753 }
779754 else throw("Strict value is not equal to itself.")
802777 let currentKLp = calcCurrentKLp(amAssetPmt, prAssetPmt, toBigInt(0))
803778 if ((currentKLp == currentKLp))
804779 then {
805- let $t03394434009 = refreshKLpInternal(0, 0, 0)
806- let refreshKLpActions = $t03394434009._1
807- let updatedKLp = $t03394434009._2
780+ let $t03397634041 = refreshKLpInternal(0, 0, 0)
781+ let refreshKLpActions = $t03397634041._1
782+ let updatedKLp = $t03397634041._2
808783 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
809784 if ((isUpdatedKLpValid == isUpdatedKLpValid))
810785 then (state ++ refreshKLpActions)
849824 else throwErr("payment asset is not supported")
850825 let userAddress = i.caller
851826 let txId = i.transactionId
852- let $t03519435346 = calcPutOneToken(paymentAmountRaw, paymentAssetId, userAddress, txId)
853- if (($t03519435346 == $t03519435346))
827+ let $t03522635378 = calcPutOneToken(paymentAmountRaw, paymentAssetId, userAddress, txId)
828+ if (($t03522635378 == $t03522635378))
854829 then {
855- let paymentInAmountAsset = $t03519435346._5
856- let bonus = $t03519435346._4
857- let feeAmount = $t03519435346._3
858- let commonState = $t03519435346._2
859- let emitAmountEstimated = $t03519435346._1
830+ let paymentInAmountAsset = $t03522635378._5
831+ let bonus = $t03522635378._4
832+ let feeAmount = $t03522635378._3
833+ let commonState = $t03522635378._2
834+ let emitAmountEstimated = $t03522635378._1
860835 let emitAmount = if (if ((minOutAmount > 0))
861836 then (minOutAmount > emitAmountEstimated)
862837 else false)
876851 let sendFee = if ((feeAmount > 0))
877852 then [ScriptTransfer(feeCollectorAddress, feeAmount, paymentAssetId)]
878853 else nil
879- let $t03593236129 = if ((this == feeCollectorAddress))
854+ let $t03596436161 = if ((this == feeCollectorAddress))
880855 then $Tuple2(0, 0)
881856 else if (paymentInAmountAsset)
882857 then $Tuple2(-(feeAmount), 0)
883858 else $Tuple2(0, -(feeAmount))
884- let amountAssetBalanceDelta = $t03593236129._1
885- let priceAssetBalanceDelta = $t03593236129._2
886- let $t03613236240 = refreshKLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
887- let refreshKLpActions = $t03613236240._1
888- let updatedKLp = $t03613236240._2
859+ let amountAssetBalanceDelta = $t03596436161._1
860+ let priceAssetBalanceDelta = $t03596436161._2
861+ let $t03616436272 = refreshKLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
862+ let refreshKLpActions = $t03616436272._1
863+ let updatedKLp = $t03616436272._2
889864 let kLp = value(getString(keyKLp))
890865 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
891866 if ((isUpdatedKLpValid == isUpdatedKLpValid))
903878
904879 @Callable(i)
905880 func putOneTknREADONLY (paymentAssetId,paymentAmountRaw) = {
906- let $t03654636703 = calcPutOneToken(paymentAmountRaw, parseAssetId(paymentAssetId), unit, unit)
907- let emitAmountEstimated = $t03654636703._1
908- let commonState = $t03654636703._2
909- let feeAmount = $t03654636703._3
910- let bonus = $t03654636703._4
911- let paymentInAmountAsset = $t03654636703._5
881+ let $t03657836735 = calcPutOneToken(paymentAmountRaw, parseAssetId(paymentAssetId), unit, unit)
882+ let emitAmountEstimated = $t03657836735._1
883+ let commonState = $t03657836735._2
884+ let feeAmount = $t03657836735._3
885+ let bonus = $t03657836735._4
886+ let paymentInAmountAsset = $t03657836735._5
912887 $Tuple2(nil, $Tuple3(emitAmountEstimated, feeAmount, bonus))
913888 }
914889
943918 let currentKLp = calcCurrentKLp(toBigInt(0), toBigInt(0), toBigInt(paymentAmount))
944919 let userAddress = i.caller
945920 let txId = i.transactionId
946- let $t03759737750 = calcGetOneToken(outAssetId, paymentAmount, paymentAssetId, userAddress, txId)
947- if (($t03759737750 == $t03759737750))
921+ let $t03762937782 = calcGetOneToken(outAssetId, paymentAmount, paymentAssetId, userAddress, txId)
922+ if (($t03762937782 == $t03762937782))
948923 then {
949- let outInAmountAsset = $t03759737750._5
950- let bonus = $t03759737750._4
951- let feeAmount = $t03759737750._3
952- let commonState = $t03759737750._2
953- let amountEstimated = $t03759737750._1
924+ let outInAmountAsset = $t03762937782._5
925+ let bonus = $t03762937782._4
926+ let feeAmount = $t03762937782._3
927+ let commonState = $t03762937782._2
928+ let amountEstimated = $t03762937782._1
954929 let amount = if (if ((minOutAmount > 0))
955930 then (minOutAmount > amountEstimated)
956931 else false)
963938 let sendFee = if ((feeAmount > 0))
964939 then [ScriptTransfer(feeCollectorAddress, feeAmount, outAssetId)]
965940 else nil
966- let $t03825038497 = {
941+ let $t03828238529 = {
967942 let feeAmountForCalc = if ((this == feeCollectorAddress))
968943 then 0
969944 else feeAmount
971946 then $Tuple2(-((amount + feeAmountForCalc)), 0)
972947 else $Tuple2(0, -((amount + feeAmountForCalc)))
973948 }
974- let amountAssetBalanceDelta = $t03825038497._1
975- let priceAssetBalanceDelta = $t03825038497._2
976- let $t03850038608 = refreshKLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
977- let refreshKLpActions = $t03850038608._1
978- let updatedKLp = $t03850038608._2
949+ let amountAssetBalanceDelta = $t03828238529._1
950+ let priceAssetBalanceDelta = $t03828238529._2
951+ let $t03853238640 = refreshKLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
952+ let refreshKLpActions = $t03853238640._1
953+ let updatedKLp = $t03853238640._2
979954 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
980955 if ((isUpdatedKLpValid == isUpdatedKLpValid))
981956 then $Tuple2((((commonState ++ assetTransfer) ++ sendFee) ++ refreshKLpActions), amount)
992967
993968 @Callable(i)
994969 func getOneTknREADONLY (outAssetId,paymentAmount) = {
995- let $t03886539021 = calcGetOneToken(parseAssetId(outAssetId), paymentAmount, cfgLpAssetId, unit, unit)
996- let amountEstimated = $t03886539021._1
997- let commonState = $t03886539021._2
998- let feeAmount = $t03886539021._3
999- let bonus = $t03886539021._4
1000- let outInAmountAsset = $t03886539021._5
970+ let $t03889739053 = calcGetOneToken(parseAssetId(outAssetId), paymentAmount, cfgLpAssetId, unit, unit)
971+ let amountEstimated = $t03889739053._1
972+ let commonState = $t03889739053._2
973+ let feeAmount = $t03889739053._3
974+ let bonus = $t03889739053._4
975+ let outInAmountAsset = $t03889739053._5
1001976 $Tuple2(nil, $Tuple3(amountEstimated, feeAmount, bonus))
1002977 }
1003978
10321007 let unstakeInv = invoke(stakingContract, "unstake", [toBase58String(cfgLpAssetId), unstakeAmount], nil)
10331008 if ((unstakeInv == unstakeInv))
10341009 then {
1035- let $t03992340074 = calcGetOneToken(outAssetId, unstakeAmount, cfgLpAssetId, userAddress, txId)
1036- if (($t03992340074 == $t03992340074))
1010+ let $t03995540106 = calcGetOneToken(outAssetId, unstakeAmount, cfgLpAssetId, userAddress, txId)
1011+ if (($t03995540106 == $t03995540106))
10371012 then {
1038- let outInAmountAsset = $t03992340074._5
1039- let bonus = $t03992340074._4
1040- let feeAmount = $t03992340074._3
1041- let commonState = $t03992340074._2
1042- let amountEstimated = $t03992340074._1
1013+ let outInAmountAsset = $t03995540106._5
1014+ let bonus = $t03995540106._4
1015+ let feeAmount = $t03995540106._3
1016+ let commonState = $t03995540106._2
1017+ let amountEstimated = $t03995540106._1
10431018 let amount = if (if ((minOutAmount > 0))
10441019 then (minOutAmount > amountEstimated)
10451020 else false)
10521027 let sendFee = if ((feeAmount > 0))
10531028 then [ScriptTransfer(feeCollectorAddress, feeAmount, outAssetId)]
10541029 else nil
1055- let $t04056940816 = {
1030+ let $t04060140848 = {
10561031 let feeAmountForCalc = if ((this == feeCollectorAddress))
10571032 then 0
10581033 else feeAmount
10601035 then $Tuple2(-((amount + feeAmountForCalc)), 0)
10611036 else $Tuple2(0, -((amount + feeAmountForCalc)))
10621037 }
1063- let amountAssetBalanceDelta = $t04056940816._1
1064- let priceAssetBalanceDelta = $t04056940816._2
1065- let $t04081940927 = refreshKLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
1066- let refreshKLpActions = $t04081940927._1
1067- let updatedKLp = $t04081940927._2
1038+ let amountAssetBalanceDelta = $t04060140848._1
1039+ let priceAssetBalanceDelta = $t04060140848._2
1040+ let $t04085140959 = refreshKLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
1041+ let refreshKLpActions = $t04085140959._1
1042+ let updatedKLp = $t04085140959._2
10681043 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
10691044 if ((isUpdatedKLpValid == isUpdatedKLpValid))
10701045 then $Tuple2((((commonState ++ assetTransfer) ++ sendFee) ++ refreshKLpActions), amount)
10931068 let burnLPAssetOnFactory = invoke(factoryContract, "burn", [pmtAmt], [AttachedPayment(pmtAssetId, pmtAmt)])
10941069 if ((burnLPAssetOnFactory == burnLPAssetOnFactory))
10951070 then {
1096- let $t04187541957 = refreshKLpInternal(-(outAmtAmt), -(outPrAmt), 0)
1097- let refreshKLpActions = $t04187541957._1
1098- let updatedKLp = $t04187541957._2
1071+ let $t04190741989 = refreshKLpInternal(-(outAmtAmt), -(outPrAmt), 0)
1072+ let refreshKLpActions = $t04190741989._1
1073+ let updatedKLp = $t04190741989._2
10991074 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
11001075 if ((isUpdatedKLpValid == isUpdatedKLpValid))
11011076 then (state ++ refreshKLpActions)
11231098 let burnLPAssetOnFactory = invoke(factoryContract, "burn", [pmtAmt], [AttachedPayment(pmtAssetId, pmtAmt)])
11241099 if ((burnLPAssetOnFactory == burnLPAssetOnFactory))
11251100 then {
1126- let $t04290842989 = refreshKLpInternal(-(outAmAmt), -(outPrAmt), 0)
1127- let refreshKLpActions = $t04290842989._1
1128- let updatedKLp = $t04290842989._2
1101+ let $t04294043021 = refreshKLpInternal(-(outAmAmt), -(outPrAmt), 0)
1102+ let refreshKLpActions = $t04294043021._1
1103+ let updatedKLp = $t04294043021._2
11291104 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
11301105 if ((isUpdatedKLpValid == isUpdatedKLpValid))
11311106 then (state ++ refreshKLpActions)
11651140 let burnLPAssetOnFactory = invoke(factoryContract, "burn", [amount], [AttachedPayment(lpAssetId, amount)])
11661141 if ((burnLPAssetOnFactory == burnLPAssetOnFactory))
11671142 then {
1168- let $t04411244193 = refreshKLpInternal(-(outAmAmt), -(outPrAmt), 0)
1169- let refreshKLpActions = $t04411244193._1
1170- let updatedKLp = $t04411244193._2
1143+ let $t04414444225 = refreshKLpInternal(-(outAmAmt), -(outPrAmt), 0)
1144+ let refreshKLpActions = $t04414444225._1
1145+ let updatedKLp = $t04414444225._2
11711146 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
11721147 if ((isUpdatedKLpValid == isUpdatedKLpValid))
11731148 then (state ++ refreshKLpActions)
12141189 let burnLPAssetOnFactory = invoke(factoryContract, "burn", [unstakeAmount], [AttachedPayment(cfgLpAssetId, unstakeAmount)])
12151190 if ((burnLPAssetOnFactory == burnLPAssetOnFactory))
12161191 then {
1217- let $t04548545566 = refreshKLpInternal(-(outAmAmt), -(outPrAmt), 0)
1218- let refreshKLpActions = $t04548545566._1
1219- let updatedKLp = $t04548545566._2
1192+ let $t04551745598 = refreshKLpInternal(-(outAmAmt), -(outPrAmt), 0)
1193+ let refreshKLpActions = $t04551745598._1
1194+ let updatedKLp = $t04551745598._2
12201195 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
12211196 if ((isUpdatedKLpValid == isUpdatedKLpValid))
12221197 then (state ++ refreshKLpActions)
12491224 if ((checkLastRefreshedBlockHeight == checkLastRefreshedBlockHeight))
12501225 then {
12511226 let kLp = valueOrErrorMessage(parseBigInt(valueOrElse(getString(this, keyKLp), "0")), fmtErr("invalid kLp"))
1252- let $t04675346817 = refreshKLpInternal(0, 0, 0)
1253- let kLpUpdateActions = $t04675346817._1
1254- let updatedKLp = $t04675346817._2
1227+ let $t04678546849 = refreshKLpInternal(0, 0, 0)
1228+ let kLpUpdateActions = $t04678546849._1
1229+ let updatedKLp = $t04678546849._2
12551230 let actions = if ((kLp != updatedKLp))
12561231 then kLpUpdateActions
12571232 else throwErr("nothing to refresh")
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let lPdecimals = 8
55
66 let scale8 = 100000000
77
88 let scale8BigInt = toBigInt(100000000)
99
1010 let scale18 = toBigInt(1000000000000000000)
1111
1212 let zeroBigInt = toBigInt(0)
1313
1414 let big0 = toBigInt(0)
1515
1616 let big1 = toBigInt(1)
1717
1818 let big2 = toBigInt(2)
1919
2020 let wavesString = "WAVES"
2121
2222 let SEP = "__"
2323
2424 let PoolActive = 1
2525
2626 let PoolPutDisabled = 2
2727
2828 let PoolMatcherDisabled = 3
2929
3030 let PoolShutdown = 4
3131
3232 let idxPoolAddress = 1
3333
3434 let idxPoolStatus = 2
3535
3636 let idxPoolLPAssetId = 3
3737
3838 let idxAmtAssetId = 4
3939
4040 let idxPriceAssetId = 5
4141
4242 let idxAmtAssetDcm = 6
4343
4444 let idxPriceAssetDcm = 7
4545
4646 let idxIAmtAssetId = 8
4747
4848 let idxIPriceAssetId = 9
4949
5050 let idxLPAssetDcm = 10
5151
5252 let idxPoolAmtAssetAmt = 1
5353
5454 let idxPoolPriceAssetAmt = 2
5555
5656 let idxPoolLPAssetAmt = 3
5757
5858 let idxFactoryStakingContract = 1
5959
6060 let idxFactorySlippageContract = 7
6161
6262 func toX18 (origVal,origScaleMult) = fraction(toBigInt(origVal), scale18, toBigInt(origScaleMult))
6363
6464
6565 func fromX18 (val,resultScaleMult) = toInt(fraction(val, toBigInt(resultScaleMult), scale18))
6666
6767
6868 func fromX18Round (val,resultScaleMult,round) = toInt(fraction(val, toBigInt(resultScaleMult), scale18, round))
6969
7070
7171 func toScale (amt,resScale,curScale) = fraction(amt, resScale, curScale)
7272
7373
7474 func abs (val) = if ((0 > val))
7575 then -(val)
7676 else val
7777
7878
7979 func absBigInt (val) = if ((zeroBigInt > val))
8080 then -(val)
8181 else val
8282
8383
8484 func fc () = "%s__factoryContract"
8585
8686
8787 func mpk () = "%s__managerPublicKey"
8888
8989
9090 func pmpk () = "%s__pendingManagerPublicKey"
9191
9292
9393 func pl () = "%s%s__price__last"
9494
9595
9696 func ph (h,timestamp) = makeString(["%s%s%d%d__price__history", toString(h), toString(timestamp)], SEP)
9797
9898
9999 func pau (userAddress,txId) = ((("%s%s%s__P__" + userAddress) + "__") + txId)
100100
101101
102102 func gau (userAddress,txId) = ((("%s%s%s__G__" + userAddress) + "__") + txId)
103103
104104
105105 func aa () = "%s__amountAsset"
106106
107107
108108 func pa () = "%s__priceAsset"
109109
110110
111111 let keyFee = "%s__fee"
112112
113113 let feeDefault = fraction(10, scale8, 10000)
114114
115115 let fee = valueOrElse(getInteger(this, keyFee), feeDefault)
116116
117117 let keyKLp = makeString(["%s", "kLp"], SEP)
118118
119119 let keyKLpRefreshedHeight = makeString(["%s", "kLpRefreshedHeight"], SEP)
120120
121121 let keyKLpRefreshDelay = makeString(["%s", "refreshKLpDelay"], SEP)
122122
123123 let kLpRefreshDelayDefault = 30
124124
125125 let kLpRefreshDelay = valueOrElse(getInteger(this, keyKLpRefreshDelay), kLpRefreshDelayDefault)
126126
127127 func keyFactoryConfig () = "%s__factoryConfig"
128128
129129
130130 func keyMatcherPub () = "%s%s__matcher__publicKey"
131131
132132
133133 func keyMappingPoolContractAddressToPoolAssets (poolContractAddress) = (("%s%s%s__" + poolContractAddress) + "__mappings__poolContract2LpAsset")
134134
135135
136136 func keyPoolConfig (iAmtAsset,iPriceAsset) = (((("%d%d%s__" + iAmtAsset) + "__") + iPriceAsset) + "__config")
137137
138138
139139 func keyMappingsBaseAsset2internalId (baseAssetStr) = ("%s%s%s__mappings__baseAsset2internalId__" + baseAssetStr)
140140
141141
142142 func keyAllPoolsShutdown () = "%s__shutdown"
143143
144144
145145 func keyPoolWeight (contractAddress) = ("%s%s__poolWeight__" + contractAddress)
146146
147147
148148 func keyAllowedLpScriptHash () = "%s__allowedLpScriptHash"
149149
150150
151151 let keyFeeCollectorAddress = "%s__feeCollectorAddress"
152152
153153 func throwOrderError (orderValid,senderValid,matcherValid) = throw(((((("order validation failed: orderValid=" + toString(orderValid)) + " senderValid=") + toString(senderValid)) + " matcherValid=") + toString(matcherValid)))
154154
155155
156156 func getStringOrFail (address,key) = valueOrErrorMessage(getString(address, key), makeString(["mandatory ", toString(address), ".", key, " is not defined"], ""))
157157
158158
159159 func getIntOrFail (address,key) = valueOrErrorMessage(getInteger(address, key), makeString(["mandatory ", toString(address), ".", key, " is not defined"], ""))
160160
161161
162162 func throwErr (msg) = throw(makeString(["lp.ride:", msg], " "))
163163
164164
165165 func fmtErr (msg) = makeString(["lp.ride:", msg], " ")
166166
167167
168168 let factoryContract = addressFromStringValue(getStringOrFail(this, fc()))
169169
170170 let feeCollectorAddress = addressFromStringValue(getStringOrFail(factoryContract, keyFeeCollectorAddress))
171171
172172 func isGlobalShutdown () = valueOrElse(getBoolean(factoryContract, keyAllPoolsShutdown()), false)
173173
174174
175175 func getMatcherPubOrFail () = fromBase58String(getStringOrFail(factoryContract, keyMatcherPub()))
176176
177177
178178 func getPoolConfig () = {
179179 let amtAsset = getStringOrFail(this, aa())
180180 let priceAsset = getStringOrFail(this, pa())
181181 let iPriceAsset = getIntOrFail(factoryContract, keyMappingsBaseAsset2internalId(priceAsset))
182182 let iAmtAsset = getIntOrFail(factoryContract, keyMappingsBaseAsset2internalId(amtAsset))
183183 split(getStringOrFail(factoryContract, keyPoolConfig(toString(iAmtAsset), toString(iPriceAsset))), SEP)
184184 }
185185
186186
187187 func parseAssetId (input) = if ((input == wavesString))
188188 then unit
189189 else fromBase58String(input)
190190
191191
192192 func assetIdToString (input) = if ((input == unit))
193193 then wavesString
194194 else toBase58String(value(input))
195195
196196
197197 func parsePoolConfig (poolConfig) = $Tuple7(addressFromStringValue(poolConfig[idxPoolAddress]), parseIntValue(poolConfig[idxPoolStatus]), fromBase58String(poolConfig[idxPoolLPAssetId]), parseAssetId(poolConfig[idxAmtAssetId]), parseAssetId(poolConfig[idxPriceAssetId]), parseIntValue(poolConfig[idxAmtAssetDcm]), parseIntValue(poolConfig[idxPriceAssetDcm]))
198198
199199
200200 let poolConfigParsed = parsePoolConfig(getPoolConfig())
201201
202202 let $t080638229 = poolConfigParsed
203203
204204 let cfgPoolAddress = $t080638229._1
205205
206206 let cfgPoolStatus = $t080638229._2
207207
208208 let cfgLpAssetId = $t080638229._3
209209
210210 let cfgAmountAssetId = $t080638229._4
211211
212212 let cfgPriceAssetId = $t080638229._5
213213
214214 let cfgAmountAssetDecimals = $t080638229._6
215215
216216 let cfgPriceAssetDecimals = $t080638229._7
217217
218218 func getFactoryConfig () = split(getStringOrFail(factoryContract, keyFactoryConfig()), SEP)
219219
220220
221221 let stakingContract = valueOrErrorMessage(addressFromString(getFactoryConfig()[idxFactoryStakingContract]), "incorrect staking address")
222222
223223 let slippageContract = valueOrErrorMessage(addressFromString(getFactoryConfig()[idxFactorySlippageContract]), "incorrect staking address")
224224
225225 func dataPutActionInfo (inAmtAssetAmt,inPriceAssetAmt,outLpAmt,price,slippageTolerancePassedByUser,slippageToleranceReal,txHeight,txTimestamp,slipageAmtAssetAmt,slipagePriceAssetAmt) = makeString(["%d%d%d%d%d%d%d%d%d%d", toString(inAmtAssetAmt), toString(inPriceAssetAmt), toString(outLpAmt), toString(price), toString(slippageTolerancePassedByUser), toString(slippageToleranceReal), toString(txHeight), toString(txTimestamp), toString(slipageAmtAssetAmt), toString(slipagePriceAssetAmt)], SEP)
226226
227227
228228 func dataGetActionInfo (outAmtAssetAmt,outPriceAssetAmt,inLpAmt,price,txHeight,txTimestamp) = makeString(["%d%d%d%d%d%d", toString(outAmtAssetAmt), toString(outPriceAssetAmt), toString(inLpAmt), toString(price), toString(txHeight), toString(txTimestamp)], SEP)
229229
230230
231231 func getAccBalance (assetId) = if ((assetId == "WAVES"))
232232 then wavesBalance(this).available
233233 else assetBalance(this, fromBase58String(assetId))
234234
235235
236236 func calcPriceBigInt (prAmtX18,amAmtX18) = fraction(prAmtX18, scale18, amAmtX18)
237237
238238
239239 func calcPriceBigIntRound (prAmtX18,amAmtX18,round) = fraction(prAmtX18, scale18, amAmtX18, round)
240240
241241
242242 func privateCalcPrice (amAssetDcm,prAssetDcm,amAmt,prAmt) = {
243243 let amtAssetAmtX18 = toX18(amAmt, amAssetDcm)
244244 let priceAssetAmtX18 = toX18(prAmt, prAssetDcm)
245245 calcPriceBigInt(priceAssetAmtX18, amtAssetAmtX18)
246246 }
247247
248248
249249 func calcPrices (amAmt,prAmt,lpAmt) = {
250250 let cfg = getPoolConfig()
251251 let amtAssetDcm = parseIntValue(cfg[idxAmtAssetDcm])
252252 let priceAssetDcm = parseIntValue(cfg[idxPriceAssetDcm])
253253 let priceX18 = privateCalcPrice(amtAssetDcm, priceAssetDcm, amAmt, prAmt)
254254 let amAmtX18 = toX18(amAmt, amtAssetDcm)
255255 let prAmtX18 = toX18(prAmt, priceAssetDcm)
256256 let lpAmtX18 = toX18(lpAmt, scale8)
257257 let lpPriceInAmAssetX18 = calcPriceBigInt(amAmtX18, lpAmtX18)
258258 let lpPriceInPrAssetX18 = calcPriceBigInt(prAmtX18, lpAmtX18)
259259 [priceX18, lpPriceInAmAssetX18, lpPriceInPrAssetX18]
260260 }
261261
262262
263263 func calculatePrices (amAmt,prAmt,lpAmt) = {
264264 let prices = calcPrices(amAmt, prAmt, lpAmt)
265265 [fromX18(prices[0], scale8), fromX18(prices[1], scale8), fromX18(prices[2], scale8)]
266266 }
267267
268268
269269 func estimateGetOperation (txId58,pmtAssetId,pmtLpAmt,userAddress) = {
270270 let cfg = getPoolConfig()
271271 let lpAssetId = cfg[idxPoolLPAssetId]
272272 let amAssetId = cfg[idxAmtAssetId]
273273 let prAssetId = cfg[idxPriceAssetId]
274274 let amAssetDcm = parseIntValue(cfg[idxAmtAssetDcm])
275275 let prAssetDcm = parseIntValue(cfg[idxPriceAssetDcm])
276276 let poolStatus = cfg[idxPoolStatus]
277277 let lpEmission = valueOrErrorMessage(assetInfo(fromBase58String(lpAssetId)), (("Asset " + lpAssetId) + " doesn't exist")).quantity
278278 if ((lpAssetId != pmtAssetId))
279279 then throw("Invalid asset passed.")
280280 else {
281281 let amBalance = getAccBalance(amAssetId)
282282 let amBalanceX18 = toX18(amBalance, amAssetDcm)
283283 let prBalance = getAccBalance(prAssetId)
284284 let prBalanceX18 = toX18(prBalance, prAssetDcm)
285285 let curPriceX18 = calcPriceBigInt(prBalanceX18, amBalanceX18)
286286 let curPrice = fromX18(curPriceX18, scale8)
287287 let pmtLpAmtX18 = toX18(pmtLpAmt, scale8)
288288 let lpEmissionX18 = toX18(lpEmission, scale8)
289289 let outAmAmtX18 = fraction(amBalanceX18, pmtLpAmtX18, lpEmissionX18)
290290 let outPrAmtX18 = fraction(prBalanceX18, pmtLpAmtX18, lpEmissionX18)
291291 let outAmAmt = fromX18(outAmAmtX18, amAssetDcm)
292292 let outPrAmt = fromX18(outPrAmtX18, prAssetDcm)
293293 let state = if ((txId58 == ""))
294294 then nil
295295 else [ScriptTransfer(userAddress, outAmAmt, if ((amAssetId == "WAVES"))
296296 then unit
297297 else fromBase58String(amAssetId)), ScriptTransfer(userAddress, outPrAmt, if ((prAssetId == "WAVES"))
298298 then unit
299299 else fromBase58String(prAssetId)), StringEntry(gau(toString(userAddress), txId58), dataGetActionInfo(outAmAmt, outPrAmt, pmtLpAmt, curPrice, height, lastBlock.timestamp)), IntegerEntry(pl(), curPrice), IntegerEntry(ph(height, lastBlock.timestamp), curPrice)]
300300 $Tuple10(outAmAmt, outPrAmt, amAssetId, prAssetId, amBalance, prBalance, lpEmission, curPriceX18, poolStatus, state)
301301 }
302302 }
303303
304304
305305 func estimatePutOperation (txId58,slippageTolerance,inAmAssetAmt,inAmAssetId,inPrAssetAmt,inPrAssetId,userAddress,isEvaluate,emitLp) = {
306306 let cfg = getPoolConfig()
307307 let lpAssetId = fromBase58String(cfg[idxPoolLPAssetId])
308308 let amAssetIdStr = cfg[idxAmtAssetId]
309309 let prAssetIdStr = cfg[idxPriceAssetId]
310310 let iAmtAssetId = cfg[idxIAmtAssetId]
311311 let iPriceAssetId = cfg[idxIPriceAssetId]
312312 let amtAssetDcm = parseIntValue(cfg[idxAmtAssetDcm])
313313 let priceAssetDcm = parseIntValue(cfg[idxPriceAssetDcm])
314314 let poolStatus = cfg[idxPoolStatus]
315315 let lpEmission = valueOrErrorMessage(assetInfo(lpAssetId), (("Asset " + toBase58String(lpAssetId)) + " doesn't exist")).quantity
316316 let inAmAssetIdStr = toBase58String(valueOrElse(inAmAssetId, fromBase58String("WAVES")))
317317 let inPrAssetIdStr = toBase58String(valueOrElse(inPrAssetId, fromBase58String("WAVES")))
318318 if (if ((amAssetIdStr != inAmAssetIdStr))
319319 then true
320320 else (prAssetIdStr != inPrAssetIdStr))
321321 then throw("Invalid amt or price asset passed.")
322322 else {
323323 let amBalance = if (isEvaluate)
324324 then getAccBalance(amAssetIdStr)
325325 else (getAccBalance(amAssetIdStr) - inAmAssetAmt)
326326 let prBalance = if (isEvaluate)
327327 then getAccBalance(prAssetIdStr)
328328 else (getAccBalance(prAssetIdStr) - inPrAssetAmt)
329329 let inAmAssetAmtX18 = toX18(inAmAssetAmt, amtAssetDcm)
330330 let inPrAssetAmtX18 = toX18(inPrAssetAmt, priceAssetDcm)
331331 let userPriceX18 = calcPriceBigInt(inPrAssetAmtX18, inAmAssetAmtX18)
332332 let amBalanceX18 = toX18(amBalance, amtAssetDcm)
333333 let prBalanceX18 = toX18(prBalance, priceAssetDcm)
334334 let res = if ((lpEmission == 0))
335335 then {
336336 let curPriceX18 = zeroBigInt
337337 let slippageX18 = zeroBigInt
338338 let lpAmtX18 = pow((inAmAssetAmtX18 * inPrAssetAmtX18), 0, toBigInt(5), 1, 0, DOWN)
339339 $Tuple5(fromX18(lpAmtX18, scale8), fromX18(inAmAssetAmtX18, amtAssetDcm), fromX18(inPrAssetAmtX18, priceAssetDcm), calcPriceBigInt((prBalanceX18 + inPrAssetAmtX18), (amBalanceX18 + inAmAssetAmtX18)), slippageX18)
340340 }
341341 else {
342342 let curPriceX18 = calcPriceBigInt(prBalanceX18, amBalanceX18)
343343 let slippageX18 = fraction(absBigInt((curPriceX18 - userPriceX18)), scale18, curPriceX18)
344344 let slippageToleranceX18 = toX18(slippageTolerance, scale8)
345345 if (if ((curPriceX18 != zeroBigInt))
346346 then (slippageX18 > slippageToleranceX18)
347347 else false)
348348 then throw(((("Price slippage " + toString(slippageX18)) + " exceeded the passed limit of ") + toString(slippageToleranceX18)))
349349 else {
350350 let lpEmissionX18 = toX18(lpEmission, scale8)
351351 let prViaAmX18 = fraction(inAmAssetAmtX18, calcPriceBigIntRound(prBalanceX18, amBalanceX18, CEILING), scale18, CEILING)
352352 let amViaPrX18 = fraction(inPrAssetAmtX18, scale18, calcPriceBigIntRound(prBalanceX18, amBalanceX18, FLOOR), CEILING)
353353 let expectedAmts = if ((prViaAmX18 > inPrAssetAmtX18))
354354 then $Tuple2(amViaPrX18, inPrAssetAmtX18)
355355 else $Tuple2(inAmAssetAmtX18, prViaAmX18)
356356 let expAmtAssetAmtX18 = expectedAmts._1
357357 let expPriceAssetAmtX18 = expectedAmts._2
358358 let lpAmtX18 = fraction(lpEmissionX18, expPriceAssetAmtX18, prBalanceX18, FLOOR)
359359 $Tuple5(fromX18Round(lpAmtX18, scale8, FLOOR), fromX18Round(expAmtAssetAmtX18, amtAssetDcm, CEILING), fromX18Round(expPriceAssetAmtX18, priceAssetDcm, CEILING), curPriceX18, slippageX18)
360360 }
361361 }
362362 let calcLpAmt = res._1
363363 let calcAmAssetPmt = res._2
364364 let calcPrAssetPmt = res._3
365365 let curPrice = fromX18(res._4, scale8)
366366 let slippageCalc = fromX18(res._5, scale8)
367367 if ((0 >= calcLpAmt))
368368 then throw("Invalid calculations. LP calculated is less than zero.")
369369 else {
370370 let emitLpAmt = if (!(emitLp))
371371 then 0
372372 else calcLpAmt
373373 let amDiff = (inAmAssetAmt - calcAmAssetPmt)
374374 let prDiff = (inPrAssetAmt - calcPrAssetPmt)
375375 let commonState = [IntegerEntry(pl(), curPrice), IntegerEntry(ph(height, lastBlock.timestamp), curPrice), StringEntry(pau(userAddress, txId58), dataPutActionInfo(calcAmAssetPmt, calcPrAssetPmt, emitLpAmt, curPrice, slippageTolerance, slippageCalc, height, lastBlock.timestamp, amDiff, prDiff))]
376376 $Tuple13(calcLpAmt, emitLpAmt, curPrice, amBalance, prBalance, lpEmission, lpAssetId, poolStatus, commonState, amDiff, prDiff, inAmAssetId, inPrAssetId)
377377 }
378378 }
379379 }
380380
381381
382382 func calcKLp (amountBalance,priceBalance,lpEmission) = {
383383 let updatedKLp = fraction(pow((amountBalance * priceBalance), 0, toBigInt(5), 1, 18, DOWN), big1, lpEmission)
384384 if ((lpEmission == big0))
385385 then big0
386386 else updatedKLp
387387 }
388388
389389
390390 func calcCurrentKLp (amountAssetDelta,priceAssetDelta,lpAssetEmissionDelta) = {
391391 let amountAssetBalance = (toBigInt(getAccBalance(assetIdToString(cfgAmountAssetId))) - amountAssetDelta)
392392 let priceAssetBalance = (toBigInt(getAccBalance(assetIdToString(cfgPriceAssetId))) - priceAssetDelta)
393393 let lpAssetEmission = (toBigInt(value(assetInfo(cfgLpAssetId)).quantity) - lpAssetEmissionDelta)
394394 let currentKLp = calcKLp(amountAssetBalance, priceAssetBalance, lpAssetEmission)
395395 currentKLp
396396 }
397397
398398
399399 func refreshKLpInternal (amountAssetBalanceDelta,priceAssetBalanceDelta,lpAssetEmissionDelta) = {
400400 let amountAssetBalance = (getAccBalance(assetIdToString(cfgAmountAssetId)) + amountAssetBalanceDelta)
401401 let priceAssetBalance = (getAccBalance(assetIdToString(cfgPriceAssetId)) + priceAssetBalanceDelta)
402402 let lpAssetEmission = (value(assetInfo(cfgLpAssetId)).quantity + lpAssetEmissionDelta)
403403 let updatedKLp = calcKLp(toBigInt(amountAssetBalance), toBigInt(priceAssetBalance), toBigInt(lpAssetEmission))
404404 let actions = [IntegerEntry(keyKLpRefreshedHeight, height), StringEntry(keyKLp, toString(updatedKLp))]
405405 $Tuple2(actions, updatedKLp)
406406 }
407407
408408
409409 func validateUpdatedKLp (oldKLp,updatedKLp) = if ((updatedKLp >= oldKLp))
410410 then true
411411 else throwErr(makeString(["updated KLp lower than current KLp", toString(oldKLp), toString(updatedKLp)], " "))
412412
413413
414414 func validateMatcherOrderAllowed (order) = {
415415 let amountAssetAmount = order.amount
416416 let priceAssetAmount = fraction(order.amount, order.price, scale8, FLOOR)
417417 let $t02080321015 = if ((order.orderType == Buy))
418418 then $Tuple2(amountAssetAmount, -(priceAssetAmount))
419419 else $Tuple2(-(amountAssetAmount), priceAssetAmount)
420420 let amountAssetBalanceDelta = $t02080321015._1
421421 let priceAssetBalanceDelta = $t02080321015._2
422422 if (if (if (isGlobalShutdown())
423423 then true
424424 else (cfgPoolStatus == PoolMatcherDisabled))
425425 then true
426426 else (cfgPoolStatus == PoolShutdown))
427427 then throw("Exchange operations disabled")
428428 else if (if ((order.assetPair.amountAsset != cfgAmountAssetId))
429429 then true
430430 else (order.assetPair.priceAsset != cfgPriceAssetId))
431431 then throw("Wrong order assets.")
432432 else {
433433 let kLp = valueOrErrorMessage(parseBigInt(valueOrErrorMessage(getString(this, keyKLp), fmtErr("kLp is required"))), fmtErr("invalid kLp"))
434434 let $t02148621586 = refreshKLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
435435 let unusedActions = $t02148621586._1
436436 let kLpNew = $t02148621586._2
437437 let isOrderValid = (kLpNew >= kLp)
438438 isOrderValid
439439 }
440440 }
441441
442442
443443 func commonGet (i) = if ((size(i.payments) != 1))
444444 then throw("exactly 1 payment is expected")
445445 else {
446446 let pmt = value(i.payments[0])
447447 let pmtAssetId = value(pmt.assetId)
448448 let pmtAmt = pmt.amount
449449 let res = estimateGetOperation(toBase58String(i.transactionId), toBase58String(pmtAssetId), pmtAmt, i.caller)
450450 let outAmAmt = res._1
451451 let outPrAmt = res._2
452452 let poolStatus = parseIntValue(res._9)
453453 let state = res._10
454454 if (if (isGlobalShutdown())
455455 then true
456456 else (poolStatus == PoolShutdown))
457457 then throw(("Get operation is blocked by admin. Status = " + toString(poolStatus)))
458458 else $Tuple5(outAmAmt, outPrAmt, pmtAmt, pmtAssetId, state)
459459 }
460460
461461
462462 func commonPut (i,slippageTolerance,emitLp) = if ((size(i.payments) != 2))
463463 then throw("exactly 2 payments are expected")
464464 else {
465465 let amAssetPmt = value(i.payments[0])
466466 let prAssetPmt = value(i.payments[1])
467467 let estPut = estimatePutOperation(toBase58String(i.transactionId), slippageTolerance, amAssetPmt.amount, amAssetPmt.assetId, prAssetPmt.amount, prAssetPmt.assetId, toString(i.caller), false, emitLp)
468468 let poolStatus = parseIntValue(estPut._8)
469469 if (if (if (isGlobalShutdown())
470470 then true
471471 else (poolStatus == PoolPutDisabled))
472472 then true
473473 else (poolStatus == PoolShutdown))
474474 then throw(("Put operation is blocked by admin. Status = " + toString(poolStatus)))
475475 else estPut
476476 }
477477
478478
479479 func emit (amount) = {
480480 let emitInv = invoke(factoryContract, "emit", [amount], nil)
481481 if ((emitInv == emitInv))
482482 then {
483483 let emitInvLegacy = match emitInv {
484484 case legacyFactoryContract: Address =>
485485 invoke(legacyFactoryContract, "emit", [amount], nil)
486486 case _ =>
487487 unit
488488 }
489489 if ((emitInvLegacy == emitInvLegacy))
490490 then amount
491491 else throw("Strict value is not equal to itself.")
492492 }
493493 else throw("Strict value is not equal to itself.")
494494 }
495495
496496
497497 func takeFee (amount) = {
498498 let feeAmount = fraction(amount, fee, scale8)
499499 $Tuple2((amount - feeAmount), feeAmount)
500500 }
501501
502502
503503 func calcPutOneToken (paymentAmountRaw,paymentAssetId,userAddress,txId) = {
504504 let isEval = (txId == unit)
505505 let amountBalanceRaw = getAccBalance(assetIdToString(cfgAmountAssetId))
506506 let priceBalanceRaw = getAccBalance(assetIdToString(cfgPriceAssetId))
507507 let paymentInAmountAsset = if ((paymentAssetId == cfgAmountAssetId))
508508 then true
509509 else if ((paymentAssetId == cfgPriceAssetId))
510510 then false
511511 else throwErr("invalid asset")
512512 let $t02427124564 = if (isEval)
513513 then $Tuple2(amountBalanceRaw, priceBalanceRaw)
514514 else if (paymentInAmountAsset)
515515 then $Tuple2((amountBalanceRaw - paymentAmountRaw), priceBalanceRaw)
516516 else $Tuple2(amountBalanceRaw, (priceBalanceRaw - paymentAmountRaw))
517517 let amountBalanceOld = $t02427124564._1
518518 let priceBalanceOld = $t02427124564._2
519519 let $t02456824717 = if (paymentInAmountAsset)
520520 then $Tuple2(paymentAmountRaw, 0)
521521 else $Tuple2(0, paymentAmountRaw)
522522 let amountAssetAmountRaw = $t02456824717._1
523523 let priceAssetAmountRaw = $t02456824717._2
524524 let amountAssetAmount = takeFee(amountAssetAmountRaw)._1
525525 let priceAssetAmount = takeFee(priceAssetAmountRaw)._1
526526 let $t02483924898 = takeFee(paymentAmountRaw)
527527 let paymentAmount = $t02483924898._1
528528 let feeAmount = $t02483924898._2
529529 let amountBalanceNew = (amountBalanceOld + amountAssetAmount)
530530 let priceBalanceNew = (priceBalanceOld + priceAssetAmount)
531531 let priceNewX18 = calcPriceBigInt(toX18(priceBalanceNew, cfgPriceAssetDecimals), toX18(amountBalanceNew, cfgAmountAssetDecimals))
532532 let priceNew = fromX18(priceNewX18, scale8)
533533 let paymentBalance = if (paymentInAmountAsset)
534534 then amountBalanceOld
535535 else priceBalanceOld
536536 let paymentBalanceBigInt = toBigInt(paymentBalance)
537537 let supplyBigInt = toBigInt(valueOrErrorMessage(assetInfo(cfgLpAssetId), (("asset " + toBase58String(cfgLpAssetId)) + " doesn't exist")).quantity)
538538 let chechSupply = if ((supplyBigInt > big0))
539539 then true
540540 else throwErr("initial deposit requires all coins")
541541 if ((chechSupply == chechSupply))
542542 then {
543543 let depositBigInt = toBigInt(paymentAmount)
544544 let issueAmount = max([0, toInt(((supplyBigInt * (sqrtBigInt((scale18 + ((depositBigInt * scale18) / paymentBalanceBigInt)), 18, 18, DOWN) - scale18)) / scale18))])
545545 let commonState = if (isEval)
546546 then nil
547547 else [IntegerEntry(pl(), priceNew), IntegerEntry(ph(height, lastBlock.timestamp), priceNew), StringEntry(pau(toString(value(userAddress)), toBase58String(value(txId))), dataPutActionInfo(amountAssetAmountRaw, priceAssetAmountRaw, issueAmount, priceNew, 0, 0, height, lastBlock.timestamp, 0, 0))]
548548 let priceOldX18 = calcPriceBigInt(toX18(priceBalanceOld, cfgPriceAssetDecimals), toX18(amountBalanceOld, cfgAmountAssetDecimals))
549549 let priceOld = fromX18(priceOldX18, scale8)
550550 let loss = {
551551 let $t02637526542 = if (paymentInAmountAsset)
552552 then $Tuple2(amountAssetAmountRaw, amountBalanceOld)
553553 else $Tuple2(priceAssetAmountRaw, priceBalanceOld)
554554 let amount = $t02637526542._1
555555 let balance = $t02637526542._2
556556 let issueAmountBoth = toInt(fraction(supplyBigInt, toBigInt((amount / 2)), toBigInt(balance)))
557557 fraction((issueAmount - issueAmountBoth), scale8, issueAmountBoth)
558558 }
559559 $Tuple5(issueAmount, commonState, feeAmount, loss, paymentInAmountAsset)
560560 }
561561 else throw("Strict value is not equal to itself.")
562562 }
563563
564564
565565 func calcGetOneToken (outAssetId,paymentAmount,paymentAssetId,userAddress,txId) = {
566566 let isEval = (txId == unit)
567567 let checks = [if ((paymentAssetId == cfgLpAssetId))
568568 then true
569569 else throwErr("invalid lp asset")]
570570 if ((checks == checks))
571571 then {
572572 let outInAmountAsset = if ((outAssetId == cfgAmountAssetId))
573573 then true
574574 else if ((outAssetId == cfgPriceAssetId))
575575 then false
576576 else throwErr("invalid asset")
577577 let balanceBigInt = if (outInAmountAsset)
578578 then toBigInt(getAccBalance(assetIdToString(cfgAmountAssetId)))
579579 else toBigInt(getAccBalance(assetIdToString(cfgPriceAssetId)))
580580 let amBalanceOld = getAccBalance(assetIdToString(cfgAmountAssetId))
581581 let prBalanceOld = getAccBalance(assetIdToString(cfgPriceAssetId))
582582 let outBalance = if (outInAmountAsset)
583583 then amBalanceOld
584584 else prBalanceOld
585585 let outBalanceBigInt = toBigInt(outBalance)
586586 let supplyBigInt = toBigInt(valueOrErrorMessage(assetInfo(cfgLpAssetId), (("asset " + toBase58String(cfgLpAssetId)) + " doesn't exist")).quantity)
587587 let redeemedBigInt = toBigInt(paymentAmount)
588588 let amountRaw = max([0, toInt(((balanceBigInt * (scale18 - pow((scale18 - ((redeemedBigInt * scale18) / supplyBigInt)), 18, big2, 0, 18, DOWN))) / scale18))])
589589 let $t02814428194 = takeFee(amountRaw)
590590 let totalAmount = $t02814428194._1
591591 let feeAmount = $t02814428194._2
592592 let $t02819828424 = if (outInAmountAsset)
593593 then $Tuple4(totalAmount, 0, (amBalanceOld - amountRaw), prBalanceOld)
594594 else $Tuple4(0, totalAmount, amBalanceOld, (prBalanceOld - amountRaw))
595595 let outAmAmount = $t02819828424._1
596596 let outPrAmount = $t02819828424._2
597597 let amBalanceNew = $t02819828424._3
598598 let prBalanceNew = $t02819828424._4
599599 let priceNewX18 = calcPriceBigInt(toX18(prBalanceNew, cfgPriceAssetDecimals), toX18(amBalanceNew, cfgAmountAssetDecimals))
600600 let priceNew = fromX18(priceNewX18, scale8)
601601 let commonState = if (isEval)
602602 then nil
603603 else [StringEntry(gau(toString(value(userAddress)), toBase58String(value(txId))), dataGetActionInfo(outAmAmount, outPrAmount, paymentAmount, priceNew, height, lastBlock.timestamp)), IntegerEntry(pl(), priceNew), IntegerEntry(ph(height, lastBlock.timestamp), priceNew)]
604604 let priceOldX18 = calcPriceBigInt(toX18(prBalanceOld, cfgPriceAssetDecimals), toX18(amBalanceOld, cfgAmountAssetDecimals))
605605 let priceOld = fromX18(priceOldX18, scale8)
606606 let loss = {
607607 let amountBothInPaymentAsset = (toInt(fraction(balanceBigInt, redeemedBigInt, supplyBigInt)) * 2)
608608 fraction((totalAmount - amountBothInPaymentAsset), scale8, amountBothInPaymentAsset)
609609 }
610610 $Tuple5(totalAmount, commonState, feeAmount, loss, outInAmountAsset)
611611 }
612612 else throw("Strict value is not equal to itself.")
613613 }
614614
615615
616616 func managerPublicKeyOrUnit () = match getString(mpk()) {
617617 case s: String =>
618618 fromBase58String(s)
619619 case _: Unit =>
620620 unit
621621 case _ =>
622622 throw("Match error")
623623 }
624624
625625
626626 func pendingManagerPublicKeyOrUnit () = match getString(pmpk()) {
627627 case s: String =>
628628 fromBase58String(s)
629629 case _: Unit =>
630630 unit
631631 case _ =>
632632 throw("Match error")
633633 }
634634
635635
636636 func isManager (i) = match managerPublicKeyOrUnit() {
637637 case pk: ByteVector =>
638638 (i.callerPublicKey == pk)
639639 case _: Unit =>
640640 (i.caller == this)
641641 case _ =>
642642 throw("Match error")
643643 }
644644
645645
646646 func mustManager (i) = {
647647 let pd = throw("Permission denied")
648648 match managerPublicKeyOrUnit() {
649649 case pk: ByteVector =>
650650 if ((i.callerPublicKey == pk))
651651 then true
652652 else pd
653653 case _: Unit =>
654654 if ((i.caller == this))
655655 then true
656656 else pd
657657 case _ =>
658658 throw("Match error")
659659 }
660660 }
661661
662662
663663 @Callable(i)
664664 func setManager (pendingManagerPublicKey) = {
665665 let checkCaller = mustManager(i)
666666 if ((checkCaller == checkCaller))
667667 then {
668668 let checkManagerPublicKey = fromBase58String(pendingManagerPublicKey)
669669 if ((checkManagerPublicKey == checkManagerPublicKey))
670670 then [StringEntry(pmpk(), pendingManagerPublicKey)]
671671 else throw("Strict value is not equal to itself.")
672672 }
673673 else throw("Strict value is not equal to itself.")
674674 }
675675
676676
677677
678678 @Callable(i)
679679 func confirmManager () = {
680680 let pm = pendingManagerPublicKeyOrUnit()
681681 let hasPM = if (isDefined(pm))
682682 then true
683683 else throw("No pending manager")
684684 if ((hasPM == hasPM))
685685 then {
686686 let checkPM = if ((i.callerPublicKey == value(pm)))
687687 then true
688688 else throw("You are not pending manager")
689689 if ((checkPM == checkPM))
690690 then [StringEntry(mpk(), toBase58String(value(pm))), DeleteEntry(pmpk())]
691691 else throw("Strict value is not equal to itself.")
692692 }
693693 else throw("Strict value is not equal to itself.")
694694 }
695695
696696
697697
698698 @Callable(i)
699699 func put (slippageTolerance,shouldAutoStake) = if ((0 > slippageTolerance))
700700 then throw("Invalid slippageTolerance passed")
701701 else {
702702 let estPut = commonPut(i, slippageTolerance, true)
703703 let emitLpAmt = estPut._2
704704 let lpAssetId = estPut._7
705705 let state = estPut._9
706706 let amDiff = estPut._10
707707 let prDiff = estPut._11
708708 let amId = estPut._12
709709 let prId = estPut._13
710710 let amAssetPmt = toBigInt(value(i.payments[0]).amount)
711711 let prAssetPmt = toBigInt(value(i.payments[1]).amount)
712- let amountAssetBalance = (toBigInt(getAccBalance(assetIdToString(cfgAmountAssetId))) - amAssetPmt)
713- if ((amountAssetBalance == amountAssetBalance))
712+ let currentKLp = calcCurrentKLp(amAssetPmt, prAssetPmt, toBigInt(0))
713+ if ((currentKLp == currentKLp))
714714 then {
715- let priceAssetBalance = (toBigInt(getAccBalance(assetIdToString(cfgPriceAssetId))) - prAssetPmt)
716- if ((priceAssetBalance == priceAssetBalance))
715+ let emitInv = invoke(factoryContract, "emit", [emitLpAmt], nil)
716+ if ((emitInv == emitInv))
717717 then {
718- let lpAssetEmission = toBigInt(value(assetInfo(cfgLpAssetId)).quantity)
719- if ((lpAssetEmission == lpAssetEmission))
718+ let emitInvLegacy = match emitInv {
719+ case legacyFactoryContract: Address =>
720+ invoke(legacyFactoryContract, "emit", [emitLpAmt], nil)
721+ case _ =>
722+ unit
723+ }
724+ if ((emitInvLegacy == emitInvLegacy))
720725 then {
721- let currentKLp = calcCurrentKLp(amAssetPmt, prAssetPmt, toBigInt(0))
722- if ((currentKLp == currentKLp))
726+ let slippageAInv = if ((amDiff > 0))
727+ then invoke(slippageContract, "put", nil, [AttachedPayment(amId, amDiff)])
728+ else nil
729+ if ((slippageAInv == slippageAInv))
723730 then {
724- let emitInv = invoke(factoryContract, "emit", [emitLpAmt], nil)
725- if ((emitInv == emitInv))
731+ let slippagePInv = if ((prDiff > 0))
732+ then invoke(slippageContract, "put", nil, [AttachedPayment(prId, prDiff)])
733+ else nil
734+ if ((slippagePInv == slippagePInv))
726735 then {
727- let emitInvLegacy = match emitInv {
728- case legacyFactoryContract: Address =>
729- invoke(legacyFactoryContract, "emit", [emitLpAmt], nil)
730- case _ =>
731- unit
732- }
733- if ((emitInvLegacy == emitInvLegacy))
736+ let lpTransfer = if (shouldAutoStake)
734737 then {
735- let slippageAInv = if ((amDiff > 0))
736- then invoke(slippageContract, "put", nil, [AttachedPayment(amId, amDiff)])
737- else nil
738- if ((slippageAInv == slippageAInv))
739- then {
740- let slippagePInv = if ((prDiff > 0))
741- then invoke(slippageContract, "put", nil, [AttachedPayment(prId, prDiff)])
742- else nil
743- if ((slippagePInv == slippagePInv))
744- then {
745- let lpTransfer = if (shouldAutoStake)
746- then {
747- let slpStakeInv = invoke(stakingContract, "stake", nil, [AttachedPayment(lpAssetId, emitLpAmt)])
748- if ((slpStakeInv == slpStakeInv))
749- then nil
750- else throw("Strict value is not equal to itself.")
751- }
752- else [ScriptTransfer(i.caller, emitLpAmt, lpAssetId)]
753- let lpAssetEmissionAfter = value(assetInfo(cfgLpAssetId)).quantity
754- if ((lpAssetEmissionAfter == lpAssetEmissionAfter))
755- then {
756- let $t03294433012 = refreshKLpInternal(0, 0, 0)
757- if (($t03294433012 == $t03294433012))
758- then {
759- let updatedKLp = $t03294433012._2
760- let refreshKLpActions = $t03294433012._1
761- let error = throwErr(makeString([toString(amountAssetBalance), toString(priceAssetBalance), toString(lpAssetEmission), toString(currentKLp), toString(updatedKLp), toString(emitLpAmt), toString(amDiff), toString(prDiff), toString(lpAssetEmission), toString(lpAssetEmissionAfter)], " "))
762- if ((error == error))
763- then {
764- let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
765- if ((isUpdatedKLpValid == isUpdatedKLpValid))
766- then ((state ++ lpTransfer) ++ refreshKLpActions)
767- else throw("Strict value is not equal to itself.")
768- }
769- else throw("Strict value is not equal to itself.")
770- }
771- else throw("Strict value is not equal to itself.")
772- }
773- else throw("Strict value is not equal to itself.")
774- }
775- else throw("Strict value is not equal to itself.")
776- }
738+ let slpStakeInv = invoke(stakingContract, "stake", nil, [AttachedPayment(lpAssetId, emitLpAmt)])
739+ if ((slpStakeInv == slpStakeInv))
740+ then nil
741+ else throw("Strict value is not equal to itself.")
742+ }
743+ else [ScriptTransfer(i.caller, emitLpAmt, lpAssetId)]
744+ let $t03295233414 = refreshKLpInternal(0, 0, 0)
745+ if (($t03295233414 == $t03295233414))
746+ then {
747+ let updatedKLp = $t03295233414._2
748+ let refreshKLpActions = $t03295233414._1
749+ let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
750+ if ((isUpdatedKLpValid == isUpdatedKLpValid))
751+ then ((state ++ lpTransfer) ++ refreshKLpActions)
777752 else throw("Strict value is not equal to itself.")
778753 }
779754 else throw("Strict value is not equal to itself.")
780755 }
781756 else throw("Strict value is not equal to itself.")
782757 }
783758 else throw("Strict value is not equal to itself.")
784759 }
785760 else throw("Strict value is not equal to itself.")
786761 }
787762 else throw("Strict value is not equal to itself.")
788763 }
789764 else throw("Strict value is not equal to itself.")
790765 }
791766
792767
793768
794769 @Callable(i)
795770 func putForFree (maxSlippage) = if ((0 > maxSlippage))
796771 then throw("Invalid value passed")
797772 else {
798773 let estPut = commonPut(i, maxSlippage, false)
799774 let state = estPut._9
800775 let amAssetPmt = toBigInt(value(i.payments[0]).amount)
801776 let prAssetPmt = toBigInt(value(i.payments[1]).amount)
802777 let currentKLp = calcCurrentKLp(amAssetPmt, prAssetPmt, toBigInt(0))
803778 if ((currentKLp == currentKLp))
804779 then {
805- let $t03394434009 = refreshKLpInternal(0, 0, 0)
806- let refreshKLpActions = $t03394434009._1
807- let updatedKLp = $t03394434009._2
780+ let $t03397634041 = refreshKLpInternal(0, 0, 0)
781+ let refreshKLpActions = $t03397634041._1
782+ let updatedKLp = $t03397634041._2
808783 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
809784 if ((isUpdatedKLpValid == isUpdatedKLpValid))
810785 then (state ++ refreshKLpActions)
811786 else throw("Strict value is not equal to itself.")
812787 }
813788 else throw("Strict value is not equal to itself.")
814789 }
815790
816791
817792
818793 @Callable(i)
819794 func putOneTkn (minOutAmount,autoStake) = {
820795 let isPoolOneTokenOperationsDisabled = {
821796 let @ = invoke(factoryContract, "isPoolOneTokenOperationsDisabledREADONLY", [toString(this)], nil)
822797 if ($isInstanceOf(@, "Boolean"))
823798 then @
824799 else throw(($getType(@) + " couldn't be cast to Boolean"))
825800 }
826801 let isPutDisabled = if (if (if (isGlobalShutdown())
827802 then true
828803 else (cfgPoolStatus == PoolPutDisabled))
829804 then true
830805 else (cfgPoolStatus == PoolShutdown))
831806 then true
832807 else isPoolOneTokenOperationsDisabled
833808 let checks = [if (if (!(isPutDisabled))
834809 then true
835810 else isManager(i))
836811 then true
837812 else throwErr("put operation is blocked by admin"), if ((size(i.payments) == 1))
838813 then true
839814 else throwErr("exactly 1 payment are expected")]
840815 if ((checks == checks))
841816 then {
842817 let payment = i.payments[0]
843818 let paymentAssetId = payment.assetId
844819 let paymentAmountRaw = payment.amount
845820 let currentKLp = if ((paymentAssetId == cfgAmountAssetId))
846821 then calcCurrentKLp(toBigInt(paymentAmountRaw), toBigInt(0), toBigInt(0))
847822 else if ((paymentAssetId == cfgPriceAssetId))
848823 then calcCurrentKLp(toBigInt(0), toBigInt(paymentAmountRaw), toBigInt(0))
849824 else throwErr("payment asset is not supported")
850825 let userAddress = i.caller
851826 let txId = i.transactionId
852- let $t03519435346 = calcPutOneToken(paymentAmountRaw, paymentAssetId, userAddress, txId)
853- if (($t03519435346 == $t03519435346))
827+ let $t03522635378 = calcPutOneToken(paymentAmountRaw, paymentAssetId, userAddress, txId)
828+ if (($t03522635378 == $t03522635378))
854829 then {
855- let paymentInAmountAsset = $t03519435346._5
856- let bonus = $t03519435346._4
857- let feeAmount = $t03519435346._3
858- let commonState = $t03519435346._2
859- let emitAmountEstimated = $t03519435346._1
830+ let paymentInAmountAsset = $t03522635378._5
831+ let bonus = $t03522635378._4
832+ let feeAmount = $t03522635378._3
833+ let commonState = $t03522635378._2
834+ let emitAmountEstimated = $t03522635378._1
860835 let emitAmount = if (if ((minOutAmount > 0))
861836 then (minOutAmount > emitAmountEstimated)
862837 else false)
863838 then throwErr(makeString(["amount to receive is less than ", toString(minOutAmount)], ""))
864839 else emitAmountEstimated
865840 let emitInv = emit(emitAmount)
866841 if ((emitInv == emitInv))
867842 then {
868843 let lpTransfer = if (autoStake)
869844 then {
870845 let stakeInv = invoke(stakingContract, "stake", nil, [AttachedPayment(cfgLpAssetId, emitAmount)])
871846 if ((stakeInv == stakeInv))
872847 then nil
873848 else throw("Strict value is not equal to itself.")
874849 }
875850 else [ScriptTransfer(i.caller, emitAmount, cfgLpAssetId)]
876851 let sendFee = if ((feeAmount > 0))
877852 then [ScriptTransfer(feeCollectorAddress, feeAmount, paymentAssetId)]
878853 else nil
879- let $t03593236129 = if ((this == feeCollectorAddress))
854+ let $t03596436161 = if ((this == feeCollectorAddress))
880855 then $Tuple2(0, 0)
881856 else if (paymentInAmountAsset)
882857 then $Tuple2(-(feeAmount), 0)
883858 else $Tuple2(0, -(feeAmount))
884- let amountAssetBalanceDelta = $t03593236129._1
885- let priceAssetBalanceDelta = $t03593236129._2
886- let $t03613236240 = refreshKLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
887- let refreshKLpActions = $t03613236240._1
888- let updatedKLp = $t03613236240._2
859+ let amountAssetBalanceDelta = $t03596436161._1
860+ let priceAssetBalanceDelta = $t03596436161._2
861+ let $t03616436272 = refreshKLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
862+ let refreshKLpActions = $t03616436272._1
863+ let updatedKLp = $t03616436272._2
889864 let kLp = value(getString(keyKLp))
890865 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
891866 if ((isUpdatedKLpValid == isUpdatedKLpValid))
892867 then $Tuple2((((commonState ++ lpTransfer) ++ sendFee) ++ refreshKLpActions), emitAmount)
893868 else throw("Strict value is not equal to itself.")
894869 }
895870 else throw("Strict value is not equal to itself.")
896871 }
897872 else throw("Strict value is not equal to itself.")
898873 }
899874 else throw("Strict value is not equal to itself.")
900875 }
901876
902877
903878
904879 @Callable(i)
905880 func putOneTknREADONLY (paymentAssetId,paymentAmountRaw) = {
906- let $t03654636703 = calcPutOneToken(paymentAmountRaw, parseAssetId(paymentAssetId), unit, unit)
907- let emitAmountEstimated = $t03654636703._1
908- let commonState = $t03654636703._2
909- let feeAmount = $t03654636703._3
910- let bonus = $t03654636703._4
911- let paymentInAmountAsset = $t03654636703._5
881+ let $t03657836735 = calcPutOneToken(paymentAmountRaw, parseAssetId(paymentAssetId), unit, unit)
882+ let emitAmountEstimated = $t03657836735._1
883+ let commonState = $t03657836735._2
884+ let feeAmount = $t03657836735._3
885+ let bonus = $t03657836735._4
886+ let paymentInAmountAsset = $t03657836735._5
912887 $Tuple2(nil, $Tuple3(emitAmountEstimated, feeAmount, bonus))
913888 }
914889
915890
916891
917892 @Callable(i)
918893 func getOneTkn (outAssetIdStr,minOutAmount) = {
919894 let isPoolOneTokenOperationsDisabled = {
920895 let @ = invoke(factoryContract, "isPoolOneTokenOperationsDisabledREADONLY", [toString(this)], nil)
921896 if ($isInstanceOf(@, "Boolean"))
922897 then @
923898 else throw(($getType(@) + " couldn't be cast to Boolean"))
924899 }
925900 let isGetDisabled = if (if (isGlobalShutdown())
926901 then true
927902 else (cfgPoolStatus == PoolShutdown))
928903 then true
929904 else isPoolOneTokenOperationsDisabled
930905 let checks = [if (if (!(isGetDisabled))
931906 then true
932907 else isManager(i))
933908 then true
934909 else throwErr("get operation is blocked by admin"), if ((size(i.payments) == 1))
935910 then true
936911 else throwErr("exactly 1 payment are expected")]
937912 if ((checks == checks))
938913 then {
939914 let outAssetId = parseAssetId(outAssetIdStr)
940915 let payment = i.payments[0]
941916 let paymentAssetId = payment.assetId
942917 let paymentAmount = payment.amount
943918 let currentKLp = calcCurrentKLp(toBigInt(0), toBigInt(0), toBigInt(paymentAmount))
944919 let userAddress = i.caller
945920 let txId = i.transactionId
946- let $t03759737750 = calcGetOneToken(outAssetId, paymentAmount, paymentAssetId, userAddress, txId)
947- if (($t03759737750 == $t03759737750))
921+ let $t03762937782 = calcGetOneToken(outAssetId, paymentAmount, paymentAssetId, userAddress, txId)
922+ if (($t03762937782 == $t03762937782))
948923 then {
949- let outInAmountAsset = $t03759737750._5
950- let bonus = $t03759737750._4
951- let feeAmount = $t03759737750._3
952- let commonState = $t03759737750._2
953- let amountEstimated = $t03759737750._1
924+ let outInAmountAsset = $t03762937782._5
925+ let bonus = $t03762937782._4
926+ let feeAmount = $t03762937782._3
927+ let commonState = $t03762937782._2
928+ let amountEstimated = $t03762937782._1
954929 let amount = if (if ((minOutAmount > 0))
955930 then (minOutAmount > amountEstimated)
956931 else false)
957932 then throwErr(makeString(["amount to receive is less than ", toString(minOutAmount)], ""))
958933 else amountEstimated
959934 let burnInv = invoke(factoryContract, "burn", [paymentAmount], [AttachedPayment(paymentAssetId, paymentAmount)])
960935 if ((burnInv == burnInv))
961936 then {
962937 let assetTransfer = [ScriptTransfer(userAddress, amount, outAssetId)]
963938 let sendFee = if ((feeAmount > 0))
964939 then [ScriptTransfer(feeCollectorAddress, feeAmount, outAssetId)]
965940 else nil
966- let $t03825038497 = {
941+ let $t03828238529 = {
967942 let feeAmountForCalc = if ((this == feeCollectorAddress))
968943 then 0
969944 else feeAmount
970945 if (outInAmountAsset)
971946 then $Tuple2(-((amount + feeAmountForCalc)), 0)
972947 else $Tuple2(0, -((amount + feeAmountForCalc)))
973948 }
974- let amountAssetBalanceDelta = $t03825038497._1
975- let priceAssetBalanceDelta = $t03825038497._2
976- let $t03850038608 = refreshKLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
977- let refreshKLpActions = $t03850038608._1
978- let updatedKLp = $t03850038608._2
949+ let amountAssetBalanceDelta = $t03828238529._1
950+ let priceAssetBalanceDelta = $t03828238529._2
951+ let $t03853238640 = refreshKLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
952+ let refreshKLpActions = $t03853238640._1
953+ let updatedKLp = $t03853238640._2
979954 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
980955 if ((isUpdatedKLpValid == isUpdatedKLpValid))
981956 then $Tuple2((((commonState ++ assetTransfer) ++ sendFee) ++ refreshKLpActions), amount)
982957 else throw("Strict value is not equal to itself.")
983958 }
984959 else throw("Strict value is not equal to itself.")
985960 }
986961 else throw("Strict value is not equal to itself.")
987962 }
988963 else throw("Strict value is not equal to itself.")
989964 }
990965
991966
992967
993968 @Callable(i)
994969 func getOneTknREADONLY (outAssetId,paymentAmount) = {
995- let $t03886539021 = calcGetOneToken(parseAssetId(outAssetId), paymentAmount, cfgLpAssetId, unit, unit)
996- let amountEstimated = $t03886539021._1
997- let commonState = $t03886539021._2
998- let feeAmount = $t03886539021._3
999- let bonus = $t03886539021._4
1000- let outInAmountAsset = $t03886539021._5
970+ let $t03889739053 = calcGetOneToken(parseAssetId(outAssetId), paymentAmount, cfgLpAssetId, unit, unit)
971+ let amountEstimated = $t03889739053._1
972+ let commonState = $t03889739053._2
973+ let feeAmount = $t03889739053._3
974+ let bonus = $t03889739053._4
975+ let outInAmountAsset = $t03889739053._5
1001976 $Tuple2(nil, $Tuple3(amountEstimated, feeAmount, bonus))
1002977 }
1003978
1004979
1005980
1006981 @Callable(i)
1007982 func unstakeAndGetOneTkn (unstakeAmount,outAssetIdStr,minOutAmount) = {
1008983 let isPoolOneTokenOperationsDisabled = {
1009984 let @ = invoke(factoryContract, "isPoolOneTokenOperationsDisabledREADONLY", [toString(this)], nil)
1010985 if ($isInstanceOf(@, "Boolean"))
1011986 then @
1012987 else throw(($getType(@) + " couldn't be cast to Boolean"))
1013988 }
1014989 let isGetDisabled = if (if (isGlobalShutdown())
1015990 then true
1016991 else (cfgPoolStatus == PoolShutdown))
1017992 then true
1018993 else isPoolOneTokenOperationsDisabled
1019994 let checks = [if (if (!(isGetDisabled))
1020995 then true
1021996 else isManager(i))
1022997 then true
1023998 else throwErr("get operation is blocked by admin"), if ((size(i.payments) == 0))
1024999 then true
10251000 else throwErr("no payments are expected")]
10261001 if ((checks == checks))
10271002 then {
10281003 let outAssetId = parseAssetId(outAssetIdStr)
10291004 let userAddress = i.caller
10301005 let txId = i.transactionId
10311006 let currentKLp = calcCurrentKLp(toBigInt(0), toBigInt(0), toBigInt(0))
10321007 let unstakeInv = invoke(stakingContract, "unstake", [toBase58String(cfgLpAssetId), unstakeAmount], nil)
10331008 if ((unstakeInv == unstakeInv))
10341009 then {
1035- let $t03992340074 = calcGetOneToken(outAssetId, unstakeAmount, cfgLpAssetId, userAddress, txId)
1036- if (($t03992340074 == $t03992340074))
1010+ let $t03995540106 = calcGetOneToken(outAssetId, unstakeAmount, cfgLpAssetId, userAddress, txId)
1011+ if (($t03995540106 == $t03995540106))
10371012 then {
1038- let outInAmountAsset = $t03992340074._5
1039- let bonus = $t03992340074._4
1040- let feeAmount = $t03992340074._3
1041- let commonState = $t03992340074._2
1042- let amountEstimated = $t03992340074._1
1013+ let outInAmountAsset = $t03995540106._5
1014+ let bonus = $t03995540106._4
1015+ let feeAmount = $t03995540106._3
1016+ let commonState = $t03995540106._2
1017+ let amountEstimated = $t03995540106._1
10431018 let amount = if (if ((minOutAmount > 0))
10441019 then (minOutAmount > amountEstimated)
10451020 else false)
10461021 then throwErr(makeString(["amount to receive is less than ", toString(minOutAmount)], ""))
10471022 else amountEstimated
10481023 let burnInv = invoke(factoryContract, "burn", [unstakeAmount], [AttachedPayment(cfgLpAssetId, unstakeAmount)])
10491024 if ((burnInv == burnInv))
10501025 then {
10511026 let assetTransfer = [ScriptTransfer(i.caller, amount, outAssetId)]
10521027 let sendFee = if ((feeAmount > 0))
10531028 then [ScriptTransfer(feeCollectorAddress, feeAmount, outAssetId)]
10541029 else nil
1055- let $t04056940816 = {
1030+ let $t04060140848 = {
10561031 let feeAmountForCalc = if ((this == feeCollectorAddress))
10571032 then 0
10581033 else feeAmount
10591034 if (outInAmountAsset)
10601035 then $Tuple2(-((amount + feeAmountForCalc)), 0)
10611036 else $Tuple2(0, -((amount + feeAmountForCalc)))
10621037 }
1063- let amountAssetBalanceDelta = $t04056940816._1
1064- let priceAssetBalanceDelta = $t04056940816._2
1065- let $t04081940927 = refreshKLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
1066- let refreshKLpActions = $t04081940927._1
1067- let updatedKLp = $t04081940927._2
1038+ let amountAssetBalanceDelta = $t04060140848._1
1039+ let priceAssetBalanceDelta = $t04060140848._2
1040+ let $t04085140959 = refreshKLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
1041+ let refreshKLpActions = $t04085140959._1
1042+ let updatedKLp = $t04085140959._2
10681043 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
10691044 if ((isUpdatedKLpValid == isUpdatedKLpValid))
10701045 then $Tuple2((((commonState ++ assetTransfer) ++ sendFee) ++ refreshKLpActions), amount)
10711046 else throw("Strict value is not equal to itself.")
10721047 }
10731048 else throw("Strict value is not equal to itself.")
10741049 }
10751050 else throw("Strict value is not equal to itself.")
10761051 }
10771052 else throw("Strict value is not equal to itself.")
10781053 }
10791054 else throw("Strict value is not equal to itself.")
10801055 }
10811056
10821057
10831058
10841059 @Callable(i)
10851060 func get () = {
10861061 let res = commonGet(i)
10871062 let outAmtAmt = res._1
10881063 let outPrAmt = res._2
10891064 let pmtAmt = res._3
10901065 let pmtAssetId = res._4
10911066 let state = res._5
10921067 let currentKLp = calcCurrentKLp(toBigInt(0), toBigInt(0), toBigInt(pmtAmt))
10931068 let burnLPAssetOnFactory = invoke(factoryContract, "burn", [pmtAmt], [AttachedPayment(pmtAssetId, pmtAmt)])
10941069 if ((burnLPAssetOnFactory == burnLPAssetOnFactory))
10951070 then {
1096- let $t04187541957 = refreshKLpInternal(-(outAmtAmt), -(outPrAmt), 0)
1097- let refreshKLpActions = $t04187541957._1
1098- let updatedKLp = $t04187541957._2
1071+ let $t04190741989 = refreshKLpInternal(-(outAmtAmt), -(outPrAmt), 0)
1072+ let refreshKLpActions = $t04190741989._1
1073+ let updatedKLp = $t04190741989._2
10991074 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
11001075 if ((isUpdatedKLpValid == isUpdatedKLpValid))
11011076 then (state ++ refreshKLpActions)
11021077 else throw("Strict value is not equal to itself.")
11031078 }
11041079 else throw("Strict value is not equal to itself.")
11051080 }
11061081
11071082
11081083
11091084 @Callable(i)
11101085 func getNoLess (noLessThenAmtAsset,noLessThenPriceAsset) = {
11111086 let res = commonGet(i)
11121087 let outAmAmt = res._1
11131088 let outPrAmt = res._2
11141089 let pmtAmt = res._3
11151090 let pmtAssetId = res._4
11161091 let state = res._5
11171092 if ((noLessThenAmtAsset > outAmAmt))
11181093 then throw(((("noLessThenAmtAsset failed: " + toString(outAmAmt)) + " < ") + toString(noLessThenAmtAsset)))
11191094 else if ((noLessThenPriceAsset > outPrAmt))
11201095 then throw(((("noLessThenPriceAsset failed: " + toString(outPrAmt)) + " < ") + toString(noLessThenPriceAsset)))
11211096 else {
11221097 let currentKLp = calcCurrentKLp(toBigInt(0), toBigInt(0), toBigInt(pmtAmt))
11231098 let burnLPAssetOnFactory = invoke(factoryContract, "burn", [pmtAmt], [AttachedPayment(pmtAssetId, pmtAmt)])
11241099 if ((burnLPAssetOnFactory == burnLPAssetOnFactory))
11251100 then {
1126- let $t04290842989 = refreshKLpInternal(-(outAmAmt), -(outPrAmt), 0)
1127- let refreshKLpActions = $t04290842989._1
1128- let updatedKLp = $t04290842989._2
1101+ let $t04294043021 = refreshKLpInternal(-(outAmAmt), -(outPrAmt), 0)
1102+ let refreshKLpActions = $t04294043021._1
1103+ let updatedKLp = $t04294043021._2
11291104 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
11301105 if ((isUpdatedKLpValid == isUpdatedKLpValid))
11311106 then (state ++ refreshKLpActions)
11321107 else throw("Strict value is not equal to itself.")
11331108 }
11341109 else throw("Strict value is not equal to itself.")
11351110 }
11361111 }
11371112
11381113
11391114
11401115 @Callable(i)
11411116 func unstakeAndGet (amount) = {
11421117 let checkPayments = if ((size(i.payments) != 0))
11431118 then throw("No payments are expected")
11441119 else true
11451120 if ((checkPayments == checkPayments))
11461121 then {
11471122 let cfg = getPoolConfig()
11481123 let lpAssetId = fromBase58String(cfg[idxPoolLPAssetId])
11491124 let currentKLp = calcCurrentKLp(toBigInt(0), toBigInt(0), toBigInt(0))
11501125 let unstakeInv = invoke(stakingContract, "unstake", [toBase58String(lpAssetId), amount], nil)
11511126 if ((unstakeInv == unstakeInv))
11521127 then {
11531128 let res = estimateGetOperation(toBase58String(i.transactionId), toBase58String(lpAssetId), amount, i.caller)
11541129 let outAmAmt = res._1
11551130 let outPrAmt = res._2
11561131 let poolStatus = parseIntValue(res._9)
11571132 let state = res._10
11581133 let checkPoolStatus = if (if (isGlobalShutdown())
11591134 then true
11601135 else (poolStatus == PoolShutdown))
11611136 then throw(("Get operation is blocked by admin. Status = " + toString(poolStatus)))
11621137 else true
11631138 if ((checkPoolStatus == checkPoolStatus))
11641139 then {
11651140 let burnLPAssetOnFactory = invoke(factoryContract, "burn", [amount], [AttachedPayment(lpAssetId, amount)])
11661141 if ((burnLPAssetOnFactory == burnLPAssetOnFactory))
11671142 then {
1168- let $t04411244193 = refreshKLpInternal(-(outAmAmt), -(outPrAmt), 0)
1169- let refreshKLpActions = $t04411244193._1
1170- let updatedKLp = $t04411244193._2
1143+ let $t04414444225 = refreshKLpInternal(-(outAmAmt), -(outPrAmt), 0)
1144+ let refreshKLpActions = $t04414444225._1
1145+ let updatedKLp = $t04414444225._2
11711146 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
11721147 if ((isUpdatedKLpValid == isUpdatedKLpValid))
11731148 then (state ++ refreshKLpActions)
11741149 else throw("Strict value is not equal to itself.")
11751150 }
11761151 else throw("Strict value is not equal to itself.")
11771152 }
11781153 else throw("Strict value is not equal to itself.")
11791154 }
11801155 else throw("Strict value is not equal to itself.")
11811156 }
11821157 else throw("Strict value is not equal to itself.")
11831158 }
11841159
11851160
11861161
11871162 @Callable(i)
11881163 func unstakeAndGetNoLess (unstakeAmount,noLessThenAmountAsset,noLessThenPriceAsset) = {
11891164 let isGetDisabled = if (isGlobalShutdown())
11901165 then true
11911166 else (cfgPoolStatus == PoolShutdown)
11921167 let checks = [if (!(isGetDisabled))
11931168 then true
11941169 else throw("get operation is blocked by admin"), if ((size(i.payments) == 0))
11951170 then true
11961171 else throw("no payments are expected")]
11971172 if ((checks == checks))
11981173 then {
11991174 let currentKLp = calcCurrentKLp(toBigInt(0), toBigInt(0), toBigInt(0))
12001175 let unstakeInv = invoke(stakingContract, "unstake", [toBase58String(cfgLpAssetId), unstakeAmount], nil)
12011176 if ((unstakeInv == unstakeInv))
12021177 then {
12031178 let res = estimateGetOperation(toBase58String(i.transactionId), toBase58String(cfgLpAssetId), unstakeAmount, i.caller)
12041179 let outAmAmt = res._1
12051180 let outPrAmt = res._2
12061181 let state = res._10
12071182 let checkAmounts = [if ((outAmAmt >= noLessThenAmountAsset))
12081183 then true
12091184 else throw(makeString(["amount asset amount to receive is less than ", toString(noLessThenAmountAsset)], "")), if ((outPrAmt >= noLessThenPriceAsset))
12101185 then true
12111186 else throw(makeString(["price asset amount to receive is less than ", toString(noLessThenPriceAsset)], ""))]
12121187 if ((checkAmounts == checkAmounts))
12131188 then {
12141189 let burnLPAssetOnFactory = invoke(factoryContract, "burn", [unstakeAmount], [AttachedPayment(cfgLpAssetId, unstakeAmount)])
12151190 if ((burnLPAssetOnFactory == burnLPAssetOnFactory))
12161191 then {
1217- let $t04548545566 = refreshKLpInternal(-(outAmAmt), -(outPrAmt), 0)
1218- let refreshKLpActions = $t04548545566._1
1219- let updatedKLp = $t04548545566._2
1192+ let $t04551745598 = refreshKLpInternal(-(outAmAmt), -(outPrAmt), 0)
1193+ let refreshKLpActions = $t04551745598._1
1194+ let updatedKLp = $t04551745598._2
12201195 let isUpdatedKLpValid = validateUpdatedKLp(currentKLp, updatedKLp)
12211196 if ((isUpdatedKLpValid == isUpdatedKLpValid))
12221197 then (state ++ refreshKLpActions)
12231198 else throw("Strict value is not equal to itself.")
12241199 }
12251200 else throw("Strict value is not equal to itself.")
12261201 }
12271202 else throw("Strict value is not equal to itself.")
12281203 }
12291204 else throw("Strict value is not equal to itself.")
12301205 }
12311206 else throw("Strict value is not equal to itself.")
12321207 }
12331208
12341209
12351210
12361211 @Callable(i)
12371212 func activate (amtAssetStr,priceAssetStr) = if ((toString(i.caller) != toString(factoryContract)))
12381213 then throw("permissions denied")
12391214 else $Tuple2([StringEntry(aa(), amtAssetStr), StringEntry(pa(), priceAssetStr)], "success")
12401215
12411216
12421217
12431218 @Callable(i)
12441219 func refreshKLp () = {
12451220 let lastRefreshedBlockHeight = valueOrElse(getInteger(keyKLpRefreshedHeight), 0)
12461221 let checkLastRefreshedBlockHeight = if (((height - lastRefreshedBlockHeight) >= kLpRefreshDelay))
12471222 then unit
12481223 else throwErr(makeString([toString(kLpRefreshDelay), " blocks have not passed since the previous call"], ""))
12491224 if ((checkLastRefreshedBlockHeight == checkLastRefreshedBlockHeight))
12501225 then {
12511226 let kLp = valueOrErrorMessage(parseBigInt(valueOrElse(getString(this, keyKLp), "0")), fmtErr("invalid kLp"))
1252- let $t04675346817 = refreshKLpInternal(0, 0, 0)
1253- let kLpUpdateActions = $t04675346817._1
1254- let updatedKLp = $t04675346817._2
1227+ let $t04678546849 = refreshKLpInternal(0, 0, 0)
1228+ let kLpUpdateActions = $t04678546849._1
1229+ let updatedKLp = $t04678546849._2
12551230 let actions = if ((kLp != updatedKLp))
12561231 then kLpUpdateActions
12571232 else throwErr("nothing to refresh")
12581233 $Tuple2(actions, toString(updatedKLp))
12591234 }
12601235 else throw("Strict value is not equal to itself.")
12611236 }
12621237
12631238
12641239
12651240 @Callable(i)
12661241 func getPoolConfigWrapperREADONLY () = $Tuple2(nil, getPoolConfig())
12671242
12681243
12691244
12701245 @Callable(i)
12711246 func getAccBalanceWrapperREADONLY (assetId) = $Tuple2(nil, getAccBalance(assetId))
12721247
12731248
12741249
12751250 @Callable(i)
12761251 func calcPricesWrapperREADONLY (amAmt,prAmt,lpAmt) = {
12771252 let prices = calcPrices(amAmt, prAmt, lpAmt)
12781253 $Tuple2(nil, [toString(prices[0]), toString(prices[1]), toString(prices[2])])
12791254 }
12801255
12811256
12821257
12831258 @Callable(i)
12841259 func toX18WrapperREADONLY (origVal,origScaleMult) = $Tuple2(nil, toString(toX18(origVal, origScaleMult)))
12851260
12861261
12871262
12881263 @Callable(i)
12891264 func fromX18WrapperREADONLY (val,resultScaleMult) = $Tuple2(nil, fromX18(parseBigIntValue(val), resultScaleMult))
12901265
12911266
12921267
12931268 @Callable(i)
12941269 func calcPriceBigIntWrapperREADONLY (prAmtX18,amAmtX18) = $Tuple2(nil, toString(calcPriceBigInt(parseBigIntValue(prAmtX18), parseBigIntValue(amAmtX18))))
12951270
12961271
12971272
12981273 @Callable(i)
12991274 func estimatePutOperationWrapperREADONLY (txId58,slippageTolerance,inAmAssetAmt,inAmAssetId,inPrAssetAmt,inPrAssetId,userAddress,isEvaluate,emitLp) = $Tuple2(nil, estimatePutOperation(txId58, slippageTolerance, inAmAssetAmt, inAmAssetId, inPrAssetAmt, inPrAssetId, userAddress, isEvaluate, emitLp))
13001275
13011276
13021277
13031278 @Callable(i)
13041279 func estimateGetOperationWrapperREADONLY (txId58,pmtAssetId,pmtLpAmt,userAddress) = {
13051280 let res = estimateGetOperation(txId58, pmtAssetId, pmtLpAmt, addressFromStringValue(userAddress))
13061281 $Tuple2(nil, $Tuple10(res._1, res._2, res._3, res._4, res._5, res._6, res._7, toString(res._8), res._9, res._10))
13071282 }
13081283
13091284
13101285
13111286 @Callable(i)
13121287 func statsREADONLY () = {
13131288 let cfg = getPoolConfig()
13141289 let lpAssetId = fromBase58String(cfg[idxPoolLPAssetId])
13151290 let amtAssetId = cfg[idxAmtAssetId]
13161291 let priceAssetId = cfg[idxPriceAssetId]
13171292 let iAmtAssetId = cfg[idxIAmtAssetId]
13181293 let iPriceAssetId = cfg[idxIPriceAssetId]
13191294 let amtAssetDcm = parseIntValue(cfg[idxAmtAssetDcm])
13201295 let priceAssetDcm = parseIntValue(cfg[idxPriceAssetDcm])
13211296 let poolLPBalance = valueOrErrorMessage(assetInfo(lpAssetId), (("Asset " + toBase58String(lpAssetId)) + " doesn't exist")).quantity
13221297 let accAmtAssetBalance = getAccBalance(amtAssetId)
13231298 let accPriceAssetBalance = getAccBalance(priceAssetId)
13241299 let pricesList = if ((poolLPBalance == 0))
13251300 then [zeroBigInt, zeroBigInt, zeroBigInt]
13261301 else calcPrices(accAmtAssetBalance, accPriceAssetBalance, poolLPBalance)
13271302 let curPrice = 0
13281303 let lpAmtAssetShare = fromX18(pricesList[1], scale8)
13291304 let lpPriceAssetShare = fromX18(pricesList[2], scale8)
13301305 let poolWeight = value(getInteger(factoryContract, keyPoolWeight(toString(this))))
13311306 $Tuple2(nil, makeString(["%d%d%d%d%d%d%d", toString(accAmtAssetBalance), toString(accPriceAssetBalance), toString(poolLPBalance), toString(curPrice), toString(lpAmtAssetShare), toString(lpPriceAssetShare), toString(poolWeight)], SEP))
13321307 }
13331308
13341309
13351310
13361311 @Callable(i)
13371312 func evaluatePutByAmountAssetREADONLY (inAmAssetAmt) = {
13381313 let cfg = getPoolConfig()
13391314 let lpAssetId = fromBase58String(cfg[idxPoolLPAssetId])
13401315 let amAssetIdStr = cfg[idxAmtAssetId]
13411316 let amAssetId = fromBase58String(amAssetIdStr)
13421317 let prAssetIdStr = cfg[idxPriceAssetId]
13431318 let prAssetId = fromBase58String(prAssetIdStr)
13441319 let amtAssetDcm = parseIntValue(cfg[idxAmtAssetDcm])
13451320 let priceAssetDcm = parseIntValue(cfg[idxPriceAssetDcm])
13461321 let poolStatus = cfg[idxPoolStatus]
13471322 let poolLPBalance = valueOrErrorMessage(assetInfo(lpAssetId), (("Asset " + toBase58String(lpAssetId)) + " doesn't exist")).quantity
13481323 let accAmtAssetBalance = getAccBalance(amAssetIdStr)
13491324 let accPriceAssetBalance = getAccBalance(prAssetIdStr)
13501325 let amtAssetAmtX18 = toX18(accAmtAssetBalance, amtAssetDcm)
13511326 let priceAssetAmtX18 = toX18(accPriceAssetBalance, priceAssetDcm)
13521327 let curPriceX18 = if ((poolLPBalance == 0))
13531328 then zeroBigInt
13541329 else calcPriceBigInt(priceAssetAmtX18, amtAssetAmtX18)
13551330 let inAmAssetAmtX18 = toX18(inAmAssetAmt, amtAssetDcm)
13561331 let inPrAssetAmtX18 = fraction(inAmAssetAmtX18, curPriceX18, scale18)
13571332 let inPrAssetAmt = fromX18(inPrAssetAmtX18, priceAssetDcm)
13581333 let estPut = estimatePutOperation("", 500000, inAmAssetAmt, amAssetId, inPrAssetAmt, prAssetId, "", true, false)
13591334 let calcLpAmt = estPut._1
13601335 let curPriceCalc = estPut._3
13611336 let amBalance = estPut._4
13621337 let prBalance = estPut._5
13631338 let lpEmission = estPut._6
13641339 $Tuple2(nil, makeString(["%d%d%d%d%d%d%d%d", toString(calcLpAmt), toString(fromX18(curPriceX18, scale8)), toString(amBalance), toString(prBalance), toString(lpEmission), poolStatus, toString(inAmAssetAmt), toString(inPrAssetAmt)], SEP))
13651340 }
13661341
13671342
13681343
13691344 @Callable(i)
13701345 func evaluatePutByPriceAssetREADONLY (inPrAssetAmt) = {
13711346 let cfg = getPoolConfig()
13721347 let lpAssetId = fromBase58String(cfg[idxPoolLPAssetId])
13731348 let amAssetIdStr = cfg[idxAmtAssetId]
13741349 let amAssetId = fromBase58String(amAssetIdStr)
13751350 let prAssetIdStr = cfg[idxPriceAssetId]
13761351 let prAssetId = fromBase58String(prAssetIdStr)
13771352 let amtAssetDcm = parseIntValue(cfg[idxAmtAssetDcm])
13781353 let priceAssetDcm = parseIntValue(cfg[idxPriceAssetDcm])
13791354 let poolStatus = cfg[idxPoolStatus]
13801355 let poolLPBalance = valueOrErrorMessage(assetInfo(lpAssetId), (("Asset " + toBase58String(lpAssetId)) + " doesn't exist")).quantity
13811356 let amBalanceRaw = getAccBalance(amAssetIdStr)
13821357 let prBalanceRaw = getAccBalance(prAssetIdStr)
13831358 let amBalanceRawX18 = toX18(amBalanceRaw, amtAssetDcm)
13841359 let prBalanceRawX18 = toX18(prBalanceRaw, priceAssetDcm)
13851360 let curPriceX18 = if ((poolLPBalance == 0))
13861361 then zeroBigInt
13871362 else calcPriceBigInt(prBalanceRawX18, amBalanceRawX18)
13881363 let inPrAssetAmtX18 = toX18(inPrAssetAmt, priceAssetDcm)
13891364 let inAmAssetAmtX18 = fraction(inPrAssetAmtX18, scale18, curPriceX18)
13901365 let inAmAssetAmt = fromX18(inAmAssetAmtX18, amtAssetDcm)
13911366 let estPut = estimatePutOperation("", 500000, inAmAssetAmt, amAssetId, inPrAssetAmt, prAssetId, "", true, false)
13921367 let calcLpAmt = estPut._1
13931368 let curPriceCalc = estPut._3
13941369 let amBalance = estPut._4
13951370 let prBalance = estPut._5
13961371 let lpEmission = estPut._6
13971372 $Tuple2(nil, makeString(["%d%d%d%d%d%d%d%d", toString(calcLpAmt), toString(fromX18(curPriceX18, scale8)), toString(amBalance), toString(prBalance), toString(lpEmission), poolStatus, toString(inAmAssetAmt), toString(inPrAssetAmt)], SEP))
13981373 }
13991374
14001375
14011376
14021377 @Callable(i)
14031378 func evaluateGetREADONLY (paymentLpAssetId,paymentLpAmt) = {
14041379 let res = estimateGetOperation("", paymentLpAssetId, paymentLpAmt, this)
14051380 let outAmAmt = res._1
14061381 let outPrAmt = res._2
14071382 let amBalance = res._5
14081383 let prBalance = res._6
14091384 let lpEmission = res._7
14101385 let curPrice = res._8
14111386 let poolStatus = parseIntValue(res._9)
14121387 $Tuple2(nil, makeString(["%d%d%d%d%d%d%d", toString(outAmAmt), toString(outPrAmt), toString(amBalance), toString(prBalance), toString(lpEmission), toString(curPrice), toString(poolStatus)], SEP))
14131388 }
14141389
14151390
14161391 @Verifier(tx)
14171392 func verify () = {
14181393 let targetPublicKey = match managerPublicKeyOrUnit() {
14191394 case pk: ByteVector =>
14201395 pk
14211396 case _: Unit =>
14221397 tx.senderPublicKey
14231398 case _ =>
14241399 throw("Match error")
14251400 }
14261401 match tx {
14271402 case order: Order =>
14281403 let matcherPub = getMatcherPubOrFail()
14291404 let orderValid = validateMatcherOrderAllowed(order)
14301405 let senderValid = sigVerify(order.bodyBytes, order.proofs[0], order.senderPublicKey)
14311406 let matcherValid = sigVerify(order.bodyBytes, order.proofs[1], matcherPub)
14321407 if (if (if (orderValid)
14331408 then senderValid
14341409 else false)
14351410 then matcherValid
14361411 else false)
14371412 then true
14381413 else throwOrderError(orderValid, senderValid, matcherValid)
14391414 case s: SetScriptTransaction =>
14401415 let newHash = blake2b256(value(s.script))
14411416 let allowedHash = fromBase64String(value(getString(factoryContract, keyAllowedLpScriptHash())))
14421417 let currentHash = scriptHash(this)
14431418 if (if ((allowedHash == newHash))
14441419 then (currentHash != newHash)
14451420 else false)
14461421 then true
14471422 else sigVerify(tx.bodyBytes, tx.proofs[0], targetPublicKey)
14481423 case _ =>
14491424 sigVerify(tx.bodyBytes, tx.proofs[0], targetPublicKey)
14501425 }
14511426 }
14521427

github/deemru/w8io/169f3d6 
161.39 ms