tx · 5t4tRB83cdfbUHn6pyHJJYCdmjTAZMaGxGXjxNYaGvWM 3MsMP2pb2p8MDd6Rxb7XEXqqwEhE8ATfyai: -0.02800000 Waves 2023.08.02 12:30 [2692775] smart account 3MsMP2pb2p8MDd6Rxb7XEXqqwEhE8ATfyai > SELF 0.00000000 Waves
{ "type": 13, "id": "5t4tRB83cdfbUHn6pyHJJYCdmjTAZMaGxGXjxNYaGvWM", "fee": 2800000, "feeAssetId": null, "timestamp": 1690968635767, "version": 2, "chainId": 84, "sender": "3MsMP2pb2p8MDd6Rxb7XEXqqwEhE8ATfyai", "senderPublicKey": "2JEaBjtjvMoNGKZmL9QxYefa1VkMJM3vMW8rNvTs9R2H", "proofs": [ "3ybHLy3a11VbV2nTdrGHDCcWhRiagMXnDyAGxCfC1hgsdvWFKKFuGmAthaFGHCyZRYL52nycXJgRU7SBLMciBMy9" ], "script": "base64:BgL9LQgCEgASBAoCCAgSBAoCCAgSAwoBCBIKCggICAgICAgIARIDCgEIEgYKBAgICAgSBAoCCBgSAwoBCBIECgIIGBIDCgEYEgoKCAgICAgIAQgIEgQKAggBEgMKAQESAwoBARIECgIIARIGCgQICAgIEgQKAggIEgQKAggIEgQKAggIEgMKAQgSAwoBCBIDCgEIEgMKAQgSAwoBCBIECgIICBIDCgEIEgMKAQgSAwoBCBIECgIICBIDCgEIEgMKAQgSAwoBCBIDCgEIIgZTQ0FMRTgiBU1VTFQ4IgZNVUxUMTIiB1NDQUxFMTgiBk1VTFQxOCIOUE9PTFdFSUdIVE1VTFQiDkdXWHZpcnR1YWxQT09MIgxsYWJlbFBvb2xzTHAiDWRlZmF1bHRTcHJlYWQiC3dhdmVzU3RyaW5nIhBjb250cmFjdEZpbGVuYW1lIhFkZWNpbWFsc011bHRQcmljZSIDU0VQIgVFTVBUWSIKUG9vbEFjdGl2ZSIPUG9vbFB1dERpc2FibGVkIhNQb29sTWF0Y2hlckRpc2FibGVkIgxQb29sU2h1dGRvd24iEmlkeEludGVybmFsQXNzZXRJZCIPaWR4UmVzdXRBY3Rpb25zIiBpZHhJZkFzc2V0SWRDYWxjdWxhdGlvblBlcmZvcm1lZCIOaWR4UG9vbEFkZHJlc3MiDWlkeFBvb2xTdGF0dXMiEGlkeFBvb2xMUEFzc2V0SWQiDWlkeEFtdEFzc2V0SWQiD2lkeFByaWNlQXNzZXRJZCIOaWR4QW10QXNzZXREY20iEGlkeFByaWNlQXNzZXREY20iDmlkeElBbXRBc3NldElkIhBpZHhJUHJpY2VBc3NldElkIg1pZHhMUEFzc2V0RGNtIgtpZHhQb29sVHlwZSITcG9vbExhYmVsV3hFbWlzc2lvbiIPdmFsaWRQb29sTGFiZWxzIgd3cmFwRXJyIgNtc2ciCHRocm93RXJyIhZrZXlBbGxvd2VkTHBTY3JpcHRIYXNoIhxrZXlBbGxvd2VkTHBTdGFibGVTY3JpcHRIYXNoIgxzd2FwQ29udHJhY3QiEGtleUZhY3RvcnlDb25maWciD2tleUxwVG9rZW5zTGlzdCIRa2V5UG9vbFNjcmlwdEhhc2giDWtleU1hdGNoZXJQdWIiGGtleUxlZ2FjeUZhY3RvcnlDb250cmFjdCIOa2V5TGVnYWN5UG9vbHMiE2tleU1hbmFnZXJQdWJsaWNLZXkiFmtleU1hbmFnZXJWYXVsdEFkZHJlc3MiD2tleUFkbWluUHViS2V5cyIWa2V5QXNzZXRzU3RvcmVDb250cmFjdCIZa2V5Vm90aW5nRW1pc3Npb25Db250cmFjdCIUa2V5VXNlclBvb2xzQ29udHJhY3QiDmtleVByaWNlQXNzZXRzIhBrZXlQcmljZURlY2ltYWxzIhNrZXlBbGxQb29sc1NodXRkb3duIhZrZXlOZXh0SW50ZXJuYWxBc3NldElkIg9rZXlQb29sVG9XZWlnaHQiC3Bvb2xBZGRyZXNzIhZrZXlQb29sVG9XZWlnaHRIaXN0b3J5IgNudW0iH2tleU1hcHBpbmdzSW50ZXJuYWwyYmFzZUFzc2V0SWQiEWludGVybmFsQmFzZUFzc2V0Ih9rZXlNYXBwaW5nc0Jhc2VBc3NldDJpbnRlcm5hbElkIgxiYXNlQXNzZXRTdHIiDWtleVBvb2xDb25maWciE2Ftb3VudEFzc2V0SW50ZXJuYWwiEnByaWNlQXNzZXRJbnRlcm5hbCIha2V5UG9vbE9uZVRva2VuT3BlcmF0aW9uc0Rpc2FibGVkIg5hc3NldHNJbnRlcm5hbCILJHQwMzg3ODM5NDAiJWtleUFsbFBvb2xzT25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWQiHWtleU1hcHBpbmdMcEFzc2V0VG9Qb29sQXNzZXRzIgpscEFzc2V0U3RyIh1rZXlNYXBwaW5nUG9vbEFzc2V0c1RvTHBhc3NldCIYaW50ZXJuYWxBbW91bnRBc3NldElkU3RyIhdpbnRlcm5hbFByaWNlQXNzZXRJZFN0ciINa2V5UG9vbFNwcmVhZCIpa2V5TWFwcGluZ1Bvb2xDb250cmFjdEFkZHJlc3NUb1Bvb2xBc3NldHMiE3Bvb2xDb250cmFjdEFkZHJlc3MiKWtleU1hcHBpbmdQb29sQXNzZXRzVG9Qb29sQ29udHJhY3RBZGRyZXNzIh9rZXlNYXBwaW5nUG9vbENvbnRyYWN0VG9MUEFzc2V0IiprZXlNYXBwaW5nUG9vbExQQXNzZXRUb1Bvb2xDb250cmFjdEFkZHJlc3MiDWtleVd4RW1pc3Npb24iDWFtb3VudEFzc2V0SWQiDHByaWNlQXNzZXRJZCIIa2V5SW5GZWUiD2tleUluRmVlRGVmYXVsdCIKa2V5U3dhcEZlZSIJa2V5T3V0RmVlIhBrZXlPdXRGZWVEZWZhdWx0IhZrZXlTa2lwT3JkZXJWYWxpZGF0aW9uIhFrZXlDaGFuZ2VBbXBEZWxheSIRa2V5Q2hhbmdlQW1wRGVsdGEiEmtleUNoYW5nZUFtcFRhcmdldCIVa2V5U1dhdmVzUHJveHlBZGRyZXNzIhBrZXlTV2F2ZXNBc3NldElkIhdrZXlTdGFraW5nUHJvZml0QWRkcmVzcyIOa2V5TGVhc2VkUmF0aW8iB2Fzc2V0SWQiFWtleUxlYXNlZFJhdGlvRGVmYXVsdCIXa2V5TGVhc2VkUmF0aW9Ub2xlcmFuY2UiDWtleU1pbkJhbGFuY2UiFGtleU1pbkJhbGFuY2VEZWZhdWx0Ig9nZXRTdHJpbmdPckZhaWwiA2tleSIQZ2V0Qm9vbGVhbk9yRmFpbCIMZ2V0SW50T3JGYWlsIgxwYXJzZUFzc2V0SWQiBWlucHV0IhxnZXRNYW5hZ2VyVmF1bHRBZGRyZXNzT3JUaGlzIgckbWF0Y2gwIgFzIhhJZHhGYWN0b3J5Q2ZnU3Rha2luZ0RhcHAiGUlkeEZhY3RvcnlDZmdCb29zdGluZ0RhcHAiFElkeEZhY3RvcnlDZmdJZG9EYXBwIhVJZHhGYWN0b3J5Q2ZnVGVhbURhcHAiGUlkeEZhY3RvcnlDZmdFbWlzc2lvbkRhcHAiFUlkeEZhY3RvcnlDZmdSZXN0RGFwcCIZSWR4RmFjdG9yeUNmZ1NsaXBwYWdlRGFwcCIUSWR4RmFjdG9yeUNmZ0Rhb0RhcHAiGklkeEZhY3RvcnlDZmdNYXJrZXRpbmdEYXBwIhpJZHhGYWN0b3J5Q2ZnR3d4UmV3YXJkRGFwcCIWSWR4RmFjdG9yeUNmZ0JpcmRzRGFwcCIYZ2V0Qm9vc3RpbmdBZGRyZXNzT3JGYWlsIgpmYWN0b3J5Q2ZnIhhnZXRFbWlzc2lvbkFkZHJlc3NPckZhaWwiF2dldFN0YWtpbmdBZGRyZXNzT3JGYWlsIhlnZXRHd3hSZXdhcmRBZGRyZXNzT3JGYWlsIg5nZXRQcmljZUFzc2V0cyIWbWFuYWdlclB1YmxpY0tleU9yVW5pdCITbWFuYWdlclZhdWx0QWRkcmVzcyIVcGVybWlzc2lvbkRlbmllZEVycm9yIgl0ZXN0RXJyb3IiCG11c3RUaGlzIgFpIgttdXN0TWFuYWdlciICcGsiEGRhdGFGYWN0b3J5Q2ZnVjMiDnN0YWtpbmdBZGRyZXNzIg9ib29zdGluZ0FkZHJlc3MiC2lkb0NvbnRyYWN0Igx0ZWFtQ29udHJhY3QiEGVtaXNzaW9uQ29udHJhY3QiDHJlc3RDb250cmFjdCIQc2xpcHBhZ2VDb250cmFjdCILZGFvQ29udHJhY3QiEW1hcmtldGluZ0NvbnRyYWN0IhJnd3hSZXdhcmRzQ29udHJhY3QiDWJpcmRzQ29udHJhY3QiDmRhdGFGYWN0b3J5Q2ZnIgtkYXRhUG9vbENmZyIKcG9vbFN0YXR1cyIJbHBBc3NldElkIg5hbW91bnRBc3NldFN0ciINcHJpY2VBc3NldFN0ciITYW1vdW50QXNzZXREZWNpbWFscyIScHJpY2VBc3NldERlY2ltYWxzIhVhbW91bnRBc3NldEludGVybmFsSWQiFHByaWNlQXNzZXRJbnRlcm5hbElkIg9scEFzc2V0RGVjaW1hbHMiCHBvb2xUeXBlIhVkYXRhTWFwcGluZ1Bvb2xBc3NldHMiFmludGVybmFsQW1vdW50QXNzZXRTdHIiFWludGVybmFsUHJpY2VBc3NldFN0ciINZ2V0UG9vbENvbmZpZyIKcG9vbEFzc2V0cyIaZ2V0SW50ZXJuYWxBc3NldElkT3JDcmVhdGUiCmFzc2V0SWRTdHIiC2luY3JlbWVudG9yIg9pbnRlcm5hbEFzc2V0SWQiGGN1cnJlbnRJbmRleE9mSW50ZXJuYWxJZCIGcmVzdWx0IhJuZXdJbnRlcm5hbEFzc2V0SWQiCW11c3RBZG1pbiIIYWRtaW5QS3MiCWlzTWFuYWdlciIWaW50T3JEZWZhdWx0T3JGYWxsYmFjayIKa2V5RGVmYXVsdCINdmFsdWVGYWxsYmFjayIScG9vbEV4aXN0c0ludGVybmFsIgRhbUFzIgRwckFzIgNjZmciCmNmZ1JldmVyc2UiBmV4aXN0cyIcZ2V0QXNzZXRzRGF0YUZyb21Qb29sQWRkcmVzcyIOZ2V0UG9vbENyZWF0b3IiDSR0MDE1MjY5MTU0MDYiEXVzZXJQb29sc0NvbnRyYWN0Igtwb29sQ3JlYXRvciIRZ2V0QWRkcmVzc0JhbGFuY2UiDWFkZHJlc3NTdHJpbmciDWFzc2V0SWRTdHJpbmciB2FkZHJlc3MiC2lzUG9vbEVtcHR5Ig0kdDAxNTk4MTE2MTE4Ig0kdDAxNjQzMzE2NzM3IgFyIgckbWF0Y2gxIgJyZCIKaXNMZWFzYWJsZSILbGVhc2VkUmF0aW8iCm1pbkJhbGFuY2UiAWIiAmJkIg0kdDAxNzAwMzE3MjI3Igxwcm94eUFkZHJlc3MiDHByb3h5QXNzZXRJZCIMcHJveHlSYXRlTXVsIhRzdGFraW5nUHJvZml0QWRkcmVzcyIGYXNzZXQxIgZhc3NldDIiCWFzc2V0TnVtMSIJYXNzZXROdW0yIgJlZSIDcmVzIgJscCIPc3Rha2luZ0NvbnRyYWN0IhBib29zdGluZ0NvbnRyYWN0IhBzbHBpcGFnZUNvbnRyYWN0Ig1wcmljZURlY2ltYWxzIgtjaGVja0NhbGxlciIQbWF0aGNoZXJQdWI1OFN0ciIKbWF0aGNlclB1YiIVbGVnYWN5RmFjdG9yeUNvbnRyYWN0IgtsZWdhY3lQb29scyITYXNzZXRzU3RvcmVDb250cmFjdCIWdm90aW5nRW1pc3Npb25Db250cmFjdCILcHJpY2VBc3NldHMiBWNoZWtzIgxhZG1pblB1YktleXMiC2xwQXNzZXROYW1lIgxscEFzc2V0RGVzY3IiCnBvb2xXZWlnaHQiBGxvZ28iF2ludGVybmFsQW1vdW50QXNzZXREYXRhIhVpbnRlcm5hbEFtb3VudEFzc2V0SWQiFmludGVybmFsUHJpY2VBc3NldERhdGEiFGludGVybmFsUHJpY2VBc3NldElkIhVwb29sQWNjb3VudFNjcmlwdEhhc2giHGV0aGFsb25Qb29sQWNjb3VudFNjcmlwdEhhc2giCnBvb2xFeGlzdHMiD3Bvb2xDb25maWdWYWx1ZSIUYW1vdW50QXNzZXRzRGVjaW1hbHMiE3ByaWNlQXNzZXRzRGVjaW1hbHMiEmxwQXNzZXRJc3N1ZUFjdGlvbiIMbHBBc3NldElkU3RyIhhwb29sQWN0aXZhdGVJbnZva2VSZXN1bHQiGGNyZWF0ZU9yVXBkYXRlTHBBc3NldEludiISYWRkUG9vbHNMcExhYmVsSW52IgpzZXRMb2dvSW52IhBhZGRBc3NldHNMaW5rSW52IhtpbmNyZWFzZUFzc2V0UG9vbHNOdW1iZXJJbnYiCW5ld1N0YXR1cyIKcG9vbENvbmZpZyIKbHBBc3NldERjbSIMYW1vdW50VG9FbWl0IgZjYWxsZXIiDG9yaWdpbkNhbGxlciIQbHBBc3NldFJlcXVlc3RlZCIHbHBBc3NldCIMYW1vdW50VG9CdXJuIgdwYXltZW50Ig1wYXltZW50QW1vdW50Ig9pbkFtb3VudEFzc2V0SWQiGmxwQXNzZXRSZXF1ZXN0ZWRGb3JCdXJuaW5nIgVzaGFyZSINcG9vbFdlaWdodEtleSIMZ3d4V2VpZ2h0S2V5Iglnd3hXZWlnaHQiDXBvb2xXZWlnaHROZXciEW9uTW9kaWZ5V2VpZ2h0SW52IhVnd3hWaXJ0dWFsUG9vbEFjdGlvbnMiFHBvb2xXZWlnaHRIaXN0b3J5S2V5Ihdwb29sV2VpZ2h0SGlzdG9yeU9yVW5pdCIYcG9vbFdlaWdodEhpc3RvcnlBY3Rpb25zIg5idGNQb29sQWRkcmVzcyIOZXRoUG9vbEFkZHJlc3MiEWV0aEJ0Y1Bvb2xBZGRyZXNzIhN1c2RjVXNkdFBvb2xBZGRyZXNzIg9ldGhCdGNXZWlnaHROZXciEXVzZGNVc2R0V2VpZ2h0TmV3Ig93ZWlnaHREZWNyZW1lbnQiC3N0YWtpbmdEYXBwIg1nd3hSZXdhcmREYXBwIgxidGNXZWlnaHRLRVkiDGV0aFdlaWdodEtFWSIPZXRoQnRjV2VpZ2h0S0VZIhF1c2RjVXNkdFdlaWdodEtFWSIJYnRjV2VpZ2h0IglldGhXZWlnaHQiDGJ0Y1dlaWdodE5ldyIMZXRoV2VpZ2h0TmV3Ig9idGNMcEFzc2V0SWRTdHIiD2V0aExwQXNzZXRJZFN0ciISZXRoQnRjTHBBc3NldElkU3RyIhR1c2RjVXNkdExwQXNzZXRJZFN0ciIRb25Nb2RpZnlXZWlnaHRCdGMiEW9uTW9kaWZ5V2VpZ2h0RXRoIhRvbk1vZGlmeVdlaWdodEV0aEJ0YyIWb25Nb2RpZnlXZWlnaHRVc2RjVXNkdCIJaGF2ZUxhYmVsIhRjaGVja1ByaWNlQXNzZXRzU2l6ZSICY2IiA2FjYyIKcHJpY2VBc3NldCIHYWN0aW9ucyICJGwiAiRzIgUkYWNjMCIFJGYwXzEiAiRhIgIkaSIFJGYwXzIiHnBvb2xPbmVUb2tlbk9wZXJhdGlvbnNEaXNhYmxlZCIiYWxsUG9vbHNPbmVUb2tlbk9wZXJhdGlvbnNEaXNhYmxlZCIDZmVlIg5wb29sQWRkcmVzc1N0ciIJZmVlT3B0aW9uIgVwYXJ0cyIHcG9vbEZlZSILcHJvdG9jb2xGZWUiEGFtb3VudEFzc2V0SWRTdHIiD3ByaWNlQXNzZXRJZFN0ciIbYW1vdW50QXNzZXRJbnRlcm5hbElkT3B0aW9uIhpwcmljZUFzc2V0SW50ZXJuYWxJZE9wdGlvbiIZcG9vbENvbnRyYWN0QWRkcmVzc09wdGlvbiIPbHBBc3NldElkT3B0aW9uIghwb29sSW5mbyIFZGVsYXkiBWRlbHRhIgZ0YXJnZXQiBndlaWdodCILY2hlY2tXZWlnaHQiC2NoZWNrU3RhdHVzIg0kdDAzOTYxNzM5NzU0Ig91c2VyUG9vbHNJbnZva2UiFHZvdGluZ0VtaXNzaW9uSW52b2tlIhFhc3NldHNTdG9yZUludm9rZSICdHgiBnZlcmlmeSIPdGFyZ2V0UHVibGljS2V5fgABYQAIAAFiAIDC1y8AAWMAgKCUpY0dAAFkABIAAWUJALYCAQCAgJC7utat8A0AAWYFAWIAAWcCDkdXWHZpcnR1YWxQT09MAAFoAghQT09MU19MUAABaQCAiXoAAWoCBVdBVkVTAAFrAg9mYWN0b3J5X3YyLnJpZGUAAWwJAGgCCQBoAgBkAOgHAOgHAAFtAgJfXwABbgIAAAFvAAEAAXAAAgABcQADAAFyAAQAAXMAAQABdAACAAF1AAMAAXYAAQABdwACAAF4AAMAAXkABAABegAFAAFBAAYAAUIABwABQwAIAAFEAAkAAUUACgABRgALAAFHAgtXWF9FTUlTU0lPTgABSAkAzAgCBQFHBQNuaWwBAUkBAUoJALkJAgkAzAgCBQFrCQDMCAICAjogCQDMCAIFAUoFA25pbAIAAQFLAQFKCQACAQkBAUkBBQFKAQFMAAIXJXNfX2FsbG93ZWRMcFNjcmlwdEhhc2gBAU0AAh0lc19fYWxsb3dlZExwU3RhYmxlU2NyaXB0SGFzaAEBTgACECVzX19zd2FwQ29udHJhY3QBAU8AAhElc19fZmFjdG9yeUNvbmZpZwEBUAACECVzX19scFRva2Vuc0xpc3QBAVEAAhYlcyVzX19wb29sX19zY3JpcHRIYXNoAQFSAAIYJXMlc19fbWF0Y2hlcl9fcHVibGljS2V5AQFTAAIZJXNfX2xlZ2FjeUZhY3RvcnlDb250cmFjdAEBVAACDyVzX19sZWdhY3lQb29scwEBVQACFCVzX19tYW5hZ2VyUHVibGljS2V5AQFWAAIXJXNfX21hbmFnZXJWYXVsdEFkZHJlc3MBAVcAAhAlc19fYWRtaW5QdWJLZXlzAQFYAAIXJXNfX2Fzc2V0c1N0b3JlQ29udHJhY3QBAVkAAholc19fdm90aW5nRW1pc3Npb25Db250cmFjdAEBWgACFSVzX191c2VyUG9vbHNDb250cmFjdAECYWEACQC5CQIJAMwIAgICJXMJAMwIAgILcHJpY2VBc3NldHMFA25pbAUBbQECYWIAAhElc19fcHJpY2VEZWNpbWFscwECYWMAAgwlc19fc2h1dGRvd24BAmFkAAIXJXNfX25leHRJbnRlcm5hbEFzc2V0SWQBAmFlAQJhZgkArAICAhIlcyVzX19wb29sV2VpZ2h0X18FAmFmAQJhZwICYWYCYWgJAKwCAgkArAICCQCsAgICEiVzJXNfX3Bvb2xXZWlnaHRfXwUCYWYCAl9fCQCkAwEFAmFoAQJhaQECYWoJAKwCAgIoJXMlcyVkX19tYXBwaW5nc19faW50ZXJuYWwyYmFzZUFzc2V0SWRfXwkApAMBBQJhagECYWsBAmFsCQCsAgICKCVzJXMlc19fbWFwcGluZ3NfX2Jhc2VBc3NldDJpbnRlcm5hbElkX18FAmFsAQJhbQICYW4CYW8JAKwCAgkArAICCQCsAgIJAKwCAgIIJWQlZCVzX18FAmFuAgJfXwUCYW8CCF9fY29uZmlnAQJhcAECYXEEAmFyBQJhcQQCYW4IBQJhcgJfMQQCYW8IBQJhcgJfMgkAuQkCCQDMCAICBiVkJWQlcwkAzAgCCQCkAwEFAmFuCQDMCAIJAKQDAQUCYW8JAMwIAgIab25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWQFA25pbAUBbQECYXMACQC5CQIJAMwIAgICJXMJAMwIAgIab25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWQFA25pbAUBbQECYXQBAmF1CQCsAgIJAKwCAgIIJXMlcyVzX18FAmF1AhhfX21hcHBpbmdzX19scEFzc2V0MlBvb2wBAmF2AgJhdwJheAkArAICCQCsAgIJAKwCAgkArAICAgolZCVkJXMlc19fBQJhdwICX18FAmF4Ah5fX21hcHBpbmdzX19Qb29sQXNzZXRzMkxwQXNzZXQBAmF5AQJhZgkArAICAg4lcyVzX19zcHJlYWRfXwUCYWYBAmF6AQJhQQkArAICCQCsAgICCCVzJXMlc19fBQJhQQIjX19tYXBwaW5nc19fcG9vbENvbnRyYWN0MlBvb2xBc3NldHMBAmFCAgJhdwJheAkArAICCQCsAgIJAKwCAgkArAICAgolZCVkJXMlc19fCQCkAwEFAmF3AgJfXwkApAMBBQJheAIjX19tYXBwaW5nc19fcG9vbEFzc2V0czJQb29sQ29udHJhY3QBAmFDAQJhQQkArAICCQCsAgICCCVzJXMlc19fBQJhQQIgX19tYXBwaW5nc19fcG9vbENvbnRyYWN0MkxwQXNzZXQBAmFEAQJhdQkArAICCQCsAgICCCVzJXMlc19fBQJhdQIgX19tYXBwaW5nc19fbHBBc3NldDJQb29sQ29udHJhY3QBAmFFAgJhRgJhRwkArAICCQCsAgIJAKwCAgIUJXMlcyVzX193eEVtaXNzaW9uX18FAmFGAgJfXwUCYUcBAmFIAQJhZgkArAICAg0lcyVzX19pbkZlZV9fBQJhZgECYUkAAhAlc19faW5GZWVEZWZhdWx0AQJhSgECYWYJAKwCAgIPJXMlc19fc3dhcEZlZV9fBQJhZgECYUsBAmFmCQCsAgICDiVzJXNfX291dEZlZV9fBQJhZgECYUwAAhElc19fb3V0RmVlRGVmYXVsdAECYU0BAmFmCQCsAgICGyVzJXNfX3NraXBPcmRlclZhbGlkYXRpb25fXwUCYWYBAmFOAQJhZgkArAICAhYlcyVzX19jaGFuZ2VBbXBEZWxheV9fBQJhZgECYU8BAmFmCQCsAgICFiVzJXNfX2NoYW5nZUFtcERlbHRhX18FAmFmAQJhUAECYWYJAKwCAgIXJXMlc19fY2hhbmdlQW1wVGFyZ2V0X18FAmFmAQJhUQACFiVzX19zV2F2ZXNQcm94eUFkZHJlc3MBAmFSAAIRJXNfX3NXYXZlc0Fzc2V0SWQBAmFTAAIYJXNfX3N0YWtpbmdQcm9maXRBZGRyZXNzAQJhVAICYWYCYVUJALkJAgkAzAgCAgYlcyVzJXMJAMwIAgILbGVhc2VkUmF0aW8JAMwIAgUCYWYJAMwIAgUCYVUFA25pbAUBbQECYVYBAmFVCQC5CQIJAMwIAgIEJXMlcwkAzAgCAhJsZWFzZWRSYXRpb0RlZmF1bHQJAMwIAgUCYVUFA25pbAUBbQECYVcCAmFmAmFVCQC5CQIJAMwIAgIGJXMlcyVzCQDMCAICFGxlYXNlZFJhdGlvVG9sZXJhbmNlCQDMCAIFAmFmCQDMCAIFAmFVBQNuaWwFAW0BAmFYAgJhZgJhVQkAuQkCCQDMCAICBiVzJXMlcwkAzAgCAgptaW5CYWxhbmNlCQDMCAIFAmFmCQDMCAIFAmFVBQNuaWwFAW0BAmFZAQJhVQkAuQkCCQDMCAICBCVzJXMJAMwIAgIRbWluQmFsYW5jZURlZmF1bHQJAMwIAgUCYVUFA25pbAUBbQECYVoBAmJhCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwUCYmEJAKwCAgIVTm8gZGF0YSBmb3IgdGhpcy5rZXk9BQJiYQECYmIBAmJhCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJsIAgUEdGhpcwUCYmEJAKwCAgIVTm8gZGF0YSBmb3IgdGhpcy5rZXk9BQJiYQECYmMBAmJhCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUEdGhpcwUCYmEJAKwCAgIVTm8gZGF0YSBmb3IgdGhpcy5rZXk9BQJiYQECYmQBAmJlAwkAAAIFAmJlBQFqBQR1bml0CQDZBAEFAmJlAQJiZgAEAmJnCQCiCAEJAQFWAAMJAAECBQJiZwIGU3RyaW5nBAJiaAUCYmcJARFAZXh0ck5hdGl2ZSgxMDYyKQEFAmJoBQR0aGlzAAJiaQABAAJiagACAAJiawADAAJibAAEAAJibQAFAAJibgAGAAJibwAHAAJicAAIAAJicQAJAAJicgAKAAJicwALAQJidAECYnUJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAJEDAgUCYnUFAmJqAQJidgECYnUJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAJEDAgUCYnUFAmJtAQJidwECYnUJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAJEDAgUCYnUFAmJpAQJieAECYnUJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAJEDAgUCYnUFAmJyAQJieQAEAmJnCQCiCAEJAQJhYQADCQABAgUCYmcCBlN0cmluZwQCYmgFAmJnAwkAAAIJALECAQUCYmgAAAUDbmlsCQC8CQIFAmJoBQFtBQNuaWwBAmJ6AAQCYkEJAQJiZgAEAmJnCQCdCAIFAmJBCQEBVQADCQABAgUCYmcCBlN0cmluZwQCYmgFAmJnCQDZBAEFAmJoAwkAAQIFAmJnAgRVbml0BQR1bml0CQACAQILTWF0Y2ggZXJyb3IAAmJCCQEBSwECEVBlcm1pc3Npb24gZGVuaWVkAAJiQwkBAUsBAg9UZXN0IGVycm9yIGhlcmUBAmJEAQJiRQMJAAACCAUCYkUGY2FsbGVyBQR0aGlzBgUCYkIBAmJGAQJiRQQCYmcJAQJiegADCQABAgUCYmcCCkJ5dGVWZWN0b3IEAmJHBQJiZwMJAAACCAUCYkUPY2FsbGVyUHVibGljS2V5BQJiRwYFAmJCAwkAAQIFAmJnAgRVbml0CQECYkQBBQJiRQkAAgECC01hdGNoIGVycm9yAQJiSAsCYkkCYkoCYksCYkwCYk0CYk4CYk8CYlACYlECYlICYlMJALkJAgkAzAgCAhYlcyVzJXMlcyVzJXMlcyVzJXMlcyVzCQDMCAIFAmJJCQDMCAIFAmJKCQDMCAIFAmJLCQDMCAIFAmJMCQDMCAIFAmJNCQDMCAIFAmJOCQDMCAIFAmJPCQDMCAIFAmJQCQDMCAIFAmJRCQDMCAIFAmJSCQDMCAIFAmJTBQNuaWwFAW0BAmJUBwJiSQJiSgJiSwJiTAJiTQJiTgJiTwkAuQkCCQDMCAICDCVzJXMlcyVzJXMlcwkAzAgCBQJiSQkAzAgCBQJiSgkAzAgCBQJiSwkAzAgCBQJiTAkAzAgCBQJiTQkAzAgCBQJiTgkAzAgCBQJiTwUDbmlsBQFtAQJiVQsCYWYCYlYCYlcCYlgCYlkCYloCY2ECY2ICY2MCY2QCY2UJALkJAgkAzAgCAhYlcyVkJXMlcyVzJWQlZCVkJWQlZCVzCQDMCAIFAmFmCQDMCAIFAmJWCQDMCAIFAmJXCQDMCAIFAmJYCQDMCAIFAmJZCQDMCAIJAKQDAQUCYloJAMwIAgkApAMBBQJjYQkAzAgCCQCkAwEFAmNiCQDMCAIJAKQDAQUCY2MJAMwIAgkApAMBBQJjZAkAzAgCBQJjZQUDbmlsBQFtAQJjZgICY2cCY2gJALkJAgkAzAgCAgQlZCVkCQDMCAIJAKQDAQUCY2cJAMwIAgkApAMBBQJjaAUDbmlsBQFtAQJjaQECYWYEAmNqCQC1CQIJAQJhWgEJAQJhegEFAmFmBQFtBAJhbgkAkQMCBQJjagABBAJhbwkAkQMCBQJjagACCQC1CQIJAQJhWgEJAQJhbQIFAmFuBQJhbwUBbQECY2sCAmNsAmNtBAJjbgkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQECYWsBBQJjbAAABAJjbwkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQECYWQAAAAEAmNwAwkAAAIFAmNuAAAEAmNxCQBkAgUCY28FAmNtCQCVCgMFAmNxCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYWQABQJjcQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAmFrAQUCY2wFAmNxCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhaQEFAmNxBQJjbAUDbmlsBgkAlQoDBQJjbgUDbmlsBwUCY3ABAmNyAQJiRQQCY3MJALUJAgkBC3ZhbHVlT3JFbHNlAgkAoggBCQEBVwAFAW4FAW0DCQEPY29udGFpbnNFbGVtZW50AgUCY3MJANgEAQgFAmJFD2NhbGxlclB1YmxpY0tleQYEAmN0CQECYkYBBQJiRQMJAAACBQJjdAUCY3QGCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJjdQMCYmECY3YCY3cJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUCYmEJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUCY3YFAmN3AQJjeAICYUYCYUcEAmFuCQCfCAEJAQJhawEFAmFGBAJhbwkAnwgBCQECYWsBBQJhRwMDCQAAAgUCYW4FBHVuaXQGCQAAAgUCYW8FBHVuaXQHBAJjeQkApAMBCQEFdmFsdWUBBQJhbgQCY3oJAKQDAQkBBXZhbHVlAQUCYW8EAmNBCQCiCAEJAQJhbQIFAmN5BQJjegQCY0IJAKIIAQkBAmFtAgUCY3oFAmN5BAJjQwMJAQIhPQIFAmNBBQR1bml0BgkBAiE9AgUCY0IFBHVuaXQFAmNDAQJjRAECYUEEAmNqBAJiZwkAoggBCQECYXoBBQJhQQMJAAECBQJiZwIGU3RyaW5nBAJiaAUCYmcJALUJAgUCYmgFAW0JAQFLAQkAuQkCCQDMCAIFAmFBCQDMCAICEXBvb2wgaXMgbm90IGZvdW5kBQNuaWwCASAEAmFuCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCY2oAAQQCYW8JAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJjagACBAJhRgkBEUBleHRyTmF0aXZlKDEwNTgpAQkBAmFpAQUCYW4EAmFHCQERQGV4dHJOYXRpdmUoMTA1OCkBCQECYWkBBQJhbwQCYlcJARFAZXh0ck5hdGl2ZSgxMDU4KQEJAQJhQwEFAmFBCQCXCgUFAmFGBQJhRwUCYlcFAmFuBQJhbwECY0UBAmFBBAJjRgkBAmNEAQUCYUEEAmFGCAUCY0YCXzEEAmFHCAUCY0YCXzIEAmJXCAUCY0YCXzMEAmFuCAUCY0YCXzQEAmFvCAUCY0YCXzUEAmNHCQERQGV4dHJOYXRpdmUoMTA2MikBCQERQGV4dHJOYXRpdmUoMTA1OCkBCQEBWgAEAmNICQD8BwQFAmNHAhZnZXRQb29sQ3JlYXRvclJFQURPTkxZCQDMCAIFAmFGCQDMCAIFAmFHBQNuaWwFA25pbAUCY0gBAmNJAgJjSgJjSwQCY0wJARFAZXh0ck5hdGl2ZSgxMDYyKQEFAmNKAwkAAAIFAmNLAgVXQVZFUwgJAO8HAQUCY0wHcmVndWxhcgQCYVUJANkEAQUCY0sJAPAHAgUCY0wFAmFVAQJjTQECYUEEAmNOCQECY0QBBQJhQQQCYUYIBQJjTgJfMQQCYUcIBQJjTgJfMgQCYlcIBQJjTgJfMwQCYW4IBQJjTgJfNAQCYW8IBQJjTgJfNQMJAAACCQECY0kCBQJhQQUCYUYAAAkAAAIJAQJjSQIFAmFBBQJhRwAAByICYkUBF2dldFN3YXBDb250cmFjdFJFQURPTkxZAAkAlAoCBQNuaWwJAQJhWgEJAQFOAAJiRQEaZ2V0UG9vbExlYXNlQ29uZmlnUkVBRE9OTFkCAmFmAmFVBAJjTwQCYmcJAJoIAgUEdGhpcwkBAmFUAgUCYWYFAmFVAwkAAQIFAmJnAgNJbnQEAmNQBQJiZwkAlAoCBgkAlwMBCQDMCAIAZAkAzAgCCQCWAwEJAMwIAgAACQDMCAIFAmNQBQNuaWwFA25pbAQCY1EJAJoIAgUEdGhpcwkBAmFWAQUCYVUDCQABAgUCY1ECA0ludAQCY1IFAmNRCQCUCgIGCQCXAwEJAMwIAgBkCQDMCAIJAJYDAQkAzAgCAAAJAMwIAgUCY1IFA25pbAUDbmlsCQCUCgIHAAAEAmNTCAUCY08CXzEEAmNUCAUCY08CXzIEAmNVBAJiZwkAmggCBQR0aGlzCQECYVgCBQJhZgUCYVUDCQABAgUCYmcCA0ludAQCY1YFAmJnCQCWAwEJAMwIAgAACQDMCAIFAmNWBQNuaWwEAmNRCQCaCAIFBHRoaXMJAQJhWQEFAmFVAwkAAQIFAmNRAgNJbnQEAmNXBQJjUQkAlgMBCQDMCAIAAAkAzAgCBQJjVwUDbmlsAAAEAmNYAwkAAAIFAmFVAgVXQVZFUwkAlQoDCQELdmFsdWVPckVsc2UCCQCdCAIFBHRoaXMJAQJhUQACAAkAnQgCBQR0aGlzCQELdmFsdWVPckVsc2UCCQECYVIAAgAFAWMJAJUKAwIAAgAAAAQCY1kIBQJjWAJfMQQCY1oIBQJjWAJfMgQCZGEIBQJjWAJfMwQCZGIJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwkBAmFTAAIACQCUCgIFA25pbAkAmQoHBQJjUwUCY1QFAmNVBQJjWQUCY1oFAmRhBQJkYgJiRQEgZ2V0THBBc3NldEZyb21Qb29sQXNzZXRzUkVBRE9OTFkCAmRjAmRkAwMJAAACBQJkYwIsOExRVzhmN1A1ZDVQWk03R3RaRUJnYXFSUEdTelMzRGZQdWlYclVSSjRBSlMJAAACBQJkZAIFV0FWRVMHCQCUCgIFA25pbAUEdW5pdAQCZGUJAQV2YWx1ZQEJAJoIAgUEdGhpcwkBAmFrAQUCZGMEAmRmCQEFdmFsdWUBCQCaCAIFBHRoaXMJAQJhawEFAmRkBAJkZwkAnQgCBQR0aGlzCQECYXYCCQCkAwEFAmRlCQCkAwEFAmRmBAJkaAMJAAACBQJkZwUEdW5pdAUEdW5pdAkAsAICCQEFdmFsdWUBBQJkZwAECQCUCgIFA25pbAUCZGgCYkUBIWdldFBvb2xBZGRyZXNzRnJvbUxwQXNzZXRSRUFET05MWQECZGkJAJQKAgUDbmlsCQELdmFsdWVPckVsc2UCCQCdCAIFBHRoaXMJAQJhRAEFAmRpAgACYkUBC2NvbnN0cnVjdG9yCAJkagJkawJiSwJiTAJiTQJiTgJkbAJkbQQCZG4JAQJiRgEFAmJFAwkAAAIFAmRuBQJkbgkAzAgCCQELU3RyaW5nRW50cnkCCQEBTwAJAQJiVAcFAmRqBQJkawUCYksFAmJMBQJiTQUCYk4FAmRsCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYWIABQJkbQUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJFAQ1jb25zdHJ1Y3RvclYyAQJkbwQCZG4JAQJiRgEFAmJFAwkAAAIFAmRuBQJkbgQCZHAJAKcIAQkA2QQBBQJkbwMJAAACBQJkcAUCZHAJAMwIAgkBC1N0cmluZ0VudHJ5AgkBAVIABQJkbwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJFAQ1jb25zdHJ1Y3RvclYzBAJiUAJiUQJiUgJiUwQCZG4JAQJiRgEFAmJFAwkAAAIFAmRuBQJkbgQCYnUJALUJAgkBAmFaAQkBAU8ABQFtCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQFPAAkBAmJICwkAkQMCBQJidQABCQCRAwIFAmJ1AAIJAJEDAgUCYnUAAwkAkQMCBQJidQAECQCRAwIFAmJ1AAUJAJEDAgUCYnUABgkAkQMCBQJidQAHBQJiUAUCYlEFAmJSBQJiUwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJFAQ1jb25zdHJ1Y3RvclY0AgJkcQJkcgQCZG4JAQJiRgEFAmJFAwkAAAIFAmRuBQJkbgkAzAgCCQELU3RyaW5nRW50cnkCCQEBUwAFAmRxCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQFUAAkAuQkCBQJkcgUBbQUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJFAQ1jb25zdHJ1Y3RvclY1AQJkcwQCZG4JAQJiRgEFAmJFAwkAAAIFAmRuBQJkbgkAzAgCCQELU3RyaW5nRW50cnkCCQEBWAAFAmRzBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYkUBDWNvbnN0cnVjdG9yVjYCAmR0AmR1BAJkdgkAzAgCCQECYkYBBQJiRQkAzAgCAwkBAiE9AgkApggBBQJkdAUEdW5pdAYCKGludmFsaWQgdm90aW5nIGVtaXNzaW9uIGNvbnRyYWN0IGFkZHJlc3MFA25pbAMJAAACBQJkdgUCZHYJAMwIAgkBC1N0cmluZ0VudHJ5AgkBAVkABQJkdAkAzAgCCQELU3RyaW5nRW50cnkCCQECYWEACQC5CQIFAmR1BQFtBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYkUBCXNldEFkbWlucwECZHcEAmRuCQECYkYBBQJiRQMJAAACBQJkbgUCZG4JAMwIAgkBC1N0cmluZ0VudHJ5AgkBAVcACQC5CQIFAmR3BQFtBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYkUBD2FjdGl2YXRlTmV3UG9vbAgCYWYCYlgCYlkCZHgCZHkCZHoCY2UCZEEEAmRuCQECY3IBBQJiRQMJAAACBQJkbgUCZG4DCQEJaXNEZWZpbmVkAQkAoggBCQECYXoBBQJhZgkBAUsBCQCsAgIJAKwCAgINUG9vbCBhZGRyZXNzIAUCYWYCFCBhbHJlYWR5IHJlZ2lzdGVyZWQuBAJkQgkBAmNrAgUCYlgAAQQCZEMIBQJkQgJfMQQCZEQJAQJjawIFAmJZAwgFAmRCAl8zAAIAAQQCZEUIBQJkRAJfMQQCZEYJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA8QcBCQERQGV4dHJOYXRpdmUoMTA2MikBBQJhZgkArAICAilObyBzY3JpcHQgaGFzIGJlZW4gZm91bmQgb24gcG9vbCBhY2NvdW50IAUCYWYEAmRHCQERQGV4dHJOYXRpdmUoMTA1NykBCQEBUQAEAmRICQECY3gCBQJiWAUCYlkDBQJkSAkBAUsBCQCsAgIJAKwCAgkArAICCQCsAgICBVBvb2wgBQJiWAIBLwUCYlkCHCBoYXMgYWxyZWFkeSBiZWVuIGFjdGl2YXRlZC4EAmRJCQEFdmFsdWUBCQCdCAIFBHRoaXMJAQJhbQIJAKQDAQUCZEMJAKQDAQUCZEUEAmRKAwkAAAIFAmJYAgVXQVZFUwUBbAkAbAYACgAACAkBBXZhbHVlAQkA7AcBCQDZBAEFAmJYCGRlY2ltYWxzAAAAAAUERE9XTgQCZEsDCQAAAgUCYlkCBVdBVkVTBQFsCQBsBgAKAAAICQEFdmFsdWUBCQDsBwEJANkEAQUCYlkIZGVjaW1hbHMAAAAABQRET1dOBAJkTAkAwggFBQJkeAUCZHkAAQAIBgQCYlcJALgIAQUCZEwEAmRNCQDYBAEFAmJXBAJkTgkA/AcECQERQGV4dHJOYXRpdmUoMTA2MikBBQJhZgIIYWN0aXZhdGUJAMwIAgUCYlgJAMwIAgUCYlkFA25pbAUDbmlsAwkAAAIFAmROBQJkTgMJAQIhPQIFAmROAgdzdWNjZXNzCQEBSwECI1Bvb2wgaW5pdGlhbGlzYXRpb24gZXJyb3IgaGFwcGVuZWQuBAJkcwkBEUBleHRyTmF0aXZlKDEwNjIpAQkBAmFaAQkBAVgABAJkTwkA/AcEBQJkcwIOY3JlYXRlT3JVcGRhdGUJAMwIAgUCZE0JAMwIAgUCZHgJAMwIAgcFA25pbAUDbmlsAwkAAAIFAmRPBQJkTwQCZFAJAPwHBAUCZHMCCGFkZExhYmVsCQDMCAIFAmRNCQDMCAIFAWgFA25pbAUDbmlsAwkAAAIFAmRQBQJkUAQCZFEJAPwHBAUCZHMCB3NldExvZ28JAMwIAgUCZE0JAMwIAgUCZEEFA25pbAUDbmlsAwkAAAIFAmRRBQJkUQQCZFIJAPwHBAUCZHMCDWFkZEFzc2V0c0xpbmsJAMwIAgUCYlgJAMwIAgUCYlkJAMwIAgUCZE0FA25pbAUDbmlsAwkAAAIFAmRSBQJkUgQCZFMJAPwHBAUCZHMCGGluY3JlYXNlQXNzZXRQb29sc051bWJlcgkAzAgCBQJiWAUDbmlsBQNuaWwDCQAAAgUCZFMFAmRTCQCUCgIJAM4IAgkAzggCCAUCZEICXzIIBQJkRAJfMgkAzAgCBQJkTAkAzAgCCQEEQnVybgIFAmJXAAEJAMwIAgkBC1N0cmluZ0VudHJ5AgkBAmFtAgkApAMBBQJkQwkApAMBBQJkRQkBAmJVCwUCYWYJAKQDAQUBbwUCZE0FAmJYBQJiWQUCZEoFAmRLBQJkQwUCZEUFAWwFAmNlCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhdAEFAmRNCQECY2YCBQJkQwUCZEUJAMwIAgkBC1N0cmluZ0VudHJ5AgkBAmF2AgkApAMBBQJkQwkApAMBBQJkRQkArAICAgQlc19fBQJkTQkAzAgCCQELU3RyaW5nRW50cnkCCQECYXoBBQJhZgkBAmNmAgUCZEMFAmRFCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhQgIFAmRDBQJkRQUCYWYJAMwIAgkBC1N0cmluZ0VudHJ5AgkBAmFEAQUCZE0FAmFmCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhQwEFAmFmBQJkTQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAmFlAQUCYWYFAmR6CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYXkBBQJhZgUBaQUDbmlsBQJkTQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJiRQEKbWFuYWdlUG9vbAICYWYCZFQEAmRuCQECYkYBBQJiRQMJAAACBQJkbgUCZG4EAmRVCQECY2kBBQJhZgQCYlYJAJEDAgUCZFUFAXcEAmRNCQCRAwIFAmRVBQF4BAJiWAkAkQMCBQJkVQUBeQQCYlkJAJEDAgUCZFUFAXoEAmRKCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCZFUFAUEEAmRLCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCZFUFAUIEAmRDCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCZFUFAUMEAmRFCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCZFUFAUQEAmRWCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUCZFUFAUUEAmNlCQCRAwIFAmRVBQFGCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhbQIJAKQDAQUCZEMJAKQDAQUCZEUJAQJiVQsFAmFmCQCkAwEFAmRUBQJkTQUCYlgFAmJZBQJkSgUCZEsFAmRDBQJkRQUCZFYFAmNlBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYkUBBGVtaXQBAmRXBAJkWAgFAmJFBmNhbGxlcgQCZFkIBQJiRQxvcmlnaW5DYWxsZXIEAmRaCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKIIAQkBAmFDAQkApQgBBQJkWAIdSW52YWxpZCBMUCBhZGRyZXNzIGNhbGxlZCBtZS4EAmVhCQDZBAEFAmRaBAJkcgkAtQkCCQELdmFsdWVPckVsc2UCCQCiCAEJAQFUAAUBbgUBbQQCZHEJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAoggBCQEBUwACKExlZ2FjeSBmYWN0b3J5IGNvbnRyYWN0IGRvZXMgbm90IGV4aXN0cy4DCQBnAgAABQJkVwUDbmlsAwkBD2NvbnRhaW5zRWxlbWVudAIFAmRyCQClCAEFAmRYCQCUCgIFA25pbAUCZHEJAJQKAgkAzAgCCQEHUmVpc3N1ZQMFAmVhBQJkVwYJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAmJFBmNhbGxlcgUCZFcFAmVhBQNuaWwCB3N1Y2Nlc3MCYkUBBGJ1cm4BAmViBAJkWAgFAmJFBmNhbGxlcgQCZFkIBQJiRQxvcmlnaW5DYWxsZXIEAmVjCQEFdmFsdWUBCQCRAwIIBQJiRQhwYXltZW50cwAABAJlZAkBBXZhbHVlAQgFAmVjBmFtb3VudAQCZWUJANgEAQkBBXZhbHVlAQgFAmVjB2Fzc2V0SWQEAmVmCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKIIAQkBAmFDAQkApQgBBQJkWAIdSW52YWxpZCBMUCBhZGRyZXNzIGNhbGxlZCBtZS4DCQECIT0CBQJlZQUCZWYJAQFLAQIVSW52YWxpZCBhc3NldCBwYXNzZWQuAwkBAiE9AgUCZWIFAmVkCQEBSwECFkludmFsaWQgYW1vdW50IHBhc3NlZC4EAmVhCQDZBAEFAmVmCQCUCgIJAMwIAgkBBEJ1cm4CBQJlYQUCZWIFA25pbAIHc3VjY2VzcwJiRQEMbW9kaWZ5V2VpZ2h0AgJiVwJlZwQCZG4DCQAAAgkA2AQBCAgFAmJFBmNhbGxlcgVieXRlcwkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzCQEBWQACAAYJAQJiRgEFAmJFAwkAAAIFAmRuBQJkbgQCYUEJAQJhWgEJAQJhRAEFAmJXBAJlaAkBAmFlAQUCYUEEAmVpCQECYWUBBQFnBAJlagkBC3ZhbHVlT3JFbHNlAgkAnwgBBQJlaQAABAJkegkBC3ZhbHVlT3JFbHNlAgkAnwgBBQJlaAAABAJlawUCZWcEAmJ1CQC1CQIJAQJhWgEJAQFPAAUBbQQCZGoJAQJidwEFAmJ1BAJlbAkA/AcEBQJkagIOb25Nb2RpZnlXZWlnaHQJAMwIAgUCYlcJAMwIAgUCYUEFA25pbAUDbmlsAwkAAAIFAmVsBQJlbAQCZW0DCQAAAgUCZWoAAAUDbmlsCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQJlaQAABQNuaWwEAmVuCQECYWcCBQJhQQAABAJlbwkAnwgBBQJlbgQCZXADCQAAAgUCZW8FBHVuaXQFA25pbAkAzAgCCQELRGVsZXRlRW50cnkBBQJlbgUDbmlsCQDOCAIJAM4IAgkAzAgCCQEMSW50ZWdlckVudHJ5AgUCZWgFAmVrBQNuaWwFAmVtBQJlcAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJiRQENbW9kaWZ5V2VpZ2h0cwQCZXECZXICZXMCZXQEAmRuCQECYkYBBQJiRQMJAAACBQJkbgUCZG4EAmV1CQBpAgkAaAIABQUBZgBkBAJldgkAaQIJAGgCAAUFAWYAZAQCZXcJAGkCCQBoAgAFBQFmAGQEAmJ1CQC1CQIJAQJhWgEJAQFPAAUBbQQCZXgJAQJidwEFAmJ1BAJleQkBAmJ4AQUCYnUEAmV6CQECYWUBBQJlcQQCZUEJAQJhZQEFAmVyBAJlQgkBAmFlAQUCZXMEAmVDCQECYWUBBQJldAQCZUQJAQJiYwEFAmV6BAJlRQkBAmJjAQUCZUEEAmVGCQBlAgUCZUQFAmV3BAJlRwkAZQIFAmVFBQJldwMJAGcCAAAFAmVGCQEBSwEJAKwCAgIWaW52YWxpZCBidGNXZWlnaHROZXc6IAkApAMBBQJlRgMJAGcCAAAFAmVHCQEBSwEJAKwCAgIWaW52YWxpZCBldGhXZWlnaHROZXc6IAkApAMBBQJlRwQCZUgJAQJhWgEJAQJhQwEFAmVxBAJlSQkBAmFaAQkBAmFDAQUCZXIEAmVKCQECYVoBCQECYUMBBQJlcwQCZUsJAQJhWgEJAQJhQwEFAmV0BAJlTAkA/AcEBQJleAIOb25Nb2RpZnlXZWlnaHQJAMwIAgUCZUgJAMwIAgUCZXEFA25pbAUDbmlsAwkAAAIFAmVMBQJlTAQCZU0JAPwHBAUCZXgCDm9uTW9kaWZ5V2VpZ2h0CQDMCAIFAmVJCQDMCAIFAmVyBQNuaWwFA25pbAMJAAACBQJlTQUCZU0EAmVOCQD8BwQFAmV4Ag5vbk1vZGlmeVdlaWdodAkAzAgCBQJlSgkAzAgCBQJlcwUDbmlsBQNuaWwDCQAAAgUCZU4FAmVOBAJlTwkA/AcEBQJleAIOb25Nb2RpZnlXZWlnaHQJAMwIAgUCZUsJAMwIAgUCZXQFA25pbAUDbmlsAwkAAAIFAmVPBQJlTwkAzAgCCQEMSW50ZWdlckVudHJ5AgUCZXoFAmVGCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQJlQQUCZUcJAMwIAgkBDEludGVnZXJFbnRyeQIFAmVCBQJldQkAzAgCCQEMSW50ZWdlckVudHJ5AgUCZUMFAmV2CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYWcCBQJlcQAABQJlRAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAmFnAgUCZXIAAAUCZUUJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJhZwIFAmVzAAAFAmV1CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECYWcCBQJldAAABQJldgUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAmJFARhjaGVja1d4RW1pc3Npb25Qb29sTGFiZWwCAmFGAmFHBAJlUAQCYmcJAKAIAQkBAmFFAgUCYUYFAmFHAwkAAQIFAmJnAgdCb29sZWFuBAJjVgUCYmcFAmNWBwkAlAoCBQNuaWwFAmVQAmJFARZzZXRXeEVtaXNzaW9uUG9vbExhYmVsAgJhRgJhRwQCZG4JAQJjcgEFAmJFAwkAAAIFAmRuBQJkbgkAlAoCCQDMCAIJAQxCb29sZWFuRW50cnkCCQECYUUCBQJhRgUCYUcGBQNuaWwFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYkUBGWRlbGV0ZVd4RW1pc3Npb25Qb29sTGFiZWwCAmFGAmFHBAJkbgMJAAACCAUCYkUGY2FsbGVyBQR0aGlzBgkBAmNyAQUCYkUDCQAAAgUCZG4FAmRuCQCUCgIJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAmFFAgUCYUYFAmFHBQNuaWwFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYkUBEm9uVmVyaWZpY2F0aW9uTG9zcwECYVUEAmRuAwkAAAIJANgEAQgIBQJiRQZjYWxsZXIFYnl0ZXMJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwkBAVgAAgAGCQECYkYBBQJiRQMJAAACBQJkbgUCZG4EAmR1CQECYnkABAJlUQMJAGYCCQCQAwEFAmR1AAAGCQEBSwECFGludmFsaWQgcHJpY2UgYXNzZXRzAwkAAAIFAmVRBQJlUQoBAmVSAgJlUwJlVAQCY1AJAPwHBAUEdGhpcwIZZGVsZXRlV3hFbWlzc2lvblBvb2xMYWJlbAkAzAgCBQJhVQkAzAgCBQJlVAUDbmlsBQNuaWwDCQAAAgUCY1AFAmNQBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuBAJlVQoAAmVWBQJkdQoAAmVXCQCQAwEFAmVWCgACZVgFBHVuaXQKAQJlWQICZVoCZmEDCQBnAgUCZmEFAmVXBQJlWgkBAmVSAgUCZVoJAJEDAgUCZVYFAmZhCgECZmICAmVaAmZhAwkAZwIFAmZhBQJlVwUCZVoJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMwkBAmZiAgkBAmVZAgkBAmVZAgkBAmVZAgkBAmVZAgkBAmVZAgkBAmVZAgkBAmVZAgkBAmVZAgkBAmVZAgkBAmVZAgkBAmVZAgkBAmVZAgkBAmVZAgUCZVgAAAABAAIAAwAEAAUABgAHAAgACQAKAAsADAANAwkAAAIFAmVVBQJlVQkAlAoCBQNuaWwFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYkUBKGlzUG9vbE9uZVRva2VuT3BlcmF0aW9uc0Rpc2FibGVkUkVBRE9OTFkBAmFmBAJkVQkBAmNpAQUCYWYEAmFxCQCUCgIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJkVQUBQwkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmRVBQFEBAJmYwkBC3ZhbHVlT3JFbHNlAgkAoAgBCQECYXABBQJhcQcEAmZkCQELdmFsdWVPckVsc2UCCQCgCAEJAQJhcwAHCQCUCgIFA25pbAMFAmZkBgUCZmMCYkUBEGdldEluRmVlUkVBRE9OTFkBAmFmBAJmZQkBAmN1AwkBAmFIAQUCYWYJAQJhSQAAAAkAlAoCBQNuaWwFAmZlAmJFARFnZXRPdXRGZWVSRUFET05MWQECYWYEAmZlCQECY3UDCQECYUsBBQJhZgkBAmFMAAkAawMACgUBYgCQTgkAlAoCBQNuaWwFAmZlAmJFARJnZXRTd2FwRmVlUkVBRE9OTFkBAmZmBAJmZwQCYmcJAJ0IAgUEdGhpcwkBAmFKAQUCZmYDCQABAgUCYmcCBlN0cmluZwQCYmgFAmJnBAJmaAkAtQkCBQJiaAUBbQQCZmkJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQJmaAABBAJmagkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmZoAAIJAJQKAgUCZmkFAmZqAwkAAQIFAmJnAgRVbml0BQR1bml0CQACAQILTWF0Y2ggZXJyb3IJAJQKAgUDbmlsBQJmZwJiRQEQcG9vbEluZm9SRUFET05MWQICZmsCZmwEAmZtCQCaCAIFBHRoaXMJAQJhawEFAmZrBAJmbgkAmggCBQR0aGlzCQECYWsBBQJmbAQCZm8JAJ0IAgUEdGhpcwkBAmFCAgkBBXZhbHVlAQUCZm0JAQV2YWx1ZQEFAmZuBAJmcAkAnQgCBQR0aGlzCQECYUMBCQEFdmFsdWUBBQJmbwQCZEgDAwkBCWlzRGVmaW5lZAEFAmZtCQEJaXNEZWZpbmVkAQUCZm4HCQEJaXNEZWZpbmVkAQUCZm8HBAJmcQMFAmRICQCUCgIJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQV2YWx1ZQEFAmZvCQECYmQBCQEFdmFsdWUBBQJmcAUEdW5pdAkAlAoCBQNuaWwFAmZxAmJFARVnZXRQb29sU3RhdHVzUkVBRE9OTFkBAmFmBAJjagkAtQkCCQECYVoBCQECYXoBBQJhZgUBbQQCYW4JAJEDAgUCY2oAAQQCYW8JAJEDAgUCY2oAAgQCY0EJALUJAgkBAmFaAQkBAmFtAgUCYW4FAmFvBQFtCQCUCgIFA25pbAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFAmNBBQF3AmJFARVnZXRQb29sQ29uZmlnUkVBRE9OTFkBAmFmBAJjagkAtQkCCQECYVoBCQECYXoBBQJhZgUBbQQCYW4JAJEDAgUCY2oAAQQCYW8JAJEDAgUCY2oAAgQCY0EJALUJAgkBAmFaAQkBAmFtAgUCYW4FAmFvBQFtCQCUCgIFA25pbAUCY0ECYkUBIGdldFBvb2xDb25maWdCeUxwQXNzZXRJZFJFQURPTkxZAQJkTQQCY2oJALUJAgkBAmFaAQkBAmF0AQUCZE0FAW0EAmFuCQCRAwIFAmNqAAEEAmFvCQCRAwIFAmNqAAIEAmNBCQC1CQIJAQJhWgEJAQJhbQIFAmFuBQJhbwUBbQkAlAoCBQNuaWwFAmNBAmJFARJwb29sRXhpc3RzUkVBRE9OTFkCAmFGAmFHCQCUCgIFA25pbAkBAmN4AgUCYUYFAmFHAmJFARtza2lwT3JkZXJWYWxpZGF0aW9uUkVBRE9OTFkBAmFmCQCUCgIFA25pbAkBC3ZhbHVlT3JFbHNlAgkAoAgBCQECYU0BBQJhZgcCYkUBGmdldENoYW5nZUFtcENvbmZpZ1JFQURPTkxZAQJhZgQCZnIJARFAZXh0ck5hdGl2ZSgxMDU1KQEJAQJhTgEFAmFmBAJmcwkBEUBleHRyTmF0aXZlKDEwNTUpAQkBAmFPAQUCYWYEAmZ0CQERQGV4dHJOYXRpdmUoMTA1NSkBCQECYVABBQJhZgkAlAoCBQNuaWwJAMwIAgUCZnIJAMwIAgUCZnMJAMwIAgUCZnQFA25pbAJiRQEVZ2V0UG9vbFdlaWdodFJFQURPTkxZAQJiVwQCYWYJAQJhWgEJAQJhRAEFAmJXBAJmdQkBC3ZhbHVlT3JFbHNlAgkAnwgBCQECYWUBBQJhZgAACQCUCgIFA25pbAUCZnUCYkUBCmRlbGV0ZVBvb2wBAmFBBAJkVQkBAmNpAQUCYUEEAmRuAwkAAAIJAKUIAQgFAmJFBmNhbGxlcgkBAmNFAQUCYUEDCQECY00BBQJhQQYJAQFLAQIRUG9vbCBpcyBub3QgZW1wdHkJAQJiRgEFAmJFAwkAAAIFAmRuBQJkbgQCZnYDCQAAAgkBC3ZhbHVlT3JFbHNlAgkAnwgBCQECYWUBBQJhQQAAAAAGCQEBSwECF1Bvb2wgd2VpZ2h0IGlzIG5vdCBaZXJvAwkAAAIFAmZ2BQJmdgQCZncDCQAAAgkAkQMCBQJkVQUBdwkApAMBBQFyBgkBAUsBAhlQb29sIG11c3QgYmUgU0hVVERPV04gKDQpAwkAAAIFAmZ3BQJmdwQCZngJAQJjRAEFAmFBBAJhRggFAmZ4Al8xBAJhRwgFAmZ4Al8yBAJiVwgFAmZ4Al8zBAJhbggFAmZ4Al80BAJhbwgFAmZ4Al81BAJjRwkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTgpAQkBAVoABAJmeQkA/AcEBQJjRwIKZGVsZXRlUG9vbAkAzAgCBQJhRgkAzAgCBQJhRwUDbmlsBQNuaWwDCQAAAgUCZnkFAmZ5BAJkdAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTgpAQkBAVkABAJmegkA/AcEBQJkdAIKZGVsZXRlUG9vbAkAzAgCBQJhRgkAzAgCBQJhRwUDbmlsBQNuaWwDCQAAAgUCZnoFAmZ6BAJkcwkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTgpAQkBAVgABAJmQQkA/AcEBQJkcwIKZGVsZXRlUG9vbAkAzAgCBQJhRgkAzAgCBQJhRwUDbmlsBQNuaWwDCQAAAgUCZkEFAmZBCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhQwEFAmFBCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhegEFAmFBCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhdgIJAKQDAQUCYW4JAKQDAQUCYW8JAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAmFCAgUCYW4FAmFvCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhbQIJAKQDAQUCYW4JAKQDAQUCYW8JAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAmF0AQUCYlcJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAmFEAQUCYlcJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAmFFAgUCYUYFAmFHCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhZQEFAmFBCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJheQEFAmFBCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhSAEFAmFBCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhSwEFAmFBCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhTQEFAmFBCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhTgEFAmFBCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhTwEFAmFBCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhUAEFAmFBBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAmZCAQJmQwAEAmZEBAJiZwkBAmJ6AAMJAAECBQJiZwIKQnl0ZVZlY3RvcgQCYkcFAmJnBQJiRwMJAAECBQJiZwIEVW5pdAgFAmZCD3NlbmRlclB1YmxpY0tleQkAAgECC01hdGNoIGVycm9yCQD0AwMIBQJmQglib2R5Qnl0ZXMJAJEDAggFAmZCBnByb29mcwAABQJmRIROJg4=", "height": 2692775, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: CBsJMtfca1ASq6C6nftddgzYuZ24BxZbrT6o3Z7jUqpH Next: FsMwn7j7hKG8RYngfkw1ytMpHno4E3TrQRyWHAGniveX Diff:
Old | New | Differences | |
---|---|---|---|
21 | 21 | ||
22 | 22 | let j = "WAVES" | |
23 | 23 | ||
24 | - | let k = | |
24 | + | let k = "factory_v2.ride" | |
25 | 25 | ||
26 | - | let l = | |
26 | + | let l = ((100 * 1000) * 1000) | |
27 | 27 | ||
28 | - | let m = "" | |
28 | + | let m = "__" | |
29 | 29 | ||
30 | - | let n = | |
30 | + | let n = "" | |
31 | 31 | ||
32 | - | let o = | |
32 | + | let o = 1 | |
33 | 33 | ||
34 | - | let p = | |
34 | + | let p = 2 | |
35 | 35 | ||
36 | - | let q = | |
36 | + | let q = 3 | |
37 | 37 | ||
38 | - | let r = | |
38 | + | let r = 4 | |
39 | 39 | ||
40 | - | let s = | |
40 | + | let s = 1 | |
41 | 41 | ||
42 | - | let t = | |
42 | + | let t = 2 | |
43 | 43 | ||
44 | - | let u = | |
44 | + | let u = 3 | |
45 | 45 | ||
46 | - | let v = | |
46 | + | let v = 1 | |
47 | 47 | ||
48 | - | let w = | |
48 | + | let w = 2 | |
49 | 49 | ||
50 | - | let x = | |
50 | + | let x = 3 | |
51 | 51 | ||
52 | - | let y = | |
52 | + | let y = 4 | |
53 | 53 | ||
54 | - | let z = | |
54 | + | let z = 5 | |
55 | 55 | ||
56 | - | let A = | |
56 | + | let A = 6 | |
57 | 57 | ||
58 | - | let B = | |
58 | + | let B = 7 | |
59 | 59 | ||
60 | - | let C = | |
60 | + | let C = 8 | |
61 | 61 | ||
62 | - | let D = | |
62 | + | let D = 9 | |
63 | 63 | ||
64 | - | let E = | |
64 | + | let E = 10 | |
65 | 65 | ||
66 | - | let F = | |
66 | + | let F = 11 | |
67 | 67 | ||
68 | - | let G = | |
68 | + | let G = "WX_EMISSION" | |
69 | 69 | ||
70 | - | func H () = "%s__allowedLpScriptHash" | |
70 | + | let H = [G] | |
71 | + | ||
72 | + | func I (J) = makeString([k, ": ", J], "") | |
71 | 73 | ||
72 | 74 | ||
73 | - | func | |
75 | + | func K (J) = throw(I(J)) | |
74 | 76 | ||
75 | 77 | ||
76 | - | func | |
78 | + | func L () = "%s__allowedLpScriptHash" | |
77 | 79 | ||
78 | 80 | ||
79 | - | func | |
81 | + | func M () = "%s__allowedLpStableScriptHash" | |
80 | 82 | ||
81 | 83 | ||
82 | - | func | |
84 | + | func N () = "%s__swapContract" | |
83 | 85 | ||
84 | 86 | ||
85 | - | func | |
87 | + | func O () = "%s__factoryConfig" | |
86 | 88 | ||
87 | 89 | ||
88 | - | func | |
90 | + | func P () = "%s__lpTokensList" | |
89 | 91 | ||
90 | 92 | ||
91 | - | func | |
93 | + | func Q () = "%s%s__pool__scriptHash" | |
92 | 94 | ||
93 | 95 | ||
94 | - | func | |
96 | + | func R () = "%s%s__matcher__publicKey" | |
95 | 97 | ||
96 | 98 | ||
97 | - | func | |
99 | + | func S () = "%s__legacyFactoryContract" | |
98 | 100 | ||
99 | 101 | ||
100 | - | func | |
102 | + | func T () = "%s__legacyPools" | |
101 | 103 | ||
102 | 104 | ||
103 | - | func | |
105 | + | func U () = "%s__managerPublicKey" | |
104 | 106 | ||
105 | 107 | ||
106 | - | func | |
108 | + | func V () = "%s__managerVaultAddress" | |
107 | 109 | ||
108 | 110 | ||
109 | - | func | |
111 | + | func W () = "%s__adminPubKeys" | |
110 | 112 | ||
111 | 113 | ||
112 | - | func | |
114 | + | func X () = "%s__assetsStoreContract" | |
113 | 115 | ||
114 | 116 | ||
115 | - | func | |
117 | + | func Y () = "%s__votingEmissionContract" | |
116 | 118 | ||
117 | 119 | ||
118 | - | func | |
120 | + | func Z () = "%s__userPoolsContract" | |
119 | 121 | ||
120 | 122 | ||
121 | - | func | |
123 | + | func aa () = makeString(["%s", "priceAssets"], m) | |
122 | 124 | ||
123 | 125 | ||
124 | - | func | |
126 | + | func ab () = "%s__priceDecimals" | |
125 | 127 | ||
126 | 128 | ||
127 | - | func | |
129 | + | func ac () = "%s__shutdown" | |
128 | 130 | ||
129 | 131 | ||
130 | - | func ad ( | |
132 | + | func ad () = "%s__nextInternalAssetId" | |
131 | 133 | ||
132 | 134 | ||
133 | - | func | |
135 | + | func ae (af) = ("%s%s__poolWeight__" + af) | |
134 | 136 | ||
135 | 137 | ||
136 | - | func | |
138 | + | func ag (af,ah) = ((("%s%s__poolWeight__" + af) + "__") + toString(ah)) | |
137 | 139 | ||
138 | 140 | ||
139 | - | func ak (al) = { | |
140 | - | let am = al | |
141 | - | let ai = am._1 | |
142 | - | let aj = am._2 | |
143 | - | makeString(["%d%d%s", toString(ai), toString(aj), "oneTokenOperationsDisabled"], l) | |
141 | + | func ai (aj) = ("%s%s%d__mappings__internal2baseAssetId__" + toString(aj)) | |
142 | + | ||
143 | + | ||
144 | + | func ak (al) = ("%s%s%s__mappings__baseAsset2internalId__" + al) | |
145 | + | ||
146 | + | ||
147 | + | func am (an,ao) = (((("%d%d%s__" + an) + "__") + ao) + "__config") | |
148 | + | ||
149 | + | ||
150 | + | func ap (aq) = { | |
151 | + | let ar = aq | |
152 | + | let an = ar._1 | |
153 | + | let ao = ar._2 | |
154 | + | makeString(["%d%d%s", toString(an), toString(ao), "oneTokenOperationsDisabled"], m) | |
144 | 155 | } | |
145 | 156 | ||
146 | 157 | ||
147 | - | func | |
158 | + | func as () = makeString(["%s", "oneTokenOperationsDisabled"], m) | |
148 | 159 | ||
149 | 160 | ||
150 | - | func | |
161 | + | func at (au) = (("%s%s%s__" + au) + "__mappings__lpAsset2Pool") | |
151 | 162 | ||
152 | 163 | ||
153 | - | func | |
164 | + | func av (aw,ax) = (((("%d%d%s%s__" + aw) + "__") + ax) + "__mappings__PoolAssets2LpAsset") | |
154 | 165 | ||
155 | 166 | ||
156 | - | func | |
167 | + | func ay (af) = ("%s%s__spread__" + af) | |
157 | 168 | ||
158 | 169 | ||
159 | - | func | |
170 | + | func az (aA) = (("%s%s%s__" + aA) + "__mappings__poolContract2PoolAssets") | |
160 | 171 | ||
161 | 172 | ||
162 | - | func | |
173 | + | func aB (aw,ax) = (((("%d%d%s%s__" + toString(aw)) + "__") + toString(ax)) + "__mappings__poolAssets2PoolContract") | |
163 | 174 | ||
164 | 175 | ||
165 | - | func | |
176 | + | func aC (aA) = (("%s%s%s__" + aA) + "__mappings__poolContract2LpAsset") | |
166 | 177 | ||
167 | 178 | ||
168 | - | func | |
179 | + | func aD (au) = (("%s%s%s__" + au) + "__mappings__lpAsset2PoolContract") | |
169 | 180 | ||
170 | 181 | ||
171 | - | func | |
182 | + | func aE (aF,aG) = ((("%s%s%s__wxEmission__" + aF) + "__") + aG) | |
172 | 183 | ||
173 | 184 | ||
174 | - | func | |
185 | + | func aH (af) = ("%s%s__inFee__" + af) | |
175 | 186 | ||
176 | 187 | ||
177 | - | func | |
188 | + | func aI () = "%s__inFeeDefault" | |
178 | 189 | ||
179 | 190 | ||
180 | - | func | |
191 | + | func aJ (af) = ("%s%s__swapFee__" + af) | |
181 | 192 | ||
182 | 193 | ||
183 | - | func | |
194 | + | func aK (af) = ("%s%s__outFee__" + af) | |
184 | 195 | ||
185 | 196 | ||
186 | - | func | |
197 | + | func aL () = "%s__outFeeDefault" | |
187 | 198 | ||
188 | 199 | ||
189 | - | func | |
200 | + | func aM (af) = ("%s%s__skipOrderValidation__" + af) | |
190 | 201 | ||
191 | 202 | ||
192 | - | func | |
203 | + | func aN (af) = ("%s%s__changeAmpDelay__" + af) | |
193 | 204 | ||
194 | 205 | ||
195 | - | func | |
206 | + | func aO (af) = ("%s%s__changeAmpDelta__" + af) | |
196 | 207 | ||
197 | 208 | ||
198 | - | func | |
209 | + | func aP (af) = ("%s%s__changeAmpTarget__" + af) | |
199 | 210 | ||
200 | 211 | ||
201 | - | func | |
212 | + | func aQ () = "%s__sWavesProxyAddress" | |
202 | 213 | ||
203 | 214 | ||
204 | - | func | |
215 | + | func aR () = "%s__sWavesAssetId" | |
205 | 216 | ||
206 | 217 | ||
207 | - | func | |
218 | + | func aS () = "%s__stakingProfitAddress" | |
208 | 219 | ||
209 | 220 | ||
210 | - | func | |
221 | + | func aT (af,aU) = makeString(["%s%s%s", "leasedRatio", af, aU], m) | |
211 | 222 | ||
212 | 223 | ||
213 | - | func | |
224 | + | func aV (aU) = makeString(["%s%s", "leasedRatioDefault", aU], m) | |
214 | 225 | ||
215 | 226 | ||
216 | - | func | |
227 | + | func aW (af,aU) = makeString(["%s%s%s", "leasedRatioTolerance", af, aU], m) | |
217 | 228 | ||
218 | 229 | ||
219 | - | func | |
230 | + | func aX (af,aU) = makeString(["%s%s%s", "minBalance", af, aU], m) | |
220 | 231 | ||
221 | 232 | ||
222 | - | func | |
233 | + | func aY (aU) = makeString(["%s%s", "minBalanceDefault", aU], m) | |
223 | 234 | ||
224 | 235 | ||
225 | - | func | |
236 | + | func aZ (ba) = valueOrErrorMessage(getString(this, ba), ("No data for this.key=" + ba)) | |
226 | 237 | ||
227 | 238 | ||
228 | - | func | |
239 | + | func bb (ba) = valueOrErrorMessage(getBoolean(this, ba), ("No data for this.key=" + ba)) | |
229 | 240 | ||
230 | 241 | ||
231 | - | func | |
242 | + | func bc (ba) = valueOrErrorMessage(getInteger(this, ba), ("No data for this.key=" + ba)) | |
232 | 243 | ||
233 | 244 | ||
234 | - | func | |
245 | + | func bd (be) = if ((be == j)) | |
235 | 246 | then unit | |
236 | - | else fromBase58String( | |
247 | + | else fromBase58String(be) | |
237 | 248 | ||
238 | 249 | ||
239 | - | func | |
240 | - | let | |
241 | - | if ($isInstanceOf( | |
250 | + | func bf () = { | |
251 | + | let bg = getString(V()) | |
252 | + | if ($isInstanceOf(bg, "String")) | |
242 | 253 | then { | |
243 | - | let | |
244 | - | addressFromStringValue( | |
254 | + | let bh = bg | |
255 | + | addressFromStringValue(bh) | |
245 | 256 | } | |
246 | 257 | else this | |
247 | 258 | } | |
248 | 259 | ||
249 | 260 | ||
250 | - | let | |
261 | + | let bi = 1 | |
251 | 262 | ||
252 | - | let | |
263 | + | let bj = 2 | |
253 | 264 | ||
254 | - | let | |
265 | + | let bk = 3 | |
255 | 266 | ||
256 | - | let | |
267 | + | let bl = 4 | |
257 | 268 | ||
258 | - | let | |
269 | + | let bm = 5 | |
259 | 270 | ||
260 | - | let | |
271 | + | let bn = 6 | |
261 | 272 | ||
262 | - | let | |
273 | + | let bo = 7 | |
263 | 274 | ||
264 | - | let | |
275 | + | let bp = 8 | |
265 | 276 | ||
266 | - | let | |
277 | + | let bq = 9 | |
267 | 278 | ||
268 | - | let | |
279 | + | let br = 10 | |
269 | 280 | ||
270 | - | let | |
281 | + | let bs = 11 | |
271 | 282 | ||
272 | - | func | |
283 | + | func bt (bu) = addressFromStringValue(bu[bj]) | |
273 | 284 | ||
274 | 285 | ||
275 | - | func | |
286 | + | func bv (bu) = addressFromStringValue(bu[bm]) | |
276 | 287 | ||
277 | 288 | ||
278 | - | func | |
289 | + | func bw (bu) = addressFromStringValue(bu[bi]) | |
279 | 290 | ||
280 | 291 | ||
281 | - | func | |
292 | + | func bx (bu) = addressFromStringValue(bu[br]) | |
282 | 293 | ||
283 | 294 | ||
284 | - | func | |
285 | - | let | |
286 | - | if ($isInstanceOf( | |
295 | + | func by () = { | |
296 | + | let bg = getString(aa()) | |
297 | + | if ($isInstanceOf(bg, "String")) | |
287 | 298 | then { | |
288 | - | let | |
289 | - | if ((size( | |
299 | + | let bh = bg | |
300 | + | if ((size(bh) == 0)) | |
290 | 301 | then nil | |
291 | - | else split_4C( | |
302 | + | else split_4C(bh, m) | |
292 | 303 | } | |
293 | 304 | else nil | |
294 | 305 | } | |
295 | 306 | ||
296 | 307 | ||
297 | - | func | |
298 | - | let | |
299 | - | let | |
300 | - | if ($isInstanceOf( | |
308 | + | func bz () = { | |
309 | + | let bA = bf() | |
310 | + | let bg = getString(bA, U()) | |
311 | + | if ($isInstanceOf(bg, "String")) | |
301 | 312 | then { | |
302 | - | let | |
303 | - | fromBase58String( | |
313 | + | let bh = bg | |
314 | + | fromBase58String(bh) | |
304 | 315 | } | |
305 | - | else if ($isInstanceOf( | |
316 | + | else if ($isInstanceOf(bg, "Unit")) | |
306 | 317 | then unit | |
307 | 318 | else throw("Match error") | |
308 | 319 | } | |
309 | 320 | ||
310 | 321 | ||
311 | - | let | |
322 | + | let bB = K("Permission denied") | |
312 | 323 | ||
313 | - | let | |
324 | + | let bC = K("Test error here") | |
314 | 325 | ||
315 | - | func | |
326 | + | func bD (bE) = if ((bE.caller == this)) | |
316 | 327 | then true | |
317 | - | else | |
328 | + | else bB | |
318 | 329 | ||
319 | 330 | ||
320 | - | func | |
321 | - | let | |
322 | - | if ($isInstanceOf( | |
331 | + | func bF (bE) = { | |
332 | + | let bg = bz() | |
333 | + | if ($isInstanceOf(bg, "ByteVector")) | |
323 | 334 | then { | |
324 | - | let | |
325 | - | if (( | |
335 | + | let bG = bg | |
336 | + | if ((bE.callerPublicKey == bG)) | |
326 | 337 | then true | |
327 | - | else | |
338 | + | else bB | |
328 | 339 | } | |
329 | - | else if ($isInstanceOf( | |
330 | - | then | |
340 | + | else if ($isInstanceOf(bg, "Unit")) | |
341 | + | then bD(bE) | |
331 | 342 | else throw("Match error") | |
332 | 343 | } | |
333 | 344 | ||
334 | 345 | ||
335 | - | func | |
346 | + | func bH (bI,bJ,bK,bL,bM,bN,bO,bP,bQ,bR,bS) = makeString(["%s%s%s%s%s%s%s%s%s%s%s", bI, bJ, bK, bL, bM, bN, bO, bP, bQ, bR, bS], m) | |
336 | 347 | ||
337 | 348 | ||
338 | - | func | |
349 | + | func bT (bI,bJ,bK,bL,bM,bN,bO) = makeString(["%s%s%s%s%s%s", bI, bJ, bK, bL, bM, bN, bO], m) | |
339 | 350 | ||
340 | 351 | ||
341 | - | func | |
352 | + | func bU (af,bV,bW,bX,bY,bZ,ca,cb,cc,cd,ce) = makeString(["%s%d%s%s%s%d%d%d%d%d%s", af, bV, bW, bX, bY, toString(bZ), toString(ca), toString(cb), toString(cc), toString(cd), ce], m) | |
342 | 353 | ||
343 | 354 | ||
344 | - | func | |
355 | + | func cf (cg,ch) = makeString(["%d%d", toString(cg), toString(ch)], m) | |
345 | 356 | ||
346 | 357 | ||
347 | - | func | |
348 | - | let | |
349 | - | let | |
350 | - | let | |
351 | - | split( | |
358 | + | func ci (af) = { | |
359 | + | let cj = split(aZ(az(af)), m) | |
360 | + | let an = cj[1] | |
361 | + | let ao = cj[2] | |
362 | + | split(aZ(am(an, ao)), m) | |
352 | 363 | } | |
353 | 364 | ||
354 | 365 | ||
355 | - | func | |
356 | - | let | |
357 | - | let | |
358 | - | let | |
366 | + | func ck (cl,cm) = { | |
367 | + | let cn = valueOrElse(getInteger(this, ak(cl)), 0) | |
368 | + | let co = valueOrElse(getInteger(this, ad()), 0) | |
369 | + | let cp = if ((cn == 0)) | |
359 | 370 | then { | |
360 | - | let | |
361 | - | $Tuple3( | |
371 | + | let cq = (co + cm) | |
372 | + | $Tuple3(cq, [IntegerEntry(ad(), cq), IntegerEntry(ak(cl), cq), StringEntry(ai(cq), cl)], true) | |
362 | 373 | } | |
363 | - | else $Tuple3( | |
364 | - | | |
374 | + | else $Tuple3(cn, nil, false) | |
375 | + | cp | |
365 | 376 | } | |
366 | 377 | ||
367 | 378 | ||
368 | - | func | |
369 | - | let | |
370 | - | if (containsElement( | |
379 | + | func cr (bE) = { | |
380 | + | let cs = split(valueOrElse(getString(W()), n), m) | |
381 | + | if (containsElement(cs, toBase58String(bE.callerPublicKey))) | |
371 | 382 | then true | |
372 | 383 | else { | |
373 | - | let | |
374 | - | if (( | |
384 | + | let ct = bF(bE) | |
385 | + | if ((ct == ct)) | |
375 | 386 | then true | |
376 | 387 | else throw("Strict value is not equal to itself.") | |
377 | 388 | } | |
378 | 389 | } | |
379 | 390 | ||
380 | 391 | ||
381 | - | func | |
392 | + | func cu (ba,cv,cw) = valueOrElse(getInteger(this, ba), valueOrElse(getInteger(this, cv), cw)) | |
382 | 393 | ||
383 | 394 | ||
384 | - | func | |
385 | - | let | |
386 | - | let | |
387 | - | if (if (( | |
395 | + | func cx (aF,aG) = { | |
396 | + | let an = getInteger(ak(aF)) | |
397 | + | let ao = getInteger(ak(aG)) | |
398 | + | if (if ((an == unit)) | |
388 | 399 | then true | |
389 | - | else ( | |
400 | + | else (ao == unit)) | |
390 | 401 | then false | |
391 | 402 | else { | |
392 | - | let | |
393 | - | let | |
394 | - | let | |
395 | - | let | |
396 | - | let | |
403 | + | let cy = toString(value(an)) | |
404 | + | let cz = toString(value(ao)) | |
405 | + | let cA = getString(am(cy, cz)) | |
406 | + | let cB = getString(am(cz, cy)) | |
407 | + | let cC = if ((cA != unit)) | |
397 | 408 | then true | |
398 | - | else ( | |
399 | - | | |
409 | + | else (cB != unit) | |
410 | + | cC | |
400 | 411 | } | |
401 | 412 | } | |
402 | 413 | ||
403 | 414 | ||
404 | - | @Callable(bz) | |
405 | - | func getSwapContractREADONLY () = $Tuple2(nil, aU(J())) | |
415 | + | func cD (aA) = { | |
416 | + | let cj = { | |
417 | + | let bg = getString(az(aA)) | |
418 | + | if ($isInstanceOf(bg, "String")) | |
419 | + | then { | |
420 | + | let bh = bg | |
421 | + | split(bh, m) | |
422 | + | } | |
423 | + | else K(makeString([aA, "pool is not found"], " ")) | |
424 | + | } | |
425 | + | let an = parseIntValue(cj[1]) | |
426 | + | let ao = parseIntValue(cj[2]) | |
427 | + | let aF = getStringValue(ai(an)) | |
428 | + | let aG = getStringValue(ai(ao)) | |
429 | + | let bW = getStringValue(aC(aA)) | |
430 | + | $Tuple5(aF, aG, bW, an, ao) | |
431 | + | } | |
432 | + | ||
433 | + | ||
434 | + | func cE (aA) = { | |
435 | + | let cF = cD(aA) | |
436 | + | let aF = cF._1 | |
437 | + | let aG = cF._2 | |
438 | + | let bW = cF._3 | |
439 | + | let an = cF._4 | |
440 | + | let ao = cF._5 | |
441 | + | let cG = addressFromStringValue(getStringValue(Z())) | |
442 | + | let cH = invoke(cG, "getPoolCreatorREADONLY", [aF, aG], nil) | |
443 | + | cH | |
444 | + | } | |
445 | + | ||
446 | + | ||
447 | + | func cI (cJ,cK) = { | |
448 | + | let cL = addressFromStringValue(cJ) | |
449 | + | if ((cK == "WAVES")) | |
450 | + | then wavesBalance(cL).regular | |
451 | + | else { | |
452 | + | let aU = fromBase58String(cK) | |
453 | + | assetBalance(cL, aU) | |
454 | + | } | |
455 | + | } | |
456 | + | ||
457 | + | ||
458 | + | func cM (aA) = { | |
459 | + | let cN = cD(aA) | |
460 | + | let aF = cN._1 | |
461 | + | let aG = cN._2 | |
462 | + | let bW = cN._3 | |
463 | + | let an = cN._4 | |
464 | + | let ao = cN._5 | |
465 | + | if ((cI(aA, aF) == 0)) | |
466 | + | then (cI(aA, aG) == 0) | |
467 | + | else false | |
468 | + | } | |
469 | + | ||
470 | + | ||
471 | + | @Callable(bE) | |
472 | + | func getSwapContractREADONLY () = $Tuple2(nil, aZ(N())) | |
406 | 473 | ||
407 | 474 | ||
408 | 475 | ||
409 | - | @Callable( | |
410 | - | func getPoolLeaseConfigREADONLY ( | |
411 | - | let | |
412 | - | let | |
413 | - | if ($isInstanceOf( | |
476 | + | @Callable(bE) | |
477 | + | func getPoolLeaseConfigREADONLY (af,aU) = { | |
478 | + | let cO = { | |
479 | + | let bg = getInteger(this, aT(af, aU)) | |
480 | + | if ($isInstanceOf(bg, "Int")) | |
414 | 481 | then { | |
415 | - | let | |
416 | - | $Tuple2(true, min([100, max([0, | |
482 | + | let cP = bg | |
483 | + | $Tuple2(true, min([100, max([0, cP])])) | |
417 | 484 | } | |
418 | 485 | else { | |
419 | - | let | |
420 | - | if ($isInstanceOf( | |
486 | + | let cQ = getInteger(this, aV(aU)) | |
487 | + | if ($isInstanceOf(cQ, "Int")) | |
421 | 488 | then { | |
422 | - | let | |
423 | - | $Tuple2(true, min([100, max([0, | |
489 | + | let cR = cQ | |
490 | + | $Tuple2(true, min([100, max([0, cR])])) | |
424 | 491 | } | |
425 | 492 | else $Tuple2(false, 0) | |
426 | 493 | } | |
427 | 494 | } | |
428 | - | let | |
429 | - | let | |
430 | - | let | |
431 | - | let | |
432 | - | if ($isInstanceOf( | |
495 | + | let cS = cO._1 | |
496 | + | let cT = cO._2 | |
497 | + | let cU = { | |
498 | + | let bg = getInteger(this, aX(af, aU)) | |
499 | + | if ($isInstanceOf(bg, "Int")) | |
433 | 500 | then { | |
434 | - | let | |
435 | - | max([0, | |
501 | + | let cV = bg | |
502 | + | max([0, cV]) | |
436 | 503 | } | |
437 | 504 | else { | |
438 | - | let | |
439 | - | if ($isInstanceOf( | |
505 | + | let cQ = getInteger(this, aY(aU)) | |
506 | + | if ($isInstanceOf(cQ, "Int")) | |
440 | 507 | then { | |
441 | - | let | |
442 | - | max([0, | |
508 | + | let cW = cQ | |
509 | + | max([0, cW]) | |
443 | 510 | } | |
444 | 511 | else 0 | |
445 | 512 | } | |
446 | 513 | } | |
447 | - | let | |
448 | - | then $Tuple3(valueOrElse(getString(this, | |
514 | + | let cX = if ((aU == "WAVES")) | |
515 | + | then $Tuple3(valueOrElse(getString(this, aQ()), ""), getString(this, valueOrElse(aR(), "")), c) | |
449 | 516 | else $Tuple3("", "", 0) | |
450 | - | let | |
451 | - | let | |
452 | - | let | |
453 | - | let | |
454 | - | $Tuple2(nil, $Tuple7( | |
517 | + | let cY = cX._1 | |
518 | + | let cZ = cX._2 | |
519 | + | let da = cX._3 | |
520 | + | let db = valueOrElse(getString(this, aS()), "") | |
521 | + | $Tuple2(nil, $Tuple7(cS, cT, cU, cY, cZ, da, db)) | |
455 | 522 | } | |
456 | 523 | ||
457 | 524 | ||
458 | 525 | ||
459 | - | @Callable( | |
460 | - | func getLpAssetFromPoolAssetsREADONLY ( | |
461 | - | then ( | |
526 | + | @Callable(bE) | |
527 | + | func getLpAssetFromPoolAssetsREADONLY (dc,dd) = if (if ((dc == "8LQW8f7P5d5PZM7GtZEBgaqRPGSzS3DfPuiXrURJ4AJS")) | |
528 | + | then (dd == "WAVES") | |
462 | 529 | else false) | |
463 | 530 | then $Tuple2(nil, unit) | |
464 | 531 | else { | |
465 | - | let | |
466 | - | let | |
467 | - | let | |
468 | - | let | |
532 | + | let de = value(getInteger(this, ak(dc))) | |
533 | + | let df = value(getInteger(this, ak(dd))) | |
534 | + | let dg = getString(this, av(toString(de), toString(df))) | |
535 | + | let dh = if ((dg == unit)) | |
469 | 536 | then unit | |
470 | - | else drop(value( | |
471 | - | $Tuple2(nil, | |
537 | + | else drop(value(dg), 4) | |
538 | + | $Tuple2(nil, dh) | |
472 | 539 | } | |
473 | 540 | ||
474 | 541 | ||
475 | 542 | ||
476 | - | @Callable( | |
477 | - | func getPoolAddressFromLpAssetREADONLY ( | |
543 | + | @Callable(bE) | |
544 | + | func getPoolAddressFromLpAssetREADONLY (di) = $Tuple2(nil, valueOrElse(getString(this, aD(di)), "")) | |
478 | 545 | ||
479 | 546 | ||
480 | 547 | ||
481 | - | @Callable( | |
482 | - | func constructor ( | |
483 | - | let | |
484 | - | if (( | |
485 | - | then [StringEntry( | |
548 | + | @Callable(bE) | |
549 | + | func constructor (dj,dk,bK,bL,bM,bN,dl,dm) = { | |
550 | + | let dn = bF(bE) | |
551 | + | if ((dn == dn)) | |
552 | + | then [StringEntry(O(), bT(dj, dk, bK, bL, bM, bN, dl)), IntegerEntry(ab(), dm)] | |
486 | 553 | else throw("Strict value is not equal to itself.") | |
487 | 554 | } | |
488 | 555 | ||
489 | 556 | ||
490 | 557 | ||
491 | - | @Callable( | |
492 | - | func constructorV2 ( | |
493 | - | let | |
494 | - | if (( | |
558 | + | @Callable(bE) | |
559 | + | func constructorV2 (do) = { | |
560 | + | let dn = bF(bE) | |
561 | + | if ((dn == dn)) | |
495 | 562 | then { | |
496 | - | let | |
497 | - | if (( | |
498 | - | then [StringEntry( | |
563 | + | let dp = addressFromPublicKey(fromBase58String(do)) | |
564 | + | if ((dp == dp)) | |
565 | + | then [StringEntry(R(), do)] | |
499 | 566 | else throw("Strict value is not equal to itself.") | |
500 | 567 | } | |
501 | 568 | else throw("Strict value is not equal to itself.") | |
503 | 570 | ||
504 | 571 | ||
505 | 572 | ||
506 | - | @Callable( | |
507 | - | func constructorV3 ( | |
508 | - | let | |
509 | - | if (( | |
573 | + | @Callable(bE) | |
574 | + | func constructorV3 (bP,bQ,bR,bS) = { | |
575 | + | let dn = bF(bE) | |
576 | + | if ((dn == dn)) | |
510 | 577 | then { | |
511 | - | let | |
512 | - | [StringEntry( | |
578 | + | let bu = split(aZ(O()), m) | |
579 | + | [StringEntry(O(), bH(bu[1], bu[2], bu[3], bu[4], bu[5], bu[6], bu[7], bP, bQ, bR, bS))] | |
513 | 580 | } | |
514 | 581 | else throw("Strict value is not equal to itself.") | |
515 | 582 | } | |
516 | 583 | ||
517 | 584 | ||
518 | 585 | ||
519 | - | @Callable( | |
520 | - | func constructorV4 ( | |
521 | - | let | |
522 | - | if (( | |
523 | - | then [StringEntry( | |
586 | + | @Callable(bE) | |
587 | + | func constructorV4 (dq,dr) = { | |
588 | + | let dn = bF(bE) | |
589 | + | if ((dn == dn)) | |
590 | + | then [StringEntry(S(), dq), StringEntry(T(), makeString(dr, m))] | |
524 | 591 | else throw("Strict value is not equal to itself.") | |
525 | 592 | } | |
526 | 593 | ||
527 | 594 | ||
528 | 595 | ||
529 | - | @Callable( | |
530 | - | func constructorV5 ( | |
531 | - | let | |
532 | - | if (( | |
533 | - | then [StringEntry( | |
596 | + | @Callable(bE) | |
597 | + | func constructorV5 (ds) = { | |
598 | + | let dn = bF(bE) | |
599 | + | if ((dn == dn)) | |
600 | + | then [StringEntry(X(), ds)] | |
534 | 601 | else throw("Strict value is not equal to itself.") | |
535 | 602 | } | |
536 | 603 | ||
537 | 604 | ||
538 | 605 | ||
539 | - | @Callable( | |
540 | - | func constructorV6 ( | |
541 | - | let | |
606 | + | @Callable(bE) | |
607 | + | func constructorV6 (dt,du) = { | |
608 | + | let dv = [bF(bE), if ((addressFromString(dt) != unit)) | |
542 | 609 | then true | |
543 | 610 | else "invalid voting emission contract address"] | |
544 | - | if (( | |
545 | - | then [StringEntry( | |
611 | + | if ((dv == dv)) | |
612 | + | then [StringEntry(Y(), dt), StringEntry(aa(), makeString(du, m))] | |
546 | 613 | else throw("Strict value is not equal to itself.") | |
547 | 614 | } | |
548 | 615 | ||
549 | 616 | ||
550 | 617 | ||
551 | - | @Callable( | |
552 | - | func setAdmins ( | |
553 | - | let | |
554 | - | if (( | |
555 | - | then [StringEntry( | |
618 | + | @Callable(bE) | |
619 | + | func setAdmins (dw) = { | |
620 | + | let dn = bF(bE) | |
621 | + | if ((dn == dn)) | |
622 | + | then [StringEntry(W(), makeString(dw, m))] | |
556 | 623 | else throw("Strict value is not equal to itself.") | |
557 | 624 | } | |
558 | 625 | ||
559 | 626 | ||
560 | 627 | ||
561 | - | @Callable( | |
562 | - | func activateNewPool ( | |
563 | - | let | |
564 | - | if (( | |
565 | - | then if (isDefined(getString( | |
566 | - | then | |
628 | + | @Callable(bE) | |
629 | + | func activateNewPool (af,bX,bY,dx,dy,dz,ce,dA) = { | |
630 | + | let dn = cr(bE) | |
631 | + | if ((dn == dn)) | |
632 | + | then if (isDefined(getString(az(af)))) | |
633 | + | then K((("Pool address " + af) + " already registered.")) | |
567 | 634 | else { | |
568 | - | let | |
569 | - | let | |
570 | - | let | |
635 | + | let dB = ck(bX, 1) | |
636 | + | let dC = dB._1 | |
637 | + | let dD = ck(bY, if (dB._3) | |
571 | 638 | then 2 | |
572 | 639 | else 1) | |
573 | - | let | |
574 | - | let | |
575 | - | let | |
576 | - | let | |
577 | - | if ( | |
578 | - | then | |
640 | + | let dE = dD._1 | |
641 | + | let dF = valueOrErrorMessage(scriptHash(addressFromStringValue(af)), ("No script has been found on pool account " + af)) | |
642 | + | let dG = getBinaryValue(Q()) | |
643 | + | let dH = cx(bX, bY) | |
644 | + | if (dH) | |
645 | + | then K((((("Pool " + bX) + "/") + bY) + " has already been activated.")) | |
579 | 646 | else { | |
580 | - | let | |
581 | - | let | |
582 | - | then | |
583 | - | else pow(10, 0, value(assetInfo(fromBase58String( | |
584 | - | let | |
585 | - | then | |
586 | - | else pow(10, 0, value(assetInfo(fromBase58String( | |
587 | - | let | |
588 | - | let | |
589 | - | let | |
590 | - | let | |
591 | - | if (( | |
592 | - | then if (( | |
593 | - | then | |
647 | + | let dI = value(getString(this, am(toString(dC), toString(dE)))) | |
648 | + | let dJ = if ((bX == "WAVES")) | |
649 | + | then l | |
650 | + | else pow(10, 0, value(assetInfo(fromBase58String(bX))).decimals, 0, 0, DOWN) | |
651 | + | let dK = if ((bY == "WAVES")) | |
652 | + | then l | |
653 | + | else pow(10, 0, value(assetInfo(fromBase58String(bY))).decimals, 0, 0, DOWN) | |
654 | + | let dL = Issue(dx, dy, 1, 8, true) | |
655 | + | let bW = calculateAssetId(dL) | |
656 | + | let dM = toBase58String(bW) | |
657 | + | let dN = invoke(addressFromStringValue(af), "activate", [bX, bY], nil) | |
658 | + | if ((dN == dN)) | |
659 | + | then if ((dN != "success")) | |
660 | + | then K("Pool initialisation error happened.") | |
594 | 661 | else { | |
595 | - | let | |
596 | - | let | |
597 | - | if (( | |
662 | + | let ds = addressFromStringValue(aZ(X())) | |
663 | + | let dO = invoke(ds, "createOrUpdate", [dM, dx, false], nil) | |
664 | + | if ((dO == dO)) | |
598 | 665 | then { | |
599 | - | let | |
600 | - | if (( | |
666 | + | let dP = invoke(ds, "addLabel", [dM, h], nil) | |
667 | + | if ((dP == dP)) | |
601 | 668 | then { | |
602 | - | let | |
603 | - | if (( | |
669 | + | let dQ = invoke(ds, "setLogo", [dM, dA], nil) | |
670 | + | if ((dQ == dQ)) | |
604 | 671 | then { | |
605 | - | let | |
606 | - | if (( | |
672 | + | let dR = invoke(ds, "addAssetsLink", [bX, bY, dM], nil) | |
673 | + | if ((dR == dR)) | |
607 | 674 | then { | |
608 | - | let | |
609 | - | if (( | |
610 | - | then $Tuple2((( | |
675 | + | let dS = invoke(ds, "increaseAssetPoolsNumber", [bX], nil) | |
676 | + | if ((dS == dS)) | |
677 | + | then $Tuple2(((dB._2 ++ dD._2) ++ [dL, Burn(bW, 1), StringEntry(am(toString(dC), toString(dE)), bU(af, toString(o), dM, bX, bY, dJ, dK, dC, dE, l, ce)), StringEntry(at(dM), cf(dC, dE)), StringEntry(av(toString(dC), toString(dE)), ("%s__" + dM)), StringEntry(az(af), cf(dC, dE)), StringEntry(aB(dC, dE), af), StringEntry(aD(dM), af), StringEntry(aC(af), dM), IntegerEntry(ae(af), dz), IntegerEntry(ay(af), i)]), dM) | |
611 | 678 | else throw("Strict value is not equal to itself.") | |
612 | 679 | } | |
613 | 680 | else throw("Strict value is not equal to itself.") | |
626 | 693 | ||
627 | 694 | ||
628 | 695 | ||
629 | - | @Callable( | |
630 | - | func managePool ( | |
631 | - | let | |
632 | - | if (( | |
696 | + | @Callable(bE) | |
697 | + | func managePool (af,dT) = { | |
698 | + | let dn = bF(bE) | |
699 | + | if ((dn == dn)) | |
633 | 700 | then { | |
634 | - | let | |
635 | - | let | |
636 | - | let | |
637 | - | let | |
638 | - | let | |
639 | - | let | |
640 | - | let | |
641 | - | let | |
642 | - | let | |
643 | - | let | |
644 | - | let | |
645 | - | [StringEntry( | |
701 | + | let dU = ci(af) | |
702 | + | let bV = dU[w] | |
703 | + | let dM = dU[x] | |
704 | + | let bX = dU[y] | |
705 | + | let bY = dU[z] | |
706 | + | let dJ = parseIntValue(dU[A]) | |
707 | + | let dK = parseIntValue(dU[B]) | |
708 | + | let dC = parseIntValue(dU[C]) | |
709 | + | let dE = parseIntValue(dU[D]) | |
710 | + | let dV = parseIntValue(dU[E]) | |
711 | + | let ce = dU[F] | |
712 | + | [StringEntry(am(toString(dC), toString(dE)), bU(af, toString(dT), dM, bX, bY, dJ, dK, dC, dE, dV, ce))] | |
646 | 713 | } | |
647 | 714 | else throw("Strict value is not equal to itself.") | |
648 | 715 | } | |
649 | 716 | ||
650 | 717 | ||
651 | 718 | ||
652 | - | @Callable( | |
653 | - | func emit ( | |
654 | - | let | |
655 | - | let | |
656 | - | let | |
657 | - | let | |
658 | - | let | |
659 | - | let | |
660 | - | if ((0 >= | |
719 | + | @Callable(bE) | |
720 | + | func emit (dW) = { | |
721 | + | let dX = bE.caller | |
722 | + | let dY = bE.originCaller | |
723 | + | let dZ = valueOrErrorMessage(getString(aC(toString(dX))), "Invalid LP address called me.") | |
724 | + | let ea = fromBase58String(dZ) | |
725 | + | let dr = split(valueOrElse(getString(T()), n), m) | |
726 | + | let dq = addressFromStringValue(valueOrErrorMessage(getString(S()), "Legacy factory contract does not exists.")) | |
727 | + | if ((0 >= dW)) | |
661 | 728 | then nil | |
662 | - | else if (containsElement( | |
663 | - | then $Tuple2(nil, | |
664 | - | else $Tuple2([Reissue( | |
729 | + | else if (containsElement(dr, toString(dX))) | |
730 | + | then $Tuple2(nil, dq) | |
731 | + | else $Tuple2([Reissue(ea, dW, true), ScriptTransfer(bE.caller, dW, ea)], "success") | |
665 | 732 | } | |
666 | 733 | ||
667 | 734 | ||
668 | 735 | ||
669 | - | @Callable( | |
670 | - | func burn ( | |
671 | - | let | |
672 | - | let | |
673 | - | let | |
674 | - | let | |
675 | - | let | |
676 | - | let | |
677 | - | if (( | |
678 | - | then | |
679 | - | else if (( | |
680 | - | then | |
736 | + | @Callable(bE) | |
737 | + | func burn (eb) = { | |
738 | + | let dX = bE.caller | |
739 | + | let dY = bE.originCaller | |
740 | + | let ec = value(bE.payments[0]) | |
741 | + | let ed = value(ec.amount) | |
742 | + | let ee = toBase58String(value(ec.assetId)) | |
743 | + | let ef = valueOrErrorMessage(getString(aC(toString(dX))), "Invalid LP address called me.") | |
744 | + | if ((ee != ef)) | |
745 | + | then K("Invalid asset passed.") | |
746 | + | else if ((eb != ed)) | |
747 | + | then K("Invalid amount passed.") | |
681 | 748 | else { | |
682 | - | let | |
683 | - | $Tuple2([Burn( | |
749 | + | let ea = fromBase58String(ef) | |
750 | + | $Tuple2([Burn(ea, eb)], "success") | |
684 | 751 | } | |
685 | 752 | } | |
686 | 753 | ||
687 | 754 | ||
688 | 755 | ||
689 | - | @Callable( | |
690 | - | func modifyWeight ( | |
691 | - | let | |
756 | + | @Callable(bE) | |
757 | + | func modifyWeight (bW,eg) = { | |
758 | + | let dn = if ((toBase58String(bE.caller.bytes) == valueOrElse(getString(this, Y()), ""))) | |
692 | 759 | then true | |
693 | - | else | |
694 | - | if (( | |
760 | + | else bF(bE) | |
761 | + | if ((dn == dn)) | |
695 | 762 | then { | |
696 | - | let | |
697 | - | let | |
698 | - | let | |
699 | - | let | |
700 | - | let | |
701 | - | let | |
702 | - | let | |
703 | - | let | |
704 | - | let | |
705 | - | if (( | |
763 | + | let aA = aZ(aD(bW)) | |
764 | + | let eh = ae(aA) | |
765 | + | let ei = ae(g) | |
766 | + | let ej = valueOrElse(getInteger(ei), 0) | |
767 | + | let dz = valueOrElse(getInteger(eh), 0) | |
768 | + | let ek = eg | |
769 | + | let bu = split(aZ(O()), m) | |
770 | + | let dj = bw(bu) | |
771 | + | let el = invoke(dj, "onModifyWeight", [bW, aA], nil) | |
772 | + | if ((el == el)) | |
706 | 773 | then { | |
707 | - | let | |
774 | + | let em = if ((ej == 0)) | |
708 | 775 | then nil | |
709 | - | else [IntegerEntry( | |
710 | - | let | |
711 | - | let | |
712 | - | let | |
776 | + | else [IntegerEntry(ei, 0)] | |
777 | + | let en = ag(aA, 0) | |
778 | + | let eo = getInteger(en) | |
779 | + | let ep = if ((eo == unit)) | |
713 | 780 | then nil | |
714 | - | else [DeleteEntry( | |
715 | - | (([IntegerEntry( | |
781 | + | else [DeleteEntry(en)] | |
782 | + | (([IntegerEntry(eh, ek)] ++ em) ++ ep) | |
716 | 783 | } | |
717 | 784 | else throw("Strict value is not equal to itself.") | |
718 | 785 | } | |
721 | 788 | ||
722 | 789 | ||
723 | 790 | ||
724 | - | @Callable( | |
725 | - | func modifyWeights ( | |
726 | - | let | |
727 | - | if (( | |
791 | + | @Callable(bE) | |
792 | + | func modifyWeights (eq,er,es,et) = { | |
793 | + | let dn = bF(bE) | |
794 | + | if ((dn == dn)) | |
728 | 795 | then { | |
729 | - | let | |
730 | - | let | |
731 | - | let | |
732 | - | let | |
733 | - | let | |
734 | - | let | |
735 | - | let | |
736 | - | let | |
737 | - | let | |
738 | - | let | |
739 | - | let | |
740 | - | let | |
741 | - | let | |
742 | - | let | |
743 | - | if ((0 >= | |
744 | - | then | |
745 | - | else if ((0 >= | |
746 | - | then | |
796 | + | let eu = ((5 * f) / 100) | |
797 | + | let ev = ((5 * f) / 100) | |
798 | + | let ew = ((5 * f) / 100) | |
799 | + | let bu = split(aZ(O()), m) | |
800 | + | let ex = bw(bu) | |
801 | + | let ey = bx(bu) | |
802 | + | let ez = ae(eq) | |
803 | + | let eA = ae(er) | |
804 | + | let eB = ae(es) | |
805 | + | let eC = ae(et) | |
806 | + | let eD = bc(ez) | |
807 | + | let eE = bc(eA) | |
808 | + | let eF = (eD - ew) | |
809 | + | let eG = (eE - ew) | |
810 | + | if ((0 >= eF)) | |
811 | + | then K(("invalid btcWeightNew: " + toString(eF))) | |
812 | + | else if ((0 >= eG)) | |
813 | + | then K(("invalid ethWeightNew: " + toString(eG))) | |
747 | 814 | else { | |
748 | - | let | |
749 | - | let | |
750 | - | let | |
751 | - | let | |
752 | - | let | |
753 | - | if (( | |
815 | + | let eH = aZ(aC(eq)) | |
816 | + | let eI = aZ(aC(er)) | |
817 | + | let eJ = aZ(aC(es)) | |
818 | + | let eK = aZ(aC(et)) | |
819 | + | let eL = invoke(ex, "onModifyWeight", [eH, eq], nil) | |
820 | + | if ((eL == eL)) | |
754 | 821 | then { | |
755 | - | let | |
756 | - | if (( | |
822 | + | let eM = invoke(ex, "onModifyWeight", [eI, er], nil) | |
823 | + | if ((eM == eM)) | |
757 | 824 | then { | |
758 | - | let | |
759 | - | if (( | |
825 | + | let eN = invoke(ex, "onModifyWeight", [eJ, es], nil) | |
826 | + | if ((eN == eN)) | |
760 | 827 | then { | |
761 | - | let | |
762 | - | if (( | |
763 | - | then [IntegerEntry( | |
828 | + | let eO = invoke(ex, "onModifyWeight", [eK, et], nil) | |
829 | + | if ((eO == eO)) | |
830 | + | then [IntegerEntry(ez, eF), IntegerEntry(eA, eG), IntegerEntry(eB, eu), IntegerEntry(eC, ev), IntegerEntry(ag(eq, 0), eD), IntegerEntry(ag(er, 0), eE), IntegerEntry(ag(es, 0), eu), IntegerEntry(ag(et, 0), ev)] | |
764 | 831 | else throw("Strict value is not equal to itself.") | |
765 | 832 | } | |
766 | 833 | else throw("Strict value is not equal to itself.") | |
775 | 842 | ||
776 | 843 | ||
777 | 844 | ||
778 | - | @Callable( | |
779 | - | func checkWxEmissionPoolLabel ( | |
780 | - | let | |
781 | - | let | |
782 | - | if ($isInstanceOf( | |
845 | + | @Callable(bE) | |
846 | + | func checkWxEmissionPoolLabel (aF,aG) = { | |
847 | + | let eP = { | |
848 | + | let bg = getBoolean(aE(aF, aG)) | |
849 | + | if ($isInstanceOf(bg, "Boolean")) | |
783 | 850 | then { | |
784 | - | let | |
785 | - | | |
851 | + | let cV = bg | |
852 | + | cV | |
786 | 853 | } | |
787 | 854 | else false | |
788 | 855 | } | |
789 | - | $Tuple2(nil, | |
856 | + | $Tuple2(nil, eP) | |
790 | 857 | } | |
791 | 858 | ||
792 | 859 | ||
793 | 860 | ||
794 | - | @Callable( | |
795 | - | func setWxEmissionPoolLabel ( | |
796 | - | let | |
797 | - | if (( | |
798 | - | then $Tuple2([BooleanEntry( | |
861 | + | @Callable(bE) | |
862 | + | func setWxEmissionPoolLabel (aF,aG) = { | |
863 | + | let dn = cr(bE) | |
864 | + | if ((dn == dn)) | |
865 | + | then $Tuple2([BooleanEntry(aE(aF, aG), true)], unit) | |
799 | 866 | else throw("Strict value is not equal to itself.") | |
800 | 867 | } | |
801 | 868 | ||
802 | 869 | ||
803 | 870 | ||
804 | - | @Callable( | |
805 | - | func deleteWxEmissionPoolLabel ( | |
806 | - | let | |
871 | + | @Callable(bE) | |
872 | + | func deleteWxEmissionPoolLabel (aF,aG) = { | |
873 | + | let dn = if ((bE.caller == this)) | |
807 | 874 | then true | |
808 | - | else | |
809 | - | if (( | |
810 | - | then $Tuple2([DeleteEntry( | |
875 | + | else cr(bE) | |
876 | + | if ((dn == dn)) | |
877 | + | then $Tuple2([DeleteEntry(aE(aF, aG))], unit) | |
811 | 878 | else throw("Strict value is not equal to itself.") | |
812 | 879 | } | |
813 | 880 | ||
814 | 881 | ||
815 | 882 | ||
816 | - | @Callable( | |
817 | - | func onVerificationLoss ( | |
818 | - | let | |
883 | + | @Callable(bE) | |
884 | + | func onVerificationLoss (aU) = { | |
885 | + | let dn = if ((toBase58String(bE.caller.bytes) == valueOrElse(getString(this, X()), ""))) | |
819 | 886 | then true | |
820 | - | else | |
821 | - | if (( | |
887 | + | else bF(bE) | |
888 | + | if ((dn == dn)) | |
822 | 889 | then { | |
823 | - | let | |
824 | - | let | |
890 | + | let du = by() | |
891 | + | let eQ = if ((size(du) > 0)) | |
825 | 892 | then true | |
826 | - | else | |
827 | - | if (( | |
893 | + | else K("invalid price assets") | |
894 | + | if ((eQ == eQ)) | |
828 | 895 | then { | |
829 | - | func | |
830 | - | let | |
831 | - | if (( | |
896 | + | func eR (eS,eT) = { | |
897 | + | let cP = invoke(this, "deleteWxEmissionPoolLabel", [aU, eT], nil) | |
898 | + | if ((cP == cP)) | |
832 | 899 | then unit | |
833 | 900 | else throw("Strict value is not equal to itself.") | |
834 | 901 | } | |
835 | 902 | ||
836 | - | let | |
837 | - | let | |
838 | - | let | |
839 | - | let | |
840 | - | func | |
841 | - | then | |
842 | - | else | |
903 | + | let eU = { | |
904 | + | let eV = du | |
905 | + | let eW = size(eV) | |
906 | + | let eX = unit | |
907 | + | func eY (eZ,fa) = if ((fa >= eW)) | |
908 | + | then eZ | |
909 | + | else eR(eZ, eV[fa]) | |
843 | 910 | ||
844 | - | func | |
845 | - | then | |
911 | + | func fb (eZ,fa) = if ((fa >= eW)) | |
912 | + | then eZ | |
846 | 913 | else throw("List size exceeds 13") | |
847 | 914 | ||
848 | - | | |
915 | + | fb(eY(eY(eY(eY(eY(eY(eY(eY(eY(eY(eY(eY(eY(eX, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13) | |
849 | 916 | } | |
850 | - | if (( | |
917 | + | if ((eU == eU)) | |
851 | 918 | then $Tuple2(nil, unit) | |
852 | 919 | else throw("Strict value is not equal to itself.") | |
853 | 920 | } | |
858 | 925 | ||
859 | 926 | ||
860 | 927 | ||
861 | - | @Callable( | |
862 | - | func isPoolOneTokenOperationsDisabledREADONLY ( | |
863 | - | let | |
864 | - | let | |
865 | - | let | |
866 | - | let | |
867 | - | $Tuple2(nil, if ( | |
928 | + | @Callable(bE) | |
929 | + | func isPoolOneTokenOperationsDisabledREADONLY (af) = { | |
930 | + | let dU = ci(af) | |
931 | + | let aq = $Tuple2(parseIntValue(dU[C]), parseIntValue(dU[D])) | |
932 | + | let fc = valueOrElse(getBoolean(ap(aq)), false) | |
933 | + | let fd = valueOrElse(getBoolean(as()), false) | |
934 | + | $Tuple2(nil, if (fd) | |
868 | 935 | then true | |
869 | - | else | |
936 | + | else fc) | |
870 | 937 | } | |
871 | 938 | ||
872 | 939 | ||
873 | 940 | ||
874 | - | @Callable( | |
875 | - | func getInFeeREADONLY ( | |
876 | - | let | |
877 | - | $Tuple2(nil, | |
941 | + | @Callable(bE) | |
942 | + | func getInFeeREADONLY (af) = { | |
943 | + | let fe = cu(aH(af), aI(), 0) | |
944 | + | $Tuple2(nil, fe) | |
878 | 945 | } | |
879 | 946 | ||
880 | 947 | ||
881 | 948 | ||
882 | - | @Callable( | |
883 | - | func getOutFeeREADONLY ( | |
884 | - | let | |
885 | - | $Tuple2(nil, | |
949 | + | @Callable(bE) | |
950 | + | func getOutFeeREADONLY (af) = { | |
951 | + | let fe = cu(aK(af), aL(), fraction(10, b, 10000)) | |
952 | + | $Tuple2(nil, fe) | |
886 | 953 | } | |
887 | 954 | ||
888 | 955 | ||
889 | 956 | ||
890 | - | @Callable( | |
891 | - | func getSwapFeeREADONLY ( | |
892 | - | let | |
893 | - | let | |
894 | - | if ($isInstanceOf( | |
957 | + | @Callable(bE) | |
958 | + | func getSwapFeeREADONLY (ff) = { | |
959 | + | let fg = { | |
960 | + | let bg = getString(this, aJ(ff)) | |
961 | + | if ($isInstanceOf(bg, "String")) | |
895 | 962 | then { | |
896 | - | let | |
897 | - | let | |
898 | - | let | |
899 | - | let | |
900 | - | $Tuple2( | |
963 | + | let bh = bg | |
964 | + | let fh = split(bh, m) | |
965 | + | let fi = parseIntValue(fh[1]) | |
966 | + | let fj = parseIntValue(fh[2]) | |
967 | + | $Tuple2(fi, fj) | |
901 | 968 | } | |
902 | - | else if ($isInstanceOf( | |
969 | + | else if ($isInstanceOf(bg, "Unit")) | |
903 | 970 | then unit | |
904 | 971 | else throw("Match error") | |
905 | 972 | } | |
906 | - | $Tuple2(nil, | |
973 | + | $Tuple2(nil, fg) | |
907 | 974 | } | |
908 | 975 | ||
909 | 976 | ||
910 | 977 | ||
911 | - | @Callable( | |
912 | - | func poolInfoREADONLY ( | |
913 | - | let | |
914 | - | let | |
915 | - | let | |
916 | - | let | |
917 | - | let | |
918 | - | then isDefined( | |
978 | + | @Callable(bE) | |
979 | + | func poolInfoREADONLY (fk,fl) = { | |
980 | + | let fm = getInteger(this, ak(fk)) | |
981 | + | let fn = getInteger(this, ak(fl)) | |
982 | + | let fo = getString(this, aB(value(fm), value(fn))) | |
983 | + | let fp = getString(this, aC(value(fo))) | |
984 | + | let dH = if (if (isDefined(fm)) | |
985 | + | then isDefined(fn) | |
919 | 986 | else false) | |
920 | - | then isDefined( | |
987 | + | then isDefined(fo) | |
921 | 988 | else false | |
922 | - | let | |
923 | - | then $Tuple2(addressFromStringValue(value( | |
989 | + | let fq = if (dH) | |
990 | + | then $Tuple2(addressFromStringValue(value(fo)), bd(value(fp))) | |
924 | 991 | else unit | |
925 | - | $Tuple2(nil, | |
992 | + | $Tuple2(nil, fq) | |
926 | 993 | } | |
927 | 994 | ||
928 | 995 | ||
929 | 996 | ||
930 | - | @Callable( | |
931 | - | func getPoolStatusREADONLY ( | |
932 | - | let | |
933 | - | let | |
934 | - | let | |
935 | - | let | |
936 | - | $Tuple2(nil, parseIntValue( | |
997 | + | @Callable(bE) | |
998 | + | func getPoolStatusREADONLY (af) = { | |
999 | + | let cj = split(aZ(az(af)), m) | |
1000 | + | let an = cj[1] | |
1001 | + | let ao = cj[2] | |
1002 | + | let cA = split(aZ(am(an, ao)), m) | |
1003 | + | $Tuple2(nil, parseIntValue(cA[w])) | |
937 | 1004 | } | |
938 | 1005 | ||
939 | 1006 | ||
940 | 1007 | ||
941 | - | @Callable( | |
942 | - | func getPoolConfigREADONLY ( | |
943 | - | let | |
944 | - | let | |
945 | - | let | |
946 | - | let | |
947 | - | $Tuple2(nil, | |
1008 | + | @Callable(bE) | |
1009 | + | func getPoolConfigREADONLY (af) = { | |
1010 | + | let cj = split(aZ(az(af)), m) | |
1011 | + | let an = cj[1] | |
1012 | + | let ao = cj[2] | |
1013 | + | let cA = split(aZ(am(an, ao)), m) | |
1014 | + | $Tuple2(nil, cA) | |
948 | 1015 | } | |
949 | 1016 | ||
950 | 1017 | ||
951 | 1018 | ||
952 | - | @Callable( | |
953 | - | func getPoolConfigByLpAssetIdREADONLY ( | |
954 | - | let | |
955 | - | let | |
956 | - | let | |
957 | - | let | |
958 | - | $Tuple2(nil, | |
1019 | + | @Callable(bE) | |
1020 | + | func getPoolConfigByLpAssetIdREADONLY (dM) = { | |
1021 | + | let cj = split(aZ(at(dM)), m) | |
1022 | + | let an = cj[1] | |
1023 | + | let ao = cj[2] | |
1024 | + | let cA = split(aZ(am(an, ao)), m) | |
1025 | + | $Tuple2(nil, cA) | |
959 | 1026 | } | |
960 | 1027 | ||
961 | 1028 | ||
962 | 1029 | ||
963 | - | @Callable( | |
964 | - | func poolExistsREADONLY ( | |
1030 | + | @Callable(bE) | |
1031 | + | func poolExistsREADONLY (aF,aG) = $Tuple2(nil, cx(aF, aG)) | |
965 | 1032 | ||
966 | 1033 | ||
967 | 1034 | ||
968 | - | @Callable( | |
969 | - | func skipOrderValidationREADONLY ( | |
1035 | + | @Callable(bE) | |
1036 | + | func skipOrderValidationREADONLY (af) = $Tuple2(nil, valueOrElse(getBoolean(aM(af)), false)) | |
970 | 1037 | ||
971 | 1038 | ||
972 | 1039 | ||
973 | - | @Callable( | |
974 | - | func getChangeAmpConfigREADONLY ( | |
975 | - | let | |
976 | - | let | |
977 | - | let | |
978 | - | $Tuple2(nil, [ | |
1040 | + | @Callable(bE) | |
1041 | + | func getChangeAmpConfigREADONLY (af) = { | |
1042 | + | let fr = getIntegerValue(aN(af)) | |
1043 | + | let fs = getIntegerValue(aO(af)) | |
1044 | + | let ft = getIntegerValue(aP(af)) | |
1045 | + | $Tuple2(nil, [fr, fs, ft]) | |
979 | 1046 | } | |
980 | 1047 | ||
981 | 1048 | ||
982 | 1049 | ||
983 | - | @Callable( | |
984 | - | func getPoolWeightREADONLY ( | |
985 | - | let | |
986 | - | let | |
987 | - | $Tuple2(nil, | |
1050 | + | @Callable(bE) | |
1051 | + | func getPoolWeightREADONLY (bW) = { | |
1052 | + | let af = aZ(aD(bW)) | |
1053 | + | let fu = valueOrElse(getInteger(ae(af)), 0) | |
1054 | + | $Tuple2(nil, fu) | |
988 | 1055 | } | |
989 | 1056 | ||
990 | 1057 | ||
991 | - | @Verifier(ff) | |
992 | - | func fg () = { | |
993 | - | let fh = { | |
994 | - | let bb = bu() | |
995 | - | if ($isInstanceOf(bb, "ByteVector")) | |
1058 | + | ||
1059 | + | @Callable(bE) | |
1060 | + | func deletePool (aA) = { | |
1061 | + | let dU = ci(aA) | |
1062 | + | let dn = if ((toString(bE.caller) == cE(aA))) | |
1063 | + | then if (cM(aA)) | |
1064 | + | then true | |
1065 | + | else K("Pool is not empty") | |
1066 | + | else bF(bE) | |
1067 | + | if ((dn == dn)) | |
1068 | + | then { | |
1069 | + | let fv = if ((valueOrElse(getInteger(ae(aA)), 0) == 0)) | |
1070 | + | then true | |
1071 | + | else K("Pool weight is not Zero") | |
1072 | + | if ((fv == fv)) | |
1073 | + | then { | |
1074 | + | let fw = if ((dU[w] == toString(r))) | |
1075 | + | then true | |
1076 | + | else K("Pool must be SHUTDOWN (4)") | |
1077 | + | if ((fw == fw)) | |
1078 | + | then { | |
1079 | + | let fx = cD(aA) | |
1080 | + | let aF = fx._1 | |
1081 | + | let aG = fx._2 | |
1082 | + | let bW = fx._3 | |
1083 | + | let an = fx._4 | |
1084 | + | let ao = fx._5 | |
1085 | + | let cG = addressFromStringValue(getStringValue(Z())) | |
1086 | + | let fy = invoke(cG, "deletePool", [aF, aG], nil) | |
1087 | + | if ((fy == fy)) | |
1088 | + | then { | |
1089 | + | let dt = addressFromStringValue(getStringValue(Y())) | |
1090 | + | let fz = invoke(dt, "deletePool", [aF, aG], nil) | |
1091 | + | if ((fz == fz)) | |
1092 | + | then { | |
1093 | + | let ds = addressFromStringValue(getStringValue(X())) | |
1094 | + | let fA = invoke(ds, "deletePool", [aF, aG], nil) | |
1095 | + | if ((fA == fA)) | |
1096 | + | then [DeleteEntry(aC(aA)), DeleteEntry(az(aA)), DeleteEntry(av(toString(an), toString(ao))), DeleteEntry(aB(an, ao)), DeleteEntry(am(toString(an), toString(ao))), DeleteEntry(at(bW)), DeleteEntry(aD(bW)), DeleteEntry(aE(aF, aG)), DeleteEntry(ae(aA)), DeleteEntry(ay(aA)), DeleteEntry(aH(aA)), DeleteEntry(aK(aA)), DeleteEntry(aM(aA)), DeleteEntry(aN(aA)), DeleteEntry(aO(aA)), DeleteEntry(aP(aA))] | |
1097 | + | else throw("Strict value is not equal to itself.") | |
1098 | + | } | |
1099 | + | else throw("Strict value is not equal to itself.") | |
1100 | + | } | |
1101 | + | else throw("Strict value is not equal to itself.") | |
1102 | + | } | |
1103 | + | else throw("Strict value is not equal to itself.") | |
1104 | + | } | |
1105 | + | else throw("Strict value is not equal to itself.") | |
1106 | + | } | |
1107 | + | else throw("Strict value is not equal to itself.") | |
1108 | + | } | |
1109 | + | ||
1110 | + | ||
1111 | + | @Verifier(fB) | |
1112 | + | func fC () = { | |
1113 | + | let fD = { | |
1114 | + | let bg = bz() | |
1115 | + | if ($isInstanceOf(bg, "ByteVector")) | |
996 | 1116 | then { | |
997 | - | let | |
998 | - | | |
1117 | + | let bG = bg | |
1118 | + | bG | |
999 | 1119 | } | |
1000 | - | else if ($isInstanceOf( | |
1001 | - | then | |
1120 | + | else if ($isInstanceOf(bg, "Unit")) | |
1121 | + | then fB.senderPublicKey | |
1002 | 1122 | else throw("Match error") | |
1003 | 1123 | } | |
1004 | - | sigVerify( | |
1124 | + | sigVerify(fB.bodyBytes, fB.proofs[0], fD) | |
1005 | 1125 | } | |
1006 | 1126 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let a = 8 | |
5 | 5 | ||
6 | 6 | let b = 100000000 | |
7 | 7 | ||
8 | 8 | let c = 1000000000000 | |
9 | 9 | ||
10 | 10 | let d = 18 | |
11 | 11 | ||
12 | 12 | let e = toBigInt(1000000000000000000) | |
13 | 13 | ||
14 | 14 | let f = b | |
15 | 15 | ||
16 | 16 | let g = "GWXvirtualPOOL" | |
17 | 17 | ||
18 | 18 | let h = "POOLS_LP" | |
19 | 19 | ||
20 | 20 | let i = 2000000 | |
21 | 21 | ||
22 | 22 | let j = "WAVES" | |
23 | 23 | ||
24 | - | let k = | |
24 | + | let k = "factory_v2.ride" | |
25 | 25 | ||
26 | - | let l = | |
26 | + | let l = ((100 * 1000) * 1000) | |
27 | 27 | ||
28 | - | let m = "" | |
28 | + | let m = "__" | |
29 | 29 | ||
30 | - | let n = | |
30 | + | let n = "" | |
31 | 31 | ||
32 | - | let o = | |
32 | + | let o = 1 | |
33 | 33 | ||
34 | - | let p = | |
34 | + | let p = 2 | |
35 | 35 | ||
36 | - | let q = | |
36 | + | let q = 3 | |
37 | 37 | ||
38 | - | let r = | |
38 | + | let r = 4 | |
39 | 39 | ||
40 | - | let s = | |
40 | + | let s = 1 | |
41 | 41 | ||
42 | - | let t = | |
42 | + | let t = 2 | |
43 | 43 | ||
44 | - | let u = | |
44 | + | let u = 3 | |
45 | 45 | ||
46 | - | let v = | |
46 | + | let v = 1 | |
47 | 47 | ||
48 | - | let w = | |
48 | + | let w = 2 | |
49 | 49 | ||
50 | - | let x = | |
50 | + | let x = 3 | |
51 | 51 | ||
52 | - | let y = | |
52 | + | let y = 4 | |
53 | 53 | ||
54 | - | let z = | |
54 | + | let z = 5 | |
55 | 55 | ||
56 | - | let A = | |
56 | + | let A = 6 | |
57 | 57 | ||
58 | - | let B = | |
58 | + | let B = 7 | |
59 | 59 | ||
60 | - | let C = | |
60 | + | let C = 8 | |
61 | 61 | ||
62 | - | let D = | |
62 | + | let D = 9 | |
63 | 63 | ||
64 | - | let E = | |
64 | + | let E = 10 | |
65 | 65 | ||
66 | - | let F = | |
66 | + | let F = 11 | |
67 | 67 | ||
68 | - | let G = | |
68 | + | let G = "WX_EMISSION" | |
69 | 69 | ||
70 | - | func H () = "%s__allowedLpScriptHash" | |
70 | + | let H = [G] | |
71 | + | ||
72 | + | func I (J) = makeString([k, ": ", J], "") | |
71 | 73 | ||
72 | 74 | ||
73 | - | func | |
75 | + | func K (J) = throw(I(J)) | |
74 | 76 | ||
75 | 77 | ||
76 | - | func | |
78 | + | func L () = "%s__allowedLpScriptHash" | |
77 | 79 | ||
78 | 80 | ||
79 | - | func | |
81 | + | func M () = "%s__allowedLpStableScriptHash" | |
80 | 82 | ||
81 | 83 | ||
82 | - | func | |
84 | + | func N () = "%s__swapContract" | |
83 | 85 | ||
84 | 86 | ||
85 | - | func | |
87 | + | func O () = "%s__factoryConfig" | |
86 | 88 | ||
87 | 89 | ||
88 | - | func | |
90 | + | func P () = "%s__lpTokensList" | |
89 | 91 | ||
90 | 92 | ||
91 | - | func | |
93 | + | func Q () = "%s%s__pool__scriptHash" | |
92 | 94 | ||
93 | 95 | ||
94 | - | func | |
96 | + | func R () = "%s%s__matcher__publicKey" | |
95 | 97 | ||
96 | 98 | ||
97 | - | func | |
99 | + | func S () = "%s__legacyFactoryContract" | |
98 | 100 | ||
99 | 101 | ||
100 | - | func | |
102 | + | func T () = "%s__legacyPools" | |
101 | 103 | ||
102 | 104 | ||
103 | - | func | |
105 | + | func U () = "%s__managerPublicKey" | |
104 | 106 | ||
105 | 107 | ||
106 | - | func | |
108 | + | func V () = "%s__managerVaultAddress" | |
107 | 109 | ||
108 | 110 | ||
109 | - | func | |
111 | + | func W () = "%s__adminPubKeys" | |
110 | 112 | ||
111 | 113 | ||
112 | - | func | |
114 | + | func X () = "%s__assetsStoreContract" | |
113 | 115 | ||
114 | 116 | ||
115 | - | func | |
117 | + | func Y () = "%s__votingEmissionContract" | |
116 | 118 | ||
117 | 119 | ||
118 | - | func | |
120 | + | func Z () = "%s__userPoolsContract" | |
119 | 121 | ||
120 | 122 | ||
121 | - | func | |
123 | + | func aa () = makeString(["%s", "priceAssets"], m) | |
122 | 124 | ||
123 | 125 | ||
124 | - | func | |
126 | + | func ab () = "%s__priceDecimals" | |
125 | 127 | ||
126 | 128 | ||
127 | - | func | |
129 | + | func ac () = "%s__shutdown" | |
128 | 130 | ||
129 | 131 | ||
130 | - | func ad ( | |
132 | + | func ad () = "%s__nextInternalAssetId" | |
131 | 133 | ||
132 | 134 | ||
133 | - | func | |
135 | + | func ae (af) = ("%s%s__poolWeight__" + af) | |
134 | 136 | ||
135 | 137 | ||
136 | - | func | |
138 | + | func ag (af,ah) = ((("%s%s__poolWeight__" + af) + "__") + toString(ah)) | |
137 | 139 | ||
138 | 140 | ||
139 | - | func ak (al) = { | |
140 | - | let am = al | |
141 | - | let ai = am._1 | |
142 | - | let aj = am._2 | |
143 | - | makeString(["%d%d%s", toString(ai), toString(aj), "oneTokenOperationsDisabled"], l) | |
141 | + | func ai (aj) = ("%s%s%d__mappings__internal2baseAssetId__" + toString(aj)) | |
142 | + | ||
143 | + | ||
144 | + | func ak (al) = ("%s%s%s__mappings__baseAsset2internalId__" + al) | |
145 | + | ||
146 | + | ||
147 | + | func am (an,ao) = (((("%d%d%s__" + an) + "__") + ao) + "__config") | |
148 | + | ||
149 | + | ||
150 | + | func ap (aq) = { | |
151 | + | let ar = aq | |
152 | + | let an = ar._1 | |
153 | + | let ao = ar._2 | |
154 | + | makeString(["%d%d%s", toString(an), toString(ao), "oneTokenOperationsDisabled"], m) | |
144 | 155 | } | |
145 | 156 | ||
146 | 157 | ||
147 | - | func | |
158 | + | func as () = makeString(["%s", "oneTokenOperationsDisabled"], m) | |
148 | 159 | ||
149 | 160 | ||
150 | - | func | |
161 | + | func at (au) = (("%s%s%s__" + au) + "__mappings__lpAsset2Pool") | |
151 | 162 | ||
152 | 163 | ||
153 | - | func | |
164 | + | func av (aw,ax) = (((("%d%d%s%s__" + aw) + "__") + ax) + "__mappings__PoolAssets2LpAsset") | |
154 | 165 | ||
155 | 166 | ||
156 | - | func | |
167 | + | func ay (af) = ("%s%s__spread__" + af) | |
157 | 168 | ||
158 | 169 | ||
159 | - | func | |
170 | + | func az (aA) = (("%s%s%s__" + aA) + "__mappings__poolContract2PoolAssets") | |
160 | 171 | ||
161 | 172 | ||
162 | - | func | |
173 | + | func aB (aw,ax) = (((("%d%d%s%s__" + toString(aw)) + "__") + toString(ax)) + "__mappings__poolAssets2PoolContract") | |
163 | 174 | ||
164 | 175 | ||
165 | - | func | |
176 | + | func aC (aA) = (("%s%s%s__" + aA) + "__mappings__poolContract2LpAsset") | |
166 | 177 | ||
167 | 178 | ||
168 | - | func | |
179 | + | func aD (au) = (("%s%s%s__" + au) + "__mappings__lpAsset2PoolContract") | |
169 | 180 | ||
170 | 181 | ||
171 | - | func | |
182 | + | func aE (aF,aG) = ((("%s%s%s__wxEmission__" + aF) + "__") + aG) | |
172 | 183 | ||
173 | 184 | ||
174 | - | func | |
185 | + | func aH (af) = ("%s%s__inFee__" + af) | |
175 | 186 | ||
176 | 187 | ||
177 | - | func | |
188 | + | func aI () = "%s__inFeeDefault" | |
178 | 189 | ||
179 | 190 | ||
180 | - | func | |
191 | + | func aJ (af) = ("%s%s__swapFee__" + af) | |
181 | 192 | ||
182 | 193 | ||
183 | - | func | |
194 | + | func aK (af) = ("%s%s__outFee__" + af) | |
184 | 195 | ||
185 | 196 | ||
186 | - | func | |
197 | + | func aL () = "%s__outFeeDefault" | |
187 | 198 | ||
188 | 199 | ||
189 | - | func | |
200 | + | func aM (af) = ("%s%s__skipOrderValidation__" + af) | |
190 | 201 | ||
191 | 202 | ||
192 | - | func | |
203 | + | func aN (af) = ("%s%s__changeAmpDelay__" + af) | |
193 | 204 | ||
194 | 205 | ||
195 | - | func | |
206 | + | func aO (af) = ("%s%s__changeAmpDelta__" + af) | |
196 | 207 | ||
197 | 208 | ||
198 | - | func | |
209 | + | func aP (af) = ("%s%s__changeAmpTarget__" + af) | |
199 | 210 | ||
200 | 211 | ||
201 | - | func | |
212 | + | func aQ () = "%s__sWavesProxyAddress" | |
202 | 213 | ||
203 | 214 | ||
204 | - | func | |
215 | + | func aR () = "%s__sWavesAssetId" | |
205 | 216 | ||
206 | 217 | ||
207 | - | func | |
218 | + | func aS () = "%s__stakingProfitAddress" | |
208 | 219 | ||
209 | 220 | ||
210 | - | func | |
221 | + | func aT (af,aU) = makeString(["%s%s%s", "leasedRatio", af, aU], m) | |
211 | 222 | ||
212 | 223 | ||
213 | - | func | |
224 | + | func aV (aU) = makeString(["%s%s", "leasedRatioDefault", aU], m) | |
214 | 225 | ||
215 | 226 | ||
216 | - | func | |
227 | + | func aW (af,aU) = makeString(["%s%s%s", "leasedRatioTolerance", af, aU], m) | |
217 | 228 | ||
218 | 229 | ||
219 | - | func | |
230 | + | func aX (af,aU) = makeString(["%s%s%s", "minBalance", af, aU], m) | |
220 | 231 | ||
221 | 232 | ||
222 | - | func | |
233 | + | func aY (aU) = makeString(["%s%s", "minBalanceDefault", aU], m) | |
223 | 234 | ||
224 | 235 | ||
225 | - | func | |
236 | + | func aZ (ba) = valueOrErrorMessage(getString(this, ba), ("No data for this.key=" + ba)) | |
226 | 237 | ||
227 | 238 | ||
228 | - | func | |
239 | + | func bb (ba) = valueOrErrorMessage(getBoolean(this, ba), ("No data for this.key=" + ba)) | |
229 | 240 | ||
230 | 241 | ||
231 | - | func | |
242 | + | func bc (ba) = valueOrErrorMessage(getInteger(this, ba), ("No data for this.key=" + ba)) | |
232 | 243 | ||
233 | 244 | ||
234 | - | func | |
245 | + | func bd (be) = if ((be == j)) | |
235 | 246 | then unit | |
236 | - | else fromBase58String( | |
247 | + | else fromBase58String(be) | |
237 | 248 | ||
238 | 249 | ||
239 | - | func | |
240 | - | let | |
241 | - | if ($isInstanceOf( | |
250 | + | func bf () = { | |
251 | + | let bg = getString(V()) | |
252 | + | if ($isInstanceOf(bg, "String")) | |
242 | 253 | then { | |
243 | - | let | |
244 | - | addressFromStringValue( | |
254 | + | let bh = bg | |
255 | + | addressFromStringValue(bh) | |
245 | 256 | } | |
246 | 257 | else this | |
247 | 258 | } | |
248 | 259 | ||
249 | 260 | ||
250 | - | let | |
261 | + | let bi = 1 | |
251 | 262 | ||
252 | - | let | |
263 | + | let bj = 2 | |
253 | 264 | ||
254 | - | let | |
265 | + | let bk = 3 | |
255 | 266 | ||
256 | - | let | |
267 | + | let bl = 4 | |
257 | 268 | ||
258 | - | let | |
269 | + | let bm = 5 | |
259 | 270 | ||
260 | - | let | |
271 | + | let bn = 6 | |
261 | 272 | ||
262 | - | let | |
273 | + | let bo = 7 | |
263 | 274 | ||
264 | - | let | |
275 | + | let bp = 8 | |
265 | 276 | ||
266 | - | let | |
277 | + | let bq = 9 | |
267 | 278 | ||
268 | - | let | |
279 | + | let br = 10 | |
269 | 280 | ||
270 | - | let | |
281 | + | let bs = 11 | |
271 | 282 | ||
272 | - | func | |
283 | + | func bt (bu) = addressFromStringValue(bu[bj]) | |
273 | 284 | ||
274 | 285 | ||
275 | - | func | |
286 | + | func bv (bu) = addressFromStringValue(bu[bm]) | |
276 | 287 | ||
277 | 288 | ||
278 | - | func | |
289 | + | func bw (bu) = addressFromStringValue(bu[bi]) | |
279 | 290 | ||
280 | 291 | ||
281 | - | func | |
292 | + | func bx (bu) = addressFromStringValue(bu[br]) | |
282 | 293 | ||
283 | 294 | ||
284 | - | func | |
285 | - | let | |
286 | - | if ($isInstanceOf( | |
295 | + | func by () = { | |
296 | + | let bg = getString(aa()) | |
297 | + | if ($isInstanceOf(bg, "String")) | |
287 | 298 | then { | |
288 | - | let | |
289 | - | if ((size( | |
299 | + | let bh = bg | |
300 | + | if ((size(bh) == 0)) | |
290 | 301 | then nil | |
291 | - | else split_4C( | |
302 | + | else split_4C(bh, m) | |
292 | 303 | } | |
293 | 304 | else nil | |
294 | 305 | } | |
295 | 306 | ||
296 | 307 | ||
297 | - | func | |
298 | - | let | |
299 | - | let | |
300 | - | if ($isInstanceOf( | |
308 | + | func bz () = { | |
309 | + | let bA = bf() | |
310 | + | let bg = getString(bA, U()) | |
311 | + | if ($isInstanceOf(bg, "String")) | |
301 | 312 | then { | |
302 | - | let | |
303 | - | fromBase58String( | |
313 | + | let bh = bg | |
314 | + | fromBase58String(bh) | |
304 | 315 | } | |
305 | - | else if ($isInstanceOf( | |
316 | + | else if ($isInstanceOf(bg, "Unit")) | |
306 | 317 | then unit | |
307 | 318 | else throw("Match error") | |
308 | 319 | } | |
309 | 320 | ||
310 | 321 | ||
311 | - | let | |
322 | + | let bB = K("Permission denied") | |
312 | 323 | ||
313 | - | let | |
324 | + | let bC = K("Test error here") | |
314 | 325 | ||
315 | - | func | |
326 | + | func bD (bE) = if ((bE.caller == this)) | |
316 | 327 | then true | |
317 | - | else | |
328 | + | else bB | |
318 | 329 | ||
319 | 330 | ||
320 | - | func | |
321 | - | let | |
322 | - | if ($isInstanceOf( | |
331 | + | func bF (bE) = { | |
332 | + | let bg = bz() | |
333 | + | if ($isInstanceOf(bg, "ByteVector")) | |
323 | 334 | then { | |
324 | - | let | |
325 | - | if (( | |
335 | + | let bG = bg | |
336 | + | if ((bE.callerPublicKey == bG)) | |
326 | 337 | then true | |
327 | - | else | |
338 | + | else bB | |
328 | 339 | } | |
329 | - | else if ($isInstanceOf( | |
330 | - | then | |
340 | + | else if ($isInstanceOf(bg, "Unit")) | |
341 | + | then bD(bE) | |
331 | 342 | else throw("Match error") | |
332 | 343 | } | |
333 | 344 | ||
334 | 345 | ||
335 | - | func | |
346 | + | func bH (bI,bJ,bK,bL,bM,bN,bO,bP,bQ,bR,bS) = makeString(["%s%s%s%s%s%s%s%s%s%s%s", bI, bJ, bK, bL, bM, bN, bO, bP, bQ, bR, bS], m) | |
336 | 347 | ||
337 | 348 | ||
338 | - | func | |
349 | + | func bT (bI,bJ,bK,bL,bM,bN,bO) = makeString(["%s%s%s%s%s%s", bI, bJ, bK, bL, bM, bN, bO], m) | |
339 | 350 | ||
340 | 351 | ||
341 | - | func | |
352 | + | func bU (af,bV,bW,bX,bY,bZ,ca,cb,cc,cd,ce) = makeString(["%s%d%s%s%s%d%d%d%d%d%s", af, bV, bW, bX, bY, toString(bZ), toString(ca), toString(cb), toString(cc), toString(cd), ce], m) | |
342 | 353 | ||
343 | 354 | ||
344 | - | func | |
355 | + | func cf (cg,ch) = makeString(["%d%d", toString(cg), toString(ch)], m) | |
345 | 356 | ||
346 | 357 | ||
347 | - | func | |
348 | - | let | |
349 | - | let | |
350 | - | let | |
351 | - | split( | |
358 | + | func ci (af) = { | |
359 | + | let cj = split(aZ(az(af)), m) | |
360 | + | let an = cj[1] | |
361 | + | let ao = cj[2] | |
362 | + | split(aZ(am(an, ao)), m) | |
352 | 363 | } | |
353 | 364 | ||
354 | 365 | ||
355 | - | func | |
356 | - | let | |
357 | - | let | |
358 | - | let | |
366 | + | func ck (cl,cm) = { | |
367 | + | let cn = valueOrElse(getInteger(this, ak(cl)), 0) | |
368 | + | let co = valueOrElse(getInteger(this, ad()), 0) | |
369 | + | let cp = if ((cn == 0)) | |
359 | 370 | then { | |
360 | - | let | |
361 | - | $Tuple3( | |
371 | + | let cq = (co + cm) | |
372 | + | $Tuple3(cq, [IntegerEntry(ad(), cq), IntegerEntry(ak(cl), cq), StringEntry(ai(cq), cl)], true) | |
362 | 373 | } | |
363 | - | else $Tuple3( | |
364 | - | | |
374 | + | else $Tuple3(cn, nil, false) | |
375 | + | cp | |
365 | 376 | } | |
366 | 377 | ||
367 | 378 | ||
368 | - | func | |
369 | - | let | |
370 | - | if (containsElement( | |
379 | + | func cr (bE) = { | |
380 | + | let cs = split(valueOrElse(getString(W()), n), m) | |
381 | + | if (containsElement(cs, toBase58String(bE.callerPublicKey))) | |
371 | 382 | then true | |
372 | 383 | else { | |
373 | - | let | |
374 | - | if (( | |
384 | + | let ct = bF(bE) | |
385 | + | if ((ct == ct)) | |
375 | 386 | then true | |
376 | 387 | else throw("Strict value is not equal to itself.") | |
377 | 388 | } | |
378 | 389 | } | |
379 | 390 | ||
380 | 391 | ||
381 | - | func | |
392 | + | func cu (ba,cv,cw) = valueOrElse(getInteger(this, ba), valueOrElse(getInteger(this, cv), cw)) | |
382 | 393 | ||
383 | 394 | ||
384 | - | func | |
385 | - | let | |
386 | - | let | |
387 | - | if (if (( | |
395 | + | func cx (aF,aG) = { | |
396 | + | let an = getInteger(ak(aF)) | |
397 | + | let ao = getInteger(ak(aG)) | |
398 | + | if (if ((an == unit)) | |
388 | 399 | then true | |
389 | - | else ( | |
400 | + | else (ao == unit)) | |
390 | 401 | then false | |
391 | 402 | else { | |
392 | - | let | |
393 | - | let | |
394 | - | let | |
395 | - | let | |
396 | - | let | |
403 | + | let cy = toString(value(an)) | |
404 | + | let cz = toString(value(ao)) | |
405 | + | let cA = getString(am(cy, cz)) | |
406 | + | let cB = getString(am(cz, cy)) | |
407 | + | let cC = if ((cA != unit)) | |
397 | 408 | then true | |
398 | - | else ( | |
399 | - | | |
409 | + | else (cB != unit) | |
410 | + | cC | |
400 | 411 | } | |
401 | 412 | } | |
402 | 413 | ||
403 | 414 | ||
404 | - | @Callable(bz) | |
405 | - | func getSwapContractREADONLY () = $Tuple2(nil, aU(J())) | |
415 | + | func cD (aA) = { | |
416 | + | let cj = { | |
417 | + | let bg = getString(az(aA)) | |
418 | + | if ($isInstanceOf(bg, "String")) | |
419 | + | then { | |
420 | + | let bh = bg | |
421 | + | split(bh, m) | |
422 | + | } | |
423 | + | else K(makeString([aA, "pool is not found"], " ")) | |
424 | + | } | |
425 | + | let an = parseIntValue(cj[1]) | |
426 | + | let ao = parseIntValue(cj[2]) | |
427 | + | let aF = getStringValue(ai(an)) | |
428 | + | let aG = getStringValue(ai(ao)) | |
429 | + | let bW = getStringValue(aC(aA)) | |
430 | + | $Tuple5(aF, aG, bW, an, ao) | |
431 | + | } | |
432 | + | ||
433 | + | ||
434 | + | func cE (aA) = { | |
435 | + | let cF = cD(aA) | |
436 | + | let aF = cF._1 | |
437 | + | let aG = cF._2 | |
438 | + | let bW = cF._3 | |
439 | + | let an = cF._4 | |
440 | + | let ao = cF._5 | |
441 | + | let cG = addressFromStringValue(getStringValue(Z())) | |
442 | + | let cH = invoke(cG, "getPoolCreatorREADONLY", [aF, aG], nil) | |
443 | + | cH | |
444 | + | } | |
445 | + | ||
446 | + | ||
447 | + | func cI (cJ,cK) = { | |
448 | + | let cL = addressFromStringValue(cJ) | |
449 | + | if ((cK == "WAVES")) | |
450 | + | then wavesBalance(cL).regular | |
451 | + | else { | |
452 | + | let aU = fromBase58String(cK) | |
453 | + | assetBalance(cL, aU) | |
454 | + | } | |
455 | + | } | |
456 | + | ||
457 | + | ||
458 | + | func cM (aA) = { | |
459 | + | let cN = cD(aA) | |
460 | + | let aF = cN._1 | |
461 | + | let aG = cN._2 | |
462 | + | let bW = cN._3 | |
463 | + | let an = cN._4 | |
464 | + | let ao = cN._5 | |
465 | + | if ((cI(aA, aF) == 0)) | |
466 | + | then (cI(aA, aG) == 0) | |
467 | + | else false | |
468 | + | } | |
469 | + | ||
470 | + | ||
471 | + | @Callable(bE) | |
472 | + | func getSwapContractREADONLY () = $Tuple2(nil, aZ(N())) | |
406 | 473 | ||
407 | 474 | ||
408 | 475 | ||
409 | - | @Callable( | |
410 | - | func getPoolLeaseConfigREADONLY ( | |
411 | - | let | |
412 | - | let | |
413 | - | if ($isInstanceOf( | |
476 | + | @Callable(bE) | |
477 | + | func getPoolLeaseConfigREADONLY (af,aU) = { | |
478 | + | let cO = { | |
479 | + | let bg = getInteger(this, aT(af, aU)) | |
480 | + | if ($isInstanceOf(bg, "Int")) | |
414 | 481 | then { | |
415 | - | let | |
416 | - | $Tuple2(true, min([100, max([0, | |
482 | + | let cP = bg | |
483 | + | $Tuple2(true, min([100, max([0, cP])])) | |
417 | 484 | } | |
418 | 485 | else { | |
419 | - | let | |
420 | - | if ($isInstanceOf( | |
486 | + | let cQ = getInteger(this, aV(aU)) | |
487 | + | if ($isInstanceOf(cQ, "Int")) | |
421 | 488 | then { | |
422 | - | let | |
423 | - | $Tuple2(true, min([100, max([0, | |
489 | + | let cR = cQ | |
490 | + | $Tuple2(true, min([100, max([0, cR])])) | |
424 | 491 | } | |
425 | 492 | else $Tuple2(false, 0) | |
426 | 493 | } | |
427 | 494 | } | |
428 | - | let | |
429 | - | let | |
430 | - | let | |
431 | - | let | |
432 | - | if ($isInstanceOf( | |
495 | + | let cS = cO._1 | |
496 | + | let cT = cO._2 | |
497 | + | let cU = { | |
498 | + | let bg = getInteger(this, aX(af, aU)) | |
499 | + | if ($isInstanceOf(bg, "Int")) | |
433 | 500 | then { | |
434 | - | let | |
435 | - | max([0, | |
501 | + | let cV = bg | |
502 | + | max([0, cV]) | |
436 | 503 | } | |
437 | 504 | else { | |
438 | - | let | |
439 | - | if ($isInstanceOf( | |
505 | + | let cQ = getInteger(this, aY(aU)) | |
506 | + | if ($isInstanceOf(cQ, "Int")) | |
440 | 507 | then { | |
441 | - | let | |
442 | - | max([0, | |
508 | + | let cW = cQ | |
509 | + | max([0, cW]) | |
443 | 510 | } | |
444 | 511 | else 0 | |
445 | 512 | } | |
446 | 513 | } | |
447 | - | let | |
448 | - | then $Tuple3(valueOrElse(getString(this, | |
514 | + | let cX = if ((aU == "WAVES")) | |
515 | + | then $Tuple3(valueOrElse(getString(this, aQ()), ""), getString(this, valueOrElse(aR(), "")), c) | |
449 | 516 | else $Tuple3("", "", 0) | |
450 | - | let | |
451 | - | let | |
452 | - | let | |
453 | - | let | |
454 | - | $Tuple2(nil, $Tuple7( | |
517 | + | let cY = cX._1 | |
518 | + | let cZ = cX._2 | |
519 | + | let da = cX._3 | |
520 | + | let db = valueOrElse(getString(this, aS()), "") | |
521 | + | $Tuple2(nil, $Tuple7(cS, cT, cU, cY, cZ, da, db)) | |
455 | 522 | } | |
456 | 523 | ||
457 | 524 | ||
458 | 525 | ||
459 | - | @Callable( | |
460 | - | func getLpAssetFromPoolAssetsREADONLY ( | |
461 | - | then ( | |
526 | + | @Callable(bE) | |
527 | + | func getLpAssetFromPoolAssetsREADONLY (dc,dd) = if (if ((dc == "8LQW8f7P5d5PZM7GtZEBgaqRPGSzS3DfPuiXrURJ4AJS")) | |
528 | + | then (dd == "WAVES") | |
462 | 529 | else false) | |
463 | 530 | then $Tuple2(nil, unit) | |
464 | 531 | else { | |
465 | - | let | |
466 | - | let | |
467 | - | let | |
468 | - | let | |
532 | + | let de = value(getInteger(this, ak(dc))) | |
533 | + | let df = value(getInteger(this, ak(dd))) | |
534 | + | let dg = getString(this, av(toString(de), toString(df))) | |
535 | + | let dh = if ((dg == unit)) | |
469 | 536 | then unit | |
470 | - | else drop(value( | |
471 | - | $Tuple2(nil, | |
537 | + | else drop(value(dg), 4) | |
538 | + | $Tuple2(nil, dh) | |
472 | 539 | } | |
473 | 540 | ||
474 | 541 | ||
475 | 542 | ||
476 | - | @Callable( | |
477 | - | func getPoolAddressFromLpAssetREADONLY ( | |
543 | + | @Callable(bE) | |
544 | + | func getPoolAddressFromLpAssetREADONLY (di) = $Tuple2(nil, valueOrElse(getString(this, aD(di)), "")) | |
478 | 545 | ||
479 | 546 | ||
480 | 547 | ||
481 | - | @Callable( | |
482 | - | func constructor ( | |
483 | - | let | |
484 | - | if (( | |
485 | - | then [StringEntry( | |
548 | + | @Callable(bE) | |
549 | + | func constructor (dj,dk,bK,bL,bM,bN,dl,dm) = { | |
550 | + | let dn = bF(bE) | |
551 | + | if ((dn == dn)) | |
552 | + | then [StringEntry(O(), bT(dj, dk, bK, bL, bM, bN, dl)), IntegerEntry(ab(), dm)] | |
486 | 553 | else throw("Strict value is not equal to itself.") | |
487 | 554 | } | |
488 | 555 | ||
489 | 556 | ||
490 | 557 | ||
491 | - | @Callable( | |
492 | - | func constructorV2 ( | |
493 | - | let | |
494 | - | if (( | |
558 | + | @Callable(bE) | |
559 | + | func constructorV2 (do) = { | |
560 | + | let dn = bF(bE) | |
561 | + | if ((dn == dn)) | |
495 | 562 | then { | |
496 | - | let | |
497 | - | if (( | |
498 | - | then [StringEntry( | |
563 | + | let dp = addressFromPublicKey(fromBase58String(do)) | |
564 | + | if ((dp == dp)) | |
565 | + | then [StringEntry(R(), do)] | |
499 | 566 | else throw("Strict value is not equal to itself.") | |
500 | 567 | } | |
501 | 568 | else throw("Strict value is not equal to itself.") | |
502 | 569 | } | |
503 | 570 | ||
504 | 571 | ||
505 | 572 | ||
506 | - | @Callable( | |
507 | - | func constructorV3 ( | |
508 | - | let | |
509 | - | if (( | |
573 | + | @Callable(bE) | |
574 | + | func constructorV3 (bP,bQ,bR,bS) = { | |
575 | + | let dn = bF(bE) | |
576 | + | if ((dn == dn)) | |
510 | 577 | then { | |
511 | - | let | |
512 | - | [StringEntry( | |
578 | + | let bu = split(aZ(O()), m) | |
579 | + | [StringEntry(O(), bH(bu[1], bu[2], bu[3], bu[4], bu[5], bu[6], bu[7], bP, bQ, bR, bS))] | |
513 | 580 | } | |
514 | 581 | else throw("Strict value is not equal to itself.") | |
515 | 582 | } | |
516 | 583 | ||
517 | 584 | ||
518 | 585 | ||
519 | - | @Callable( | |
520 | - | func constructorV4 ( | |
521 | - | let | |
522 | - | if (( | |
523 | - | then [StringEntry( | |
586 | + | @Callable(bE) | |
587 | + | func constructorV4 (dq,dr) = { | |
588 | + | let dn = bF(bE) | |
589 | + | if ((dn == dn)) | |
590 | + | then [StringEntry(S(), dq), StringEntry(T(), makeString(dr, m))] | |
524 | 591 | else throw("Strict value is not equal to itself.") | |
525 | 592 | } | |
526 | 593 | ||
527 | 594 | ||
528 | 595 | ||
529 | - | @Callable( | |
530 | - | func constructorV5 ( | |
531 | - | let | |
532 | - | if (( | |
533 | - | then [StringEntry( | |
596 | + | @Callable(bE) | |
597 | + | func constructorV5 (ds) = { | |
598 | + | let dn = bF(bE) | |
599 | + | if ((dn == dn)) | |
600 | + | then [StringEntry(X(), ds)] | |
534 | 601 | else throw("Strict value is not equal to itself.") | |
535 | 602 | } | |
536 | 603 | ||
537 | 604 | ||
538 | 605 | ||
539 | - | @Callable( | |
540 | - | func constructorV6 ( | |
541 | - | let | |
606 | + | @Callable(bE) | |
607 | + | func constructorV6 (dt,du) = { | |
608 | + | let dv = [bF(bE), if ((addressFromString(dt) != unit)) | |
542 | 609 | then true | |
543 | 610 | else "invalid voting emission contract address"] | |
544 | - | if (( | |
545 | - | then [StringEntry( | |
611 | + | if ((dv == dv)) | |
612 | + | then [StringEntry(Y(), dt), StringEntry(aa(), makeString(du, m))] | |
546 | 613 | else throw("Strict value is not equal to itself.") | |
547 | 614 | } | |
548 | 615 | ||
549 | 616 | ||
550 | 617 | ||
551 | - | @Callable( | |
552 | - | func setAdmins ( | |
553 | - | let | |
554 | - | if (( | |
555 | - | then [StringEntry( | |
618 | + | @Callable(bE) | |
619 | + | func setAdmins (dw) = { | |
620 | + | let dn = bF(bE) | |
621 | + | if ((dn == dn)) | |
622 | + | then [StringEntry(W(), makeString(dw, m))] | |
556 | 623 | else throw("Strict value is not equal to itself.") | |
557 | 624 | } | |
558 | 625 | ||
559 | 626 | ||
560 | 627 | ||
561 | - | @Callable( | |
562 | - | func activateNewPool ( | |
563 | - | let | |
564 | - | if (( | |
565 | - | then if (isDefined(getString( | |
566 | - | then | |
628 | + | @Callable(bE) | |
629 | + | func activateNewPool (af,bX,bY,dx,dy,dz,ce,dA) = { | |
630 | + | let dn = cr(bE) | |
631 | + | if ((dn == dn)) | |
632 | + | then if (isDefined(getString(az(af)))) | |
633 | + | then K((("Pool address " + af) + " already registered.")) | |
567 | 634 | else { | |
568 | - | let | |
569 | - | let | |
570 | - | let | |
635 | + | let dB = ck(bX, 1) | |
636 | + | let dC = dB._1 | |
637 | + | let dD = ck(bY, if (dB._3) | |
571 | 638 | then 2 | |
572 | 639 | else 1) | |
573 | - | let | |
574 | - | let | |
575 | - | let | |
576 | - | let | |
577 | - | if ( | |
578 | - | then | |
640 | + | let dE = dD._1 | |
641 | + | let dF = valueOrErrorMessage(scriptHash(addressFromStringValue(af)), ("No script has been found on pool account " + af)) | |
642 | + | let dG = getBinaryValue(Q()) | |
643 | + | let dH = cx(bX, bY) | |
644 | + | if (dH) | |
645 | + | then K((((("Pool " + bX) + "/") + bY) + " has already been activated.")) | |
579 | 646 | else { | |
580 | - | let | |
581 | - | let | |
582 | - | then | |
583 | - | else pow(10, 0, value(assetInfo(fromBase58String( | |
584 | - | let | |
585 | - | then | |
586 | - | else pow(10, 0, value(assetInfo(fromBase58String( | |
587 | - | let | |
588 | - | let | |
589 | - | let | |
590 | - | let | |
591 | - | if (( | |
592 | - | then if (( | |
593 | - | then | |
647 | + | let dI = value(getString(this, am(toString(dC), toString(dE)))) | |
648 | + | let dJ = if ((bX == "WAVES")) | |
649 | + | then l | |
650 | + | else pow(10, 0, value(assetInfo(fromBase58String(bX))).decimals, 0, 0, DOWN) | |
651 | + | let dK = if ((bY == "WAVES")) | |
652 | + | then l | |
653 | + | else pow(10, 0, value(assetInfo(fromBase58String(bY))).decimals, 0, 0, DOWN) | |
654 | + | let dL = Issue(dx, dy, 1, 8, true) | |
655 | + | let bW = calculateAssetId(dL) | |
656 | + | let dM = toBase58String(bW) | |
657 | + | let dN = invoke(addressFromStringValue(af), "activate", [bX, bY], nil) | |
658 | + | if ((dN == dN)) | |
659 | + | then if ((dN != "success")) | |
660 | + | then K("Pool initialisation error happened.") | |
594 | 661 | else { | |
595 | - | let | |
596 | - | let | |
597 | - | if (( | |
662 | + | let ds = addressFromStringValue(aZ(X())) | |
663 | + | let dO = invoke(ds, "createOrUpdate", [dM, dx, false], nil) | |
664 | + | if ((dO == dO)) | |
598 | 665 | then { | |
599 | - | let | |
600 | - | if (( | |
666 | + | let dP = invoke(ds, "addLabel", [dM, h], nil) | |
667 | + | if ((dP == dP)) | |
601 | 668 | then { | |
602 | - | let | |
603 | - | if (( | |
669 | + | let dQ = invoke(ds, "setLogo", [dM, dA], nil) | |
670 | + | if ((dQ == dQ)) | |
604 | 671 | then { | |
605 | - | let | |
606 | - | if (( | |
672 | + | let dR = invoke(ds, "addAssetsLink", [bX, bY, dM], nil) | |
673 | + | if ((dR == dR)) | |
607 | 674 | then { | |
608 | - | let | |
609 | - | if (( | |
610 | - | then $Tuple2((( | |
675 | + | let dS = invoke(ds, "increaseAssetPoolsNumber", [bX], nil) | |
676 | + | if ((dS == dS)) | |
677 | + | then $Tuple2(((dB._2 ++ dD._2) ++ [dL, Burn(bW, 1), StringEntry(am(toString(dC), toString(dE)), bU(af, toString(o), dM, bX, bY, dJ, dK, dC, dE, l, ce)), StringEntry(at(dM), cf(dC, dE)), StringEntry(av(toString(dC), toString(dE)), ("%s__" + dM)), StringEntry(az(af), cf(dC, dE)), StringEntry(aB(dC, dE), af), StringEntry(aD(dM), af), StringEntry(aC(af), dM), IntegerEntry(ae(af), dz), IntegerEntry(ay(af), i)]), dM) | |
611 | 678 | else throw("Strict value is not equal to itself.") | |
612 | 679 | } | |
613 | 680 | else throw("Strict value is not equal to itself.") | |
614 | 681 | } | |
615 | 682 | else throw("Strict value is not equal to itself.") | |
616 | 683 | } | |
617 | 684 | else throw("Strict value is not equal to itself.") | |
618 | 685 | } | |
619 | 686 | else throw("Strict value is not equal to itself.") | |
620 | 687 | } | |
621 | 688 | else throw("Strict value is not equal to itself.") | |
622 | 689 | } | |
623 | 690 | } | |
624 | 691 | else throw("Strict value is not equal to itself.") | |
625 | 692 | } | |
626 | 693 | ||
627 | 694 | ||
628 | 695 | ||
629 | - | @Callable( | |
630 | - | func managePool ( | |
631 | - | let | |
632 | - | if (( | |
696 | + | @Callable(bE) | |
697 | + | func managePool (af,dT) = { | |
698 | + | let dn = bF(bE) | |
699 | + | if ((dn == dn)) | |
633 | 700 | then { | |
634 | - | let | |
635 | - | let | |
636 | - | let | |
637 | - | let | |
638 | - | let | |
639 | - | let | |
640 | - | let | |
641 | - | let | |
642 | - | let | |
643 | - | let | |
644 | - | let | |
645 | - | [StringEntry( | |
701 | + | let dU = ci(af) | |
702 | + | let bV = dU[w] | |
703 | + | let dM = dU[x] | |
704 | + | let bX = dU[y] | |
705 | + | let bY = dU[z] | |
706 | + | let dJ = parseIntValue(dU[A]) | |
707 | + | let dK = parseIntValue(dU[B]) | |
708 | + | let dC = parseIntValue(dU[C]) | |
709 | + | let dE = parseIntValue(dU[D]) | |
710 | + | let dV = parseIntValue(dU[E]) | |
711 | + | let ce = dU[F] | |
712 | + | [StringEntry(am(toString(dC), toString(dE)), bU(af, toString(dT), dM, bX, bY, dJ, dK, dC, dE, dV, ce))] | |
646 | 713 | } | |
647 | 714 | else throw("Strict value is not equal to itself.") | |
648 | 715 | } | |
649 | 716 | ||
650 | 717 | ||
651 | 718 | ||
652 | - | @Callable( | |
653 | - | func emit ( | |
654 | - | let | |
655 | - | let | |
656 | - | let | |
657 | - | let | |
658 | - | let | |
659 | - | let | |
660 | - | if ((0 >= | |
719 | + | @Callable(bE) | |
720 | + | func emit (dW) = { | |
721 | + | let dX = bE.caller | |
722 | + | let dY = bE.originCaller | |
723 | + | let dZ = valueOrErrorMessage(getString(aC(toString(dX))), "Invalid LP address called me.") | |
724 | + | let ea = fromBase58String(dZ) | |
725 | + | let dr = split(valueOrElse(getString(T()), n), m) | |
726 | + | let dq = addressFromStringValue(valueOrErrorMessage(getString(S()), "Legacy factory contract does not exists.")) | |
727 | + | if ((0 >= dW)) | |
661 | 728 | then nil | |
662 | - | else if (containsElement( | |
663 | - | then $Tuple2(nil, | |
664 | - | else $Tuple2([Reissue( | |
729 | + | else if (containsElement(dr, toString(dX))) | |
730 | + | then $Tuple2(nil, dq) | |
731 | + | else $Tuple2([Reissue(ea, dW, true), ScriptTransfer(bE.caller, dW, ea)], "success") | |
665 | 732 | } | |
666 | 733 | ||
667 | 734 | ||
668 | 735 | ||
669 | - | @Callable( | |
670 | - | func burn ( | |
671 | - | let | |
672 | - | let | |
673 | - | let | |
674 | - | let | |
675 | - | let | |
676 | - | let | |
677 | - | if (( | |
678 | - | then | |
679 | - | else if (( | |
680 | - | then | |
736 | + | @Callable(bE) | |
737 | + | func burn (eb) = { | |
738 | + | let dX = bE.caller | |
739 | + | let dY = bE.originCaller | |
740 | + | let ec = value(bE.payments[0]) | |
741 | + | let ed = value(ec.amount) | |
742 | + | let ee = toBase58String(value(ec.assetId)) | |
743 | + | let ef = valueOrErrorMessage(getString(aC(toString(dX))), "Invalid LP address called me.") | |
744 | + | if ((ee != ef)) | |
745 | + | then K("Invalid asset passed.") | |
746 | + | else if ((eb != ed)) | |
747 | + | then K("Invalid amount passed.") | |
681 | 748 | else { | |
682 | - | let | |
683 | - | $Tuple2([Burn( | |
749 | + | let ea = fromBase58String(ef) | |
750 | + | $Tuple2([Burn(ea, eb)], "success") | |
684 | 751 | } | |
685 | 752 | } | |
686 | 753 | ||
687 | 754 | ||
688 | 755 | ||
689 | - | @Callable( | |
690 | - | func modifyWeight ( | |
691 | - | let | |
756 | + | @Callable(bE) | |
757 | + | func modifyWeight (bW,eg) = { | |
758 | + | let dn = if ((toBase58String(bE.caller.bytes) == valueOrElse(getString(this, Y()), ""))) | |
692 | 759 | then true | |
693 | - | else | |
694 | - | if (( | |
760 | + | else bF(bE) | |
761 | + | if ((dn == dn)) | |
695 | 762 | then { | |
696 | - | let | |
697 | - | let | |
698 | - | let | |
699 | - | let | |
700 | - | let | |
701 | - | let | |
702 | - | let | |
703 | - | let | |
704 | - | let | |
705 | - | if (( | |
763 | + | let aA = aZ(aD(bW)) | |
764 | + | let eh = ae(aA) | |
765 | + | let ei = ae(g) | |
766 | + | let ej = valueOrElse(getInteger(ei), 0) | |
767 | + | let dz = valueOrElse(getInteger(eh), 0) | |
768 | + | let ek = eg | |
769 | + | let bu = split(aZ(O()), m) | |
770 | + | let dj = bw(bu) | |
771 | + | let el = invoke(dj, "onModifyWeight", [bW, aA], nil) | |
772 | + | if ((el == el)) | |
706 | 773 | then { | |
707 | - | let | |
774 | + | let em = if ((ej == 0)) | |
708 | 775 | then nil | |
709 | - | else [IntegerEntry( | |
710 | - | let | |
711 | - | let | |
712 | - | let | |
776 | + | else [IntegerEntry(ei, 0)] | |
777 | + | let en = ag(aA, 0) | |
778 | + | let eo = getInteger(en) | |
779 | + | let ep = if ((eo == unit)) | |
713 | 780 | then nil | |
714 | - | else [DeleteEntry( | |
715 | - | (([IntegerEntry( | |
781 | + | else [DeleteEntry(en)] | |
782 | + | (([IntegerEntry(eh, ek)] ++ em) ++ ep) | |
716 | 783 | } | |
717 | 784 | else throw("Strict value is not equal to itself.") | |
718 | 785 | } | |
719 | 786 | else throw("Strict value is not equal to itself.") | |
720 | 787 | } | |
721 | 788 | ||
722 | 789 | ||
723 | 790 | ||
724 | - | @Callable( | |
725 | - | func modifyWeights ( | |
726 | - | let | |
727 | - | if (( | |
791 | + | @Callable(bE) | |
792 | + | func modifyWeights (eq,er,es,et) = { | |
793 | + | let dn = bF(bE) | |
794 | + | if ((dn == dn)) | |
728 | 795 | then { | |
729 | - | let | |
730 | - | let | |
731 | - | let | |
732 | - | let | |
733 | - | let | |
734 | - | let | |
735 | - | let | |
736 | - | let | |
737 | - | let | |
738 | - | let | |
739 | - | let | |
740 | - | let | |
741 | - | let | |
742 | - | let | |
743 | - | if ((0 >= | |
744 | - | then | |
745 | - | else if ((0 >= | |
746 | - | then | |
796 | + | let eu = ((5 * f) / 100) | |
797 | + | let ev = ((5 * f) / 100) | |
798 | + | let ew = ((5 * f) / 100) | |
799 | + | let bu = split(aZ(O()), m) | |
800 | + | let ex = bw(bu) | |
801 | + | let ey = bx(bu) | |
802 | + | let ez = ae(eq) | |
803 | + | let eA = ae(er) | |
804 | + | let eB = ae(es) | |
805 | + | let eC = ae(et) | |
806 | + | let eD = bc(ez) | |
807 | + | let eE = bc(eA) | |
808 | + | let eF = (eD - ew) | |
809 | + | let eG = (eE - ew) | |
810 | + | if ((0 >= eF)) | |
811 | + | then K(("invalid btcWeightNew: " + toString(eF))) | |
812 | + | else if ((0 >= eG)) | |
813 | + | then K(("invalid ethWeightNew: " + toString(eG))) | |
747 | 814 | else { | |
748 | - | let | |
749 | - | let | |
750 | - | let | |
751 | - | let | |
752 | - | let | |
753 | - | if (( | |
815 | + | let eH = aZ(aC(eq)) | |
816 | + | let eI = aZ(aC(er)) | |
817 | + | let eJ = aZ(aC(es)) | |
818 | + | let eK = aZ(aC(et)) | |
819 | + | let eL = invoke(ex, "onModifyWeight", [eH, eq], nil) | |
820 | + | if ((eL == eL)) | |
754 | 821 | then { | |
755 | - | let | |
756 | - | if (( | |
822 | + | let eM = invoke(ex, "onModifyWeight", [eI, er], nil) | |
823 | + | if ((eM == eM)) | |
757 | 824 | then { | |
758 | - | let | |
759 | - | if (( | |
825 | + | let eN = invoke(ex, "onModifyWeight", [eJ, es], nil) | |
826 | + | if ((eN == eN)) | |
760 | 827 | then { | |
761 | - | let | |
762 | - | if (( | |
763 | - | then [IntegerEntry( | |
828 | + | let eO = invoke(ex, "onModifyWeight", [eK, et], nil) | |
829 | + | if ((eO == eO)) | |
830 | + | then [IntegerEntry(ez, eF), IntegerEntry(eA, eG), IntegerEntry(eB, eu), IntegerEntry(eC, ev), IntegerEntry(ag(eq, 0), eD), IntegerEntry(ag(er, 0), eE), IntegerEntry(ag(es, 0), eu), IntegerEntry(ag(et, 0), ev)] | |
764 | 831 | else throw("Strict value is not equal to itself.") | |
765 | 832 | } | |
766 | 833 | else throw("Strict value is not equal to itself.") | |
767 | 834 | } | |
768 | 835 | else throw("Strict value is not equal to itself.") | |
769 | 836 | } | |
770 | 837 | else throw("Strict value is not equal to itself.") | |
771 | 838 | } | |
772 | 839 | } | |
773 | 840 | else throw("Strict value is not equal to itself.") | |
774 | 841 | } | |
775 | 842 | ||
776 | 843 | ||
777 | 844 | ||
778 | - | @Callable( | |
779 | - | func checkWxEmissionPoolLabel ( | |
780 | - | let | |
781 | - | let | |
782 | - | if ($isInstanceOf( | |
845 | + | @Callable(bE) | |
846 | + | func checkWxEmissionPoolLabel (aF,aG) = { | |
847 | + | let eP = { | |
848 | + | let bg = getBoolean(aE(aF, aG)) | |
849 | + | if ($isInstanceOf(bg, "Boolean")) | |
783 | 850 | then { | |
784 | - | let | |
785 | - | | |
851 | + | let cV = bg | |
852 | + | cV | |
786 | 853 | } | |
787 | 854 | else false | |
788 | 855 | } | |
789 | - | $Tuple2(nil, | |
856 | + | $Tuple2(nil, eP) | |
790 | 857 | } | |
791 | 858 | ||
792 | 859 | ||
793 | 860 | ||
794 | - | @Callable( | |
795 | - | func setWxEmissionPoolLabel ( | |
796 | - | let | |
797 | - | if (( | |
798 | - | then $Tuple2([BooleanEntry( | |
861 | + | @Callable(bE) | |
862 | + | func setWxEmissionPoolLabel (aF,aG) = { | |
863 | + | let dn = cr(bE) | |
864 | + | if ((dn == dn)) | |
865 | + | then $Tuple2([BooleanEntry(aE(aF, aG), true)], unit) | |
799 | 866 | else throw("Strict value is not equal to itself.") | |
800 | 867 | } | |
801 | 868 | ||
802 | 869 | ||
803 | 870 | ||
804 | - | @Callable( | |
805 | - | func deleteWxEmissionPoolLabel ( | |
806 | - | let | |
871 | + | @Callable(bE) | |
872 | + | func deleteWxEmissionPoolLabel (aF,aG) = { | |
873 | + | let dn = if ((bE.caller == this)) | |
807 | 874 | then true | |
808 | - | else | |
809 | - | if (( | |
810 | - | then $Tuple2([DeleteEntry( | |
875 | + | else cr(bE) | |
876 | + | if ((dn == dn)) | |
877 | + | then $Tuple2([DeleteEntry(aE(aF, aG))], unit) | |
811 | 878 | else throw("Strict value is not equal to itself.") | |
812 | 879 | } | |
813 | 880 | ||
814 | 881 | ||
815 | 882 | ||
816 | - | @Callable( | |
817 | - | func onVerificationLoss ( | |
818 | - | let | |
883 | + | @Callable(bE) | |
884 | + | func onVerificationLoss (aU) = { | |
885 | + | let dn = if ((toBase58String(bE.caller.bytes) == valueOrElse(getString(this, X()), ""))) | |
819 | 886 | then true | |
820 | - | else | |
821 | - | if (( | |
887 | + | else bF(bE) | |
888 | + | if ((dn == dn)) | |
822 | 889 | then { | |
823 | - | let | |
824 | - | let | |
890 | + | let du = by() | |
891 | + | let eQ = if ((size(du) > 0)) | |
825 | 892 | then true | |
826 | - | else | |
827 | - | if (( | |
893 | + | else K("invalid price assets") | |
894 | + | if ((eQ == eQ)) | |
828 | 895 | then { | |
829 | - | func | |
830 | - | let | |
831 | - | if (( | |
896 | + | func eR (eS,eT) = { | |
897 | + | let cP = invoke(this, "deleteWxEmissionPoolLabel", [aU, eT], nil) | |
898 | + | if ((cP == cP)) | |
832 | 899 | then unit | |
833 | 900 | else throw("Strict value is not equal to itself.") | |
834 | 901 | } | |
835 | 902 | ||
836 | - | let | |
837 | - | let | |
838 | - | let | |
839 | - | let | |
840 | - | func | |
841 | - | then | |
842 | - | else | |
903 | + | let eU = { | |
904 | + | let eV = du | |
905 | + | let eW = size(eV) | |
906 | + | let eX = unit | |
907 | + | func eY (eZ,fa) = if ((fa >= eW)) | |
908 | + | then eZ | |
909 | + | else eR(eZ, eV[fa]) | |
843 | 910 | ||
844 | - | func | |
845 | - | then | |
911 | + | func fb (eZ,fa) = if ((fa >= eW)) | |
912 | + | then eZ | |
846 | 913 | else throw("List size exceeds 13") | |
847 | 914 | ||
848 | - | | |
915 | + | fb(eY(eY(eY(eY(eY(eY(eY(eY(eY(eY(eY(eY(eY(eX, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13) | |
849 | 916 | } | |
850 | - | if (( | |
917 | + | if ((eU == eU)) | |
851 | 918 | then $Tuple2(nil, unit) | |
852 | 919 | else throw("Strict value is not equal to itself.") | |
853 | 920 | } | |
854 | 921 | else throw("Strict value is not equal to itself.") | |
855 | 922 | } | |
856 | 923 | else throw("Strict value is not equal to itself.") | |
857 | 924 | } | |
858 | 925 | ||
859 | 926 | ||
860 | 927 | ||
861 | - | @Callable( | |
862 | - | func isPoolOneTokenOperationsDisabledREADONLY ( | |
863 | - | let | |
864 | - | let | |
865 | - | let | |
866 | - | let | |
867 | - | $Tuple2(nil, if ( | |
928 | + | @Callable(bE) | |
929 | + | func isPoolOneTokenOperationsDisabledREADONLY (af) = { | |
930 | + | let dU = ci(af) | |
931 | + | let aq = $Tuple2(parseIntValue(dU[C]), parseIntValue(dU[D])) | |
932 | + | let fc = valueOrElse(getBoolean(ap(aq)), false) | |
933 | + | let fd = valueOrElse(getBoolean(as()), false) | |
934 | + | $Tuple2(nil, if (fd) | |
868 | 935 | then true | |
869 | - | else | |
936 | + | else fc) | |
870 | 937 | } | |
871 | 938 | ||
872 | 939 | ||
873 | 940 | ||
874 | - | @Callable( | |
875 | - | func getInFeeREADONLY ( | |
876 | - | let | |
877 | - | $Tuple2(nil, | |
941 | + | @Callable(bE) | |
942 | + | func getInFeeREADONLY (af) = { | |
943 | + | let fe = cu(aH(af), aI(), 0) | |
944 | + | $Tuple2(nil, fe) | |
878 | 945 | } | |
879 | 946 | ||
880 | 947 | ||
881 | 948 | ||
882 | - | @Callable( | |
883 | - | func getOutFeeREADONLY ( | |
884 | - | let | |
885 | - | $Tuple2(nil, | |
949 | + | @Callable(bE) | |
950 | + | func getOutFeeREADONLY (af) = { | |
951 | + | let fe = cu(aK(af), aL(), fraction(10, b, 10000)) | |
952 | + | $Tuple2(nil, fe) | |
886 | 953 | } | |
887 | 954 | ||
888 | 955 | ||
889 | 956 | ||
890 | - | @Callable( | |
891 | - | func getSwapFeeREADONLY ( | |
892 | - | let | |
893 | - | let | |
894 | - | if ($isInstanceOf( | |
957 | + | @Callable(bE) | |
958 | + | func getSwapFeeREADONLY (ff) = { | |
959 | + | let fg = { | |
960 | + | let bg = getString(this, aJ(ff)) | |
961 | + | if ($isInstanceOf(bg, "String")) | |
895 | 962 | then { | |
896 | - | let | |
897 | - | let | |
898 | - | let | |
899 | - | let | |
900 | - | $Tuple2( | |
963 | + | let bh = bg | |
964 | + | let fh = split(bh, m) | |
965 | + | let fi = parseIntValue(fh[1]) | |
966 | + | let fj = parseIntValue(fh[2]) | |
967 | + | $Tuple2(fi, fj) | |
901 | 968 | } | |
902 | - | else if ($isInstanceOf( | |
969 | + | else if ($isInstanceOf(bg, "Unit")) | |
903 | 970 | then unit | |
904 | 971 | else throw("Match error") | |
905 | 972 | } | |
906 | - | $Tuple2(nil, | |
973 | + | $Tuple2(nil, fg) | |
907 | 974 | } | |
908 | 975 | ||
909 | 976 | ||
910 | 977 | ||
911 | - | @Callable( | |
912 | - | func poolInfoREADONLY ( | |
913 | - | let | |
914 | - | let | |
915 | - | let | |
916 | - | let | |
917 | - | let | |
918 | - | then isDefined( | |
978 | + | @Callable(bE) | |
979 | + | func poolInfoREADONLY (fk,fl) = { | |
980 | + | let fm = getInteger(this, ak(fk)) | |
981 | + | let fn = getInteger(this, ak(fl)) | |
982 | + | let fo = getString(this, aB(value(fm), value(fn))) | |
983 | + | let fp = getString(this, aC(value(fo))) | |
984 | + | let dH = if (if (isDefined(fm)) | |
985 | + | then isDefined(fn) | |
919 | 986 | else false) | |
920 | - | then isDefined( | |
987 | + | then isDefined(fo) | |
921 | 988 | else false | |
922 | - | let | |
923 | - | then $Tuple2(addressFromStringValue(value( | |
989 | + | let fq = if (dH) | |
990 | + | then $Tuple2(addressFromStringValue(value(fo)), bd(value(fp))) | |
924 | 991 | else unit | |
925 | - | $Tuple2(nil, | |
992 | + | $Tuple2(nil, fq) | |
926 | 993 | } | |
927 | 994 | ||
928 | 995 | ||
929 | 996 | ||
930 | - | @Callable( | |
931 | - | func getPoolStatusREADONLY ( | |
932 | - | let | |
933 | - | let | |
934 | - | let | |
935 | - | let | |
936 | - | $Tuple2(nil, parseIntValue( | |
997 | + | @Callable(bE) | |
998 | + | func getPoolStatusREADONLY (af) = { | |
999 | + | let cj = split(aZ(az(af)), m) | |
1000 | + | let an = cj[1] | |
1001 | + | let ao = cj[2] | |
1002 | + | let cA = split(aZ(am(an, ao)), m) | |
1003 | + | $Tuple2(nil, parseIntValue(cA[w])) | |
937 | 1004 | } | |
938 | 1005 | ||
939 | 1006 | ||
940 | 1007 | ||
941 | - | @Callable( | |
942 | - | func getPoolConfigREADONLY ( | |
943 | - | let | |
944 | - | let | |
945 | - | let | |
946 | - | let | |
947 | - | $Tuple2(nil, | |
1008 | + | @Callable(bE) | |
1009 | + | func getPoolConfigREADONLY (af) = { | |
1010 | + | let cj = split(aZ(az(af)), m) | |
1011 | + | let an = cj[1] | |
1012 | + | let ao = cj[2] | |
1013 | + | let cA = split(aZ(am(an, ao)), m) | |
1014 | + | $Tuple2(nil, cA) | |
948 | 1015 | } | |
949 | 1016 | ||
950 | 1017 | ||
951 | 1018 | ||
952 | - | @Callable( | |
953 | - | func getPoolConfigByLpAssetIdREADONLY ( | |
954 | - | let | |
955 | - | let | |
956 | - | let | |
957 | - | let | |
958 | - | $Tuple2(nil, | |
1019 | + | @Callable(bE) | |
1020 | + | func getPoolConfigByLpAssetIdREADONLY (dM) = { | |
1021 | + | let cj = split(aZ(at(dM)), m) | |
1022 | + | let an = cj[1] | |
1023 | + | let ao = cj[2] | |
1024 | + | let cA = split(aZ(am(an, ao)), m) | |
1025 | + | $Tuple2(nil, cA) | |
959 | 1026 | } | |
960 | 1027 | ||
961 | 1028 | ||
962 | 1029 | ||
963 | - | @Callable( | |
964 | - | func poolExistsREADONLY ( | |
1030 | + | @Callable(bE) | |
1031 | + | func poolExistsREADONLY (aF,aG) = $Tuple2(nil, cx(aF, aG)) | |
965 | 1032 | ||
966 | 1033 | ||
967 | 1034 | ||
968 | - | @Callable( | |
969 | - | func skipOrderValidationREADONLY ( | |
1035 | + | @Callable(bE) | |
1036 | + | func skipOrderValidationREADONLY (af) = $Tuple2(nil, valueOrElse(getBoolean(aM(af)), false)) | |
970 | 1037 | ||
971 | 1038 | ||
972 | 1039 | ||
973 | - | @Callable( | |
974 | - | func getChangeAmpConfigREADONLY ( | |
975 | - | let | |
976 | - | let | |
977 | - | let | |
978 | - | $Tuple2(nil, [ | |
1040 | + | @Callable(bE) | |
1041 | + | func getChangeAmpConfigREADONLY (af) = { | |
1042 | + | let fr = getIntegerValue(aN(af)) | |
1043 | + | let fs = getIntegerValue(aO(af)) | |
1044 | + | let ft = getIntegerValue(aP(af)) | |
1045 | + | $Tuple2(nil, [fr, fs, ft]) | |
979 | 1046 | } | |
980 | 1047 | ||
981 | 1048 | ||
982 | 1049 | ||
983 | - | @Callable( | |
984 | - | func getPoolWeightREADONLY ( | |
985 | - | let | |
986 | - | let | |
987 | - | $Tuple2(nil, | |
1050 | + | @Callable(bE) | |
1051 | + | func getPoolWeightREADONLY (bW) = { | |
1052 | + | let af = aZ(aD(bW)) | |
1053 | + | let fu = valueOrElse(getInteger(ae(af)), 0) | |
1054 | + | $Tuple2(nil, fu) | |
988 | 1055 | } | |
989 | 1056 | ||
990 | 1057 | ||
991 | - | @Verifier(ff) | |
992 | - | func fg () = { | |
993 | - | let fh = { | |
994 | - | let bb = bu() | |
995 | - | if ($isInstanceOf(bb, "ByteVector")) | |
1058 | + | ||
1059 | + | @Callable(bE) | |
1060 | + | func deletePool (aA) = { | |
1061 | + | let dU = ci(aA) | |
1062 | + | let dn = if ((toString(bE.caller) == cE(aA))) | |
1063 | + | then if (cM(aA)) | |
1064 | + | then true | |
1065 | + | else K("Pool is not empty") | |
1066 | + | else bF(bE) | |
1067 | + | if ((dn == dn)) | |
1068 | + | then { | |
1069 | + | let fv = if ((valueOrElse(getInteger(ae(aA)), 0) == 0)) | |
1070 | + | then true | |
1071 | + | else K("Pool weight is not Zero") | |
1072 | + | if ((fv == fv)) | |
1073 | + | then { | |
1074 | + | let fw = if ((dU[w] == toString(r))) | |
1075 | + | then true | |
1076 | + | else K("Pool must be SHUTDOWN (4)") | |
1077 | + | if ((fw == fw)) | |
1078 | + | then { | |
1079 | + | let fx = cD(aA) | |
1080 | + | let aF = fx._1 | |
1081 | + | let aG = fx._2 | |
1082 | + | let bW = fx._3 | |
1083 | + | let an = fx._4 | |
1084 | + | let ao = fx._5 | |
1085 | + | let cG = addressFromStringValue(getStringValue(Z())) | |
1086 | + | let fy = invoke(cG, "deletePool", [aF, aG], nil) | |
1087 | + | if ((fy == fy)) | |
1088 | + | then { | |
1089 | + | let dt = addressFromStringValue(getStringValue(Y())) | |
1090 | + | let fz = invoke(dt, "deletePool", [aF, aG], nil) | |
1091 | + | if ((fz == fz)) | |
1092 | + | then { | |
1093 | + | let ds = addressFromStringValue(getStringValue(X())) | |
1094 | + | let fA = invoke(ds, "deletePool", [aF, aG], nil) | |
1095 | + | if ((fA == fA)) | |
1096 | + | then [DeleteEntry(aC(aA)), DeleteEntry(az(aA)), DeleteEntry(av(toString(an), toString(ao))), DeleteEntry(aB(an, ao)), DeleteEntry(am(toString(an), toString(ao))), DeleteEntry(at(bW)), DeleteEntry(aD(bW)), DeleteEntry(aE(aF, aG)), DeleteEntry(ae(aA)), DeleteEntry(ay(aA)), DeleteEntry(aH(aA)), DeleteEntry(aK(aA)), DeleteEntry(aM(aA)), DeleteEntry(aN(aA)), DeleteEntry(aO(aA)), DeleteEntry(aP(aA))] | |
1097 | + | else throw("Strict value is not equal to itself.") | |
1098 | + | } | |
1099 | + | else throw("Strict value is not equal to itself.") | |
1100 | + | } | |
1101 | + | else throw("Strict value is not equal to itself.") | |
1102 | + | } | |
1103 | + | else throw("Strict value is not equal to itself.") | |
1104 | + | } | |
1105 | + | else throw("Strict value is not equal to itself.") | |
1106 | + | } | |
1107 | + | else throw("Strict value is not equal to itself.") | |
1108 | + | } | |
1109 | + | ||
1110 | + | ||
1111 | + | @Verifier(fB) | |
1112 | + | func fC () = { | |
1113 | + | let fD = { | |
1114 | + | let bg = bz() | |
1115 | + | if ($isInstanceOf(bg, "ByteVector")) | |
996 | 1116 | then { | |
997 | - | let | |
998 | - | | |
1117 | + | let bG = bg | |
1118 | + | bG | |
999 | 1119 | } | |
1000 | - | else if ($isInstanceOf( | |
1001 | - | then | |
1120 | + | else if ($isInstanceOf(bg, "Unit")) | |
1121 | + | then fB.senderPublicKey | |
1002 | 1122 | else throw("Match error") | |
1003 | 1123 | } | |
1004 | - | sigVerify( | |
1124 | + | sigVerify(fB.bodyBytes, fB.proofs[0], fD) | |
1005 | 1125 | } | |
1006 | 1126 |
github/deemru/w8io/169f3d6 453.68 ms ◑