tx · BENDQ4yDNTxnTX3TqTXTDHr8XNPt4EDzri3Sb22iVfYC 3PBbLJcBjLWUZZrFFUk5s53TdTUneHXDc7e: -0.01800000 Waves 2023.11.26 10:09 [3925928] smart account 3PBbLJcBjLWUZZrFFUk5s53TdTUneHXDc7e > SELF 0.00000000 Waves
{ "type": 13, "id": "BENDQ4yDNTxnTX3TqTXTDHr8XNPt4EDzri3Sb22iVfYC", "fee": 1800000, "feeAssetId": null, "timestamp": 1700982559427, "version": 2, "chainId": 87, "sender": "3PBbLJcBjLWUZZrFFUk5s53TdTUneHXDc7e", "senderPublicKey": "qv5sHFvV7GyNRm1A2r8BR9oX2nhkc1yNa1QfWLkaja8", "proofs": [ "2FbuyuvNtmBmGBoJxhgfefcVu7kiQcLLcRn5quAS9FqeJytb7Q9fuqa7SnKWgCPDB8axEtmbnD4GZTK15AFZ7gaf" ], "script": "base64:BgIdCAISABIAEgASABIAEgASABIDCgEBEgQKAggBEgBTAQ10cnlHZXRJbnRlZ2VyAgdhZGRyZXNzA2tleQQHJG1hdGNoMAkAmggCBQdhZGRyZXNzBQNrZXkDCQABAgUHJG1hdGNoMAIDSW50BAFiBQckbWF0Y2gwBQFiAAABDHRyeUdldFN0cmluZwIHYWRkcmVzcwNrZXkEByRtYXRjaDAJAJ0IAgUHYWRkcmVzcwUDa2V5AwkAAQIFByRtYXRjaDACBlN0cmluZwQBYgUHJG1hdGNoMAUBYgIAAAJkOACAwtcvAANkMTYJAGgCBQJkOAUCZDgAC3VubG9ja0Jsb2NrCQBoAgAeAKALAApoZWlyUHViS2V5ASAaFa4tDyIv1uhzDfwRR/IHtg7qNN7P3pYq2N1IFBp+EAAMdW5sb2NrQmxvY2syCQBoAgBaAKALABJQdXp6bGVNYXN0ZXJQdWJLZXkBIDs1TW4/n774VJyWRAeAVqsv4hNgRcR78j8XQ/RCBSZdAAxrZXlBY3RpdmF0ZWQCFUFjdGl2YXRlZCBibG9ja2hlaWdodAASa2V5U3VycGx1c1JlY2VpdmVkAhxzdXJwbHVzIHJlY2VpdmVkIGluIHdhdmVsZXRzABNrZXlXYXZlbGV0c1JlY2VpdmVkAiB0b3RhbCBXQVZFUyByZWNlaXZlZCBpbiB3YXZlbGV0cwAVa2V5V2F2ZWxldHNSZWNlaXZlZEJUAil0b3RhbCB3YXZlbGV0cyByZWNlaXZlZCBmb3IgYmFzZSB0cmVhc3VyeQASa2V5V2F2ZWxldHNQYWlkT3V0AiB0b3RhbCBXQVZFUyBwYWlkIG91dCBpbiB3YXZlbGV0cwAGa2V5Uk9JAhBST0kgYmFzaXMgcG9pbnRzABZrZXlXaGlybHBvb2xJc3N1ZVByaWNlAiFXSElSTFBPT0wgaXNzdWUgcHJpY2UgaW4gd2F2ZWxldHMAEGJ1cm54dG5QUFRwb29sSWQBGgFX9UZoJ4ANaN9OJnV6tKHTKDHgCb/1eXk3AAxwcm9qZWN0T3duZXIBGgFXjh3mUco4I87DkcPEVovVg9NviFb/Nt0LAA93aGlybHBvb2xQb29sSWQBGgFXCUhUqJi1/8xKRtsS/UvJkxlGN0OYh9fNAAl3aGlybHBvb2wBIAnOgNqkhGEBAxbRwocUXSVMmBXtucPLIo6Y3v+QralHAA93aGlybHBvb2xTdHJpbmcJANgEAQEgWeON3MK1I7pKFNzE0K8UCeZk5gS+JQYLJk7lUG2XWccABXdhdmVzAQQTq9kzAAd1c2R0ZXJjASCE2nqyCAM/TtG7yo7ui5O8yYLdC136B5ao1CP5qA//uQAHdXNkY2VyYwEg8b90j2kCa66vzjuwb/Nd8MVKoTFsVrfc+ipKoeuRGkkAB3VzZHRic2MBIIeFKhRdvRvgacOk2tYbd0/cBQSbrAXfQbCvgMBJMOmiAAd1c2RjYnNjASAvN5TEMA7UHoYvTQ14Xf3kXkI8Q97mJBxq1GB3huvltQAHYnVybnh0bgEgJE91eWp+Mzm4+wz/hKlxXF7KLd4zoMRdafnqRBHsTFQAA2V0aAEgJR76/9ghyXCe+8C03j63q4aeBTtm79wH/FHj9agzKHIAA2JuYgEgS7ep4jwDLeZJ/TwoM/wRUkbi6v6x+mu9cBafRBfVHhwABHdidGMBIBKeo3EHNGSP6mN2enCiK9cwBs75vPQVGctmd0xybol/AARidGNiASDIlsraYoy6SPYFNHcPBbtsEP/v2GRaY5157d4CGOemoQAEZWFzdAEgVoJP4wutz64pn/F3h50Vd/r+QUj98n3dRjyfnx8R03QABnN0ZWFzdAEg4Tj7DL+1BlqSS0fgEtOD/O7RI9SQqBlxFRrcq0CylDYABnN3YXZlcwEgCB/I9xYw7VHCKRvsrBqP/JBxHFk4LeshgbA3QfBF0UoABHN1cmYBIJLR9EriEQEr9H7q3iGOPcX7yfJ9zoey7VIZ8DpOJFj1AAtwb29sYm9vc3RTQwEaAVdJth4Q36ANT9jV0A+j44S32V46KbMRqawAB1BMX01haW4JAQdBZGRyZXNzAQEaAVcglFxKrc/0SDk7iECzv9vujFCgp2rP2ugAB1BMX0RlZmkJAQdBZGRyZXNzAQEaAVcZCzuPP83F9QBSQ7jrpozIrL8UOTE+JL4ABlBMX0xvdwkBB0FkZHJlc3MBARoBV65gFNJmcAzwP9x0xdJ05hq+qeBSweoLkAAKRUFTVF9zdGFrZQkBB0FkZHJlc3MBARoBVwh0qdnDd/GCffeig0jz65uzT/yIPOsXbwANV1hfV0FWRVNfRUFTVAkBB0FkZHJlc3MBARoBV7XCP+dwv1AcUXW5CmJm9PY+3NzVnaTo1AAMU1dBVkVTX3N0YWtlCQEHQWRkcmVzcwEBGgFXfcl7kxR5/+dR8bFKx2/5ah2AlUfPWCN+AAxXWF9FVEhfV0FWRVMJAQdBZGRyZXNzAQEaAVcLgNUSD01KXiUxquVDz7RZ2COjQ9sP68EAC3dhdmVzSW5Qb29sCQENdHJ5R2V0SW50ZWdlcgIJAQdBZGRyZXNzAQUQYnVybnh0blBQVHBvb2xJZAkArAICCQCsAgICB2dsb2JhbF8JANgEAQUFd2F2ZXMCCF9iYWxhbmNlAAxwcm9qZWN0U3Rha2UJAQ10cnlHZXRJbnRlZ2VyAgkBB0FkZHJlc3MBBRBidXJueHRuUFBUcG9vbElkCQCsAgIJAKUIAQUEdGhpcwIMX2luZGV4U3Rha2VkAAp0b3RhbFN0YWtlCQENdHJ5R2V0SW50ZWdlcgIJAQdBZGRyZXNzAQUQYnVybnh0blBQVHBvb2xJZAIXZ2xvYmFsX3Bvb2xUb2tlbl9hbW91bnQBCFBMX3ZhbHVlAgtkQXBwQWRkcmVzcwVhc3NldAkAawMJAQ10cnlHZXRJbnRlZ2VyAgULZEFwcEFkZHJlc3MJAKwCAgkArAICCQClCAEFBHRoaXMCCl9zdXBwbGllZF8JANgEAQUFYXNzZXQJAQ10cnlHZXRJbnRlZ2VyAgULZEFwcEFkZHJlc3MJAKwCAgkA2AQBBQVhc3NldAIGX3NSYXRlBQNkMTYBCF9sb2FkSW50AgRrZXlfCGRlZmF1bHRfBAckbWF0Y2gwCQCaCAIFDFNXQVZFU19zdGFrZQUEa2V5XwMJAAECBQckbWF0Y2gwAgNJbnQEAWEFByRtYXRjaDAFAWEFCGRlZmF1bHRfAQtfbG9hZEJpZ0ludAIEa2V5XwhkZWZhdWx0XwQHJG1hdGNoMAkAnAgCBQxTV0FWRVNfc3Rha2UFBGtleV8DCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQBYQUHJG1hdGNoMAkAngMBBQFhBQhkZWZhdWx0XwAIbGFzdFJhdGUJAQtfbG9hZEJpZ0ludAICCUxBU1RfUkFURQkAtgIBAICglKWNHQALY3VycmVudFJhdGUJAQtfbG9hZEJpZ0ludAICDENVUlJFTlRfUkFURQkAtgIBAAAACmxhc3RIZWlnaHQJAQhfbG9hZEludAICC0xBU1RfSEVJR0hUAAAADHRhcmdldEhlaWdodAkAlwMBCQDMCAIJAQhfbG9hZEludAICDVRBUkdFVF9IRUlHSFQAAAkAzAgCBQZoZWlnaHQFA25pbAAPbGFzdFJhdGVVcGRhdGVkCQC3AgIFCGxhc3RSYXRlCQC5AgIFC2N1cnJlbnRSYXRlCQC2AgEJAGUCBQx0YXJnZXRIZWlnaHQFCmxhc3RIZWlnaHQACmJhc2VBbW91bnQJAKADAQkAvQIECQC2AgEJAPAHAgUNV1hfV0FWRVNfRUFTVAUGc3dhdmVzBQ9sYXN0UmF0ZVVwZGF0ZWQJALYCAQCAoJSljR0FBUZMT09SAAtiYXNlQW1vdW50MgkAoAMBCQC9AgQJALYCAQkA8AcCBQxXWF9FVEhfV0FWRVMFBnN3YXZlcwUPbGFzdFJhdGVVcGRhdGVkCQC2AgEAgKCUpY0dBQVGTE9PUgAJd2F2ZXNJbldYCQBkAggJAO8HAQUNV1hfV0FWRVNfRUFTVAdyZWd1bGFyBQpiYXNlQW1vdW50AAhlYXN0SW5XWAkA8AcCBQ1XWF9XQVZFU19FQVNUBQRlYXN0AAl3YXZlc0Vhc3QJAGsDCQBoAgUCZDgAZAUIZWFzdEluV1gFCXdhdmVzSW5XWAAKd2F2ZXMySW5XWAkAZAIICQDvBwEFDFdYX0VUSF9XQVZFUwdyZWd1bGFyBQtiYXNlQW1vdW50MgAHZXRoSW5XWAkA8AcCBQxXWF9FVEhfV0FWRVMFA2V0aAAIZXRoV2F2ZXMJAGsDBQJkOAUKd2F2ZXMySW5XWAUHZXRoSW5XWAAQd2F2ZXNJbldoaXJscG9vbAkBDXRyeUdldEludGVnZXICCQEHQWRkcmVzcwEFD3doaXJscG9vbFBvb2xJZAkArAICCQCsAgICB2dsb2JhbF8JANgEAQUFd2F2ZXMCCF9iYWxhbmNlABB3aGlybEluV2hpcmxwb29sCQENdHJ5R2V0SW50ZWdlcgIJAQdBZGRyZXNzAQUPd2hpcmxwb29sUG9vbElkCQCsAgIJAKwCAgIHZ2xvYmFsXwUPd2hpcmxwb29sU3RyaW5nAghfYmFsYW5jZQARcHJvamVjdFN0YWtlV2hpcmwJAQ10cnlHZXRJbnRlZ2VyAgkBB0FkZHJlc3MBBQ93aGlybHBvb2xQb29sSWQJAKwCAgkApQgBBQR0aGlzAgxfaW5kZXhTdGFrZWQAD3RvdGFsU3Rha2VXaGlybAkBDXRyeUdldEludGVnZXICCQEHQWRkcmVzcwEFD3doaXJscG9vbFBvb2xJZAIXZ2xvYmFsX3Bvb2xUb2tlbl9hbW91bnQADXN0RWFzdEluV2F2ZXMJAGgCCQBrAwkAaQIJAG4ECQDwBwIFBHRoaXMFBnN0ZWFzdAkBDXRyeUdldEludGVnZXICBQpFQVNUX3N0YWtlAgglc19fcmF0ZQCAoJSljR0FCEhBTEZFVkVOAGQFAmQ4BQl3YXZlc0Vhc3QAZAANZWFzdEluU3Rha2luZwkAaQIJAG4ECQDwBwIFBHRoaXMFBnN0ZWFzdAkBDXRyeUdldEludGVnZXICBQpFQVNUX3N0YWtlAgglc19fcmF0ZQCAoJSljR0FCEhBTEZFVkVOAGQADWtleVZhdWx0QXNzZXQJAQx0cnlHZXRTdHJpbmcCCQEHQWRkcmVzcwEBGgFX2uOuefvK+c/jAzQhEVGadt14ZVxGW3IYCQCsAgIJAKwCAgIPJXMlcyVzX192YXVsdF9fCQClCAEFBHRoaXMCB19fV0FWRVMAC1dBVkVTaW5FQVNUCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgkAtQkCBQ1rZXlWYXVsdEFzc2V0AgJfXwACAAtkQXBwYWRkcmVzcwkBB0FkZHJlc3MBARoBV6/jkM1C/fh9Eb9nLjCmpdUnA6Fup99jWQAJRVRIYXRva2VuCQENdHJ5R2V0SW50ZWdlcgIFC2RBcHBhZGRyZXNzCQCsAgIJAKUIAQUEdGhpcwIOX2FUb2tlbkJhbGFuY2UADkVUSGF0b2tlblRvdGFsCQENdHJ5R2V0SW50ZWdlcgIFC2RBcHBhZGRyZXNzAhFhVG9rZW5DaXJjdWxhdGlvbgAKcmVzZXJ2ZVN0cgkBDHRyeUdldFN0cmluZwIFC2RBcHBhZGRyZXNzAhFyZXNlcnZlR2xvYmFsRGF0YQAHZ2V0MVN0cgkAkQMCCQC1CQIFCnJlc2VydmVTdHICAXwAAQAIc3RyVG9JbnQJAQ1wYXJzZUludFZhbHVlAQUHZ2V0MVN0cgAPRVRIdG90YWxSZXNlcnZlCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgkAtQkCCQEMdHJ5R2V0U3RyaW5nAgULZEFwcGFkZHJlc3MCEXJlc2VydmVHbG9iYWxEYXRhAgF8AAEACkVUSGluVmlyZXMJAGsDBQlFVEhhdG9rZW4FD0VUSHRvdGFsUmVzZXJ2ZQUORVRIYXRva2VuVG90YWwAEkVUSGluVmlyZXNXYXZlbGV0cwkAawMFCkVUSGluVmlyZXMFCGV0aFdhdmVzBQJkOAAKdHZsSW5XYXZlcwkAZAIJAGQCCQBrAwkAaAIFC3dhdmVzSW5Qb29sAAoFDHByb2plY3RTdGFrZQUKdG90YWxTdGFrZQkAawMJAGgCBRB3YXZlc0luV2hpcmxwb29sAAoFEXByb2plY3RTdGFrZVdoaXJsBQ90b3RhbFN0YWtlV2hpcmwFEkVUSGluVmlyZXNXYXZlbGV0cwAHdG90YWxCVAULV0FWRVNpbkVBU1QADXRvdGFsVHJlYXN1cnkJAGQCBQd0b3RhbEJUBQp0dmxJbldhdmVzAA93aGlybHBvb2xTdXBwbHkEByRtYXRjaDAJAOwHAQUJd2hpcmxwb29sAwkAAQIFByRtYXRjaDACBUFzc2V0BAVhc3NldAUHJG1hdGNoMAgFBWFzc2V0CHF1YW50aXR5CQACAQIQQ2FuJ3QgZmluZCBhc3NldAAFcHJpY2UDCQBnAgkAZAIJAGsDCQBkAgUKdHZsSW5XYXZlcwkBDXRyeUdldEludGVnZXICBQR0aGlzBRJrZXlTdXJwbHVzUmVjZWl2ZWQFAmQ4BQ93aGlybHBvb2xTdXBwbHkFAmQ4CQENdHJ5R2V0SW50ZWdlcgIFBHRoaXMFFmtleVdoaXJscG9vbElzc3VlUHJpY2UJAGQCCQBrAwkAZAIFCnR2bEluV2F2ZXMJAQ10cnlHZXRJbnRlZ2VyAgUEdGhpcwUSa2V5U3VycGx1c1JlY2VpdmVkBQJkOAUPd2hpcmxwb29sU3VwcGx5BQJkOAkBDXRyeUdldEludGVnZXICBQR0aGlzBRZrZXlXaGlybHBvb2xJc3N1ZVByaWNlCgFpARVidXlXSElSTFBPT0x3aXRoV0FWRVMABBZXaGlybHBvb2xCYWxhbmNlQmVmb3JlCQDwBwIFBHRoaXMFCXdoaXJscG9vbAMJAAACBRZXaGlybHBvb2xCYWxhbmNlQmVmb3JlBRZXaGlybHBvb2xCYWxhbmNlQmVmb3JlBANwbXQJAQV2YWx1ZQEJAJEDAggFAWkIcGF5bWVudHMAAAQHc3VycGx1cwkAawMJAGUCBQVwcmljZQUCZDgIBQNwbXQGYW1vdW50BQJkOAQLSXNzdWVBbW91bnQDCQBnAggFA3BtdAZhbW91bnQJAGsDCAUDcG10BmFtb3VudAUCZDgFBXByaWNlCQBrAwgFA3BtdAZhbW91bnQFAmQ4BQVwcmljZQkAAgECMHBsZWFzZSBjb250YWN0IHByb2plY3Qgb3duZXI6IGlzc3VlIGFtb3VudCBlcnJvcgQNY2xlYW5BbW91bnRJbgkAZQIIBQNwbXQGYW1vdW50CQBrAwgFA3BtdAZhbW91bnQAyAEAkE4ECUFtb3VudE91dAkAbgQFEHdoaXJsSW5XaGlybHBvb2wJAGUCCQBoAgUCZDgFAmQ4CQCgAwEJAHYGCQC9AgQJALYCAQUQd2F2ZXNJbldoaXJscG9vbAkAtgIBCQBoAgUCZDgFAmQ4CQC2AgEJAGQCBRB3YXZlc0luV2hpcmxwb29sBQ1jbGVhbkFtb3VudEluBQZIQUxGVVAAEAkAtgIBCQBrAwCgjQYAkE4AoPc2AAQAEAUHQ0VJTElORwkAaAIFAmQ4BQJkOAUERE9XTgMJAGYCCQBpAgUCZDgAFAgFA3BtdAZhbW91bnQJAAIBAhptaW5pbXVtIHBheW1lbnQgMC4wNSBXQVZFUwMJAQIhPQIIBQNwbXQHYXNzZXRJZAUEdW5pdAkAAgECF2F0dGFjaCBXQVZFUyB0b2tlbiBvbmx5BANidXkDCQBmAgUJQW1vdW50T3V0BQtJc3N1ZUFtb3VudAkA/AcECQEHQWRkcmVzcwEFD3doaXJscG9vbFBvb2xJZAIEc3dhcAkAzAgCBQ93aGlybHBvb2xTdHJpbmcJAMwIAgkAZAIFC0lzc3VlQW1vdW50AAEFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUEdW5pdAgFA3BtdAZhbW91bnQFA25pbAUEdW5pdAMJAAACBQNidXkFA2J1eQQVV2hpcmxwb29sQmFsYW5jZUFmdGVyCQDwBwIFBHRoaXMFCXdoaXJscG9vbAQRV2hpcmxwb29sRnJvbVN3YXAJAGUCBRVXaGlybHBvb2xCYWxhbmNlQWZ0ZXIFFldoaXJscG9vbEJhbGFuY2VCZWZvcmUJAMwIAgkBB1JlaXNzdWUDBQl3aGlybHBvb2wDCQBnAgULSXNzdWVBbW91bnQFCUFtb3VudE91dAULSXNzdWVBbW91bnQAAAYJAMwIAgMJAGYCBQlBbW91bnRPdXQFC0lzc3VlQW1vdW50CQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFEVdoaXJscG9vbEZyb21Td2FwBQl3aGlybHBvb2wJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgULSXNzdWVBbW91bnQFCXdoaXJscG9vbAkAzAgCCQEMSW50ZWdlckVudHJ5AgUWa2V5V2hpcmxwb29sSXNzdWVQcmljZQUFcHJpY2UJAMwIAgkBDEludGVnZXJFbnRyeQIDCQBmAgUJQW1vdW50T3V0BQtJc3N1ZUFtb3VudAIVcHJpY2UgV0hJUkxQT09ML1dBVkVTAiBXSElSTFBPT0wvV0FWRVMgbWlkIG1hcmtldCBwcmljZQMJAGYCBQlBbW91bnRPdXQFC0lzc3VlQW1vdW50CQBrAwUCZDgIBQNwbXQGYW1vdW50BRFXaGlybHBvb2xGcm9tU3dhcAkAawMFAmQ4CQBoAgUQd2F2ZXNJbldoaXJscG9vbAAJBRB3aGlybEluV2hpcmxwb29sCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRNrZXlXYXZlbGV0c1JlY2VpdmVkAwkAZwIFC0lzc3VlQW1vdW50BQlBbW91bnRPdXQJAGQCCAUDcG10BmFtb3VudAkBDXRyeUdldEludGVnZXICBQR0aGlzBRNrZXlXYXZlbGV0c1JlY2VpdmVkCQENdHJ5R2V0SW50ZWdlcgIFBHRoaXMFE2tleVdhdmVsZXRzUmVjZWl2ZWQJAMwIAgkBDEludGVnZXJFbnRyeQIFE2tleVdhdmVsZXRzUmVjZWl2ZWQDCQBnAgULSXNzdWVBbW91bnQFCUFtb3VudE91dAkAZAIJAGUCCAUDcG10BmFtb3VudAUHc3VycGx1cwkBDXRyeUdldEludGVnZXICBQR0aGlzBRNrZXlXYXZlbGV0c1JlY2VpdmVkCQENdHJ5R2V0SW50ZWdlcgIFBHRoaXMFE2tleVdhdmVsZXRzUmVjZWl2ZWQJAMwIAgkBDEludGVnZXJFbnRyeQIFEmtleVN1cnBsdXNSZWNlaXZlZAMJAGYCBQlBbW91bnRPdXQFC0lzc3VlQW1vdW50CQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzBRJrZXlTdXJwbHVzUmVjZWl2ZWQJAGQCBQdzdXJwbHVzCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzBRJrZXlTdXJwbHVzUmVjZWl2ZWQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARVwcmljZUFuZFRyZWFzdXJ5U3RhdHMACQDMCAIJAQxJbnRlZ2VyRW50cnkCAg9FVEgvV0FWRVMgcHJpY2UFCGV0aFdhdmVzCQDMCAIJAQxJbnRlZ2VyRW50cnkCAhZCVCBXQVZFUyBpbiBFQVNUIHZhdWx0BQtXQVZFU2luRUFTVAkAzAgCCQEMSW50ZWdlckVudHJ5AgIiU1QgQlVSTi1YVE4geCBQZXBlVGVhbSBpbiB3YXZlbGV0cwkAawMJAGgCBQt3YXZlc0luUG9vbAAKBQxwcm9qZWN0U3Rha2UFCnRvdGFsU3Rha2UJAMwIAgkBDEludGVnZXJFbnRyeQICHFNUIFdISVJMUE9PTCBBTU0gaW4gd2F2ZWxldHMJAGsDCQBoAgUQd2F2ZXNJbldoaXJscG9vbAAKBRFwcm9qZWN0U3Rha2VXaGlybAUPdG90YWxTdGFrZVdoaXJsCQDMCAIJAQxJbnRlZ2VyRW50cnkCAgdTVCB2RVRIBQpFVEhpblZpcmVzCQDMCAIJAQxJbnRlZ2VyRW50cnkCAhNTVCB2RVRIIGluIHdhdmVsZXRzBRJFVEhpblZpcmVzV2F2ZWxldHMJAMwIAgkBDEludGVnZXJFbnRyeQICFFRvdGFsIFNUIGluIHdhdmVsZXRzBQp0dmxJbldhdmVzCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRZrZXlXaGlybHBvb2xJc3N1ZVByaWNlBQVwcmljZQkAzAgCCQEMSW50ZWdlckVudHJ5AgIgV0hJUkxQT09ML1dBVkVTIG1pZCBtYXJrZXQgcHJpY2UJAGsDBQJkOAkAaAIFEHdhdmVzSW5XaGlybHBvb2wACQUQd2hpcmxJbldoaXJscG9vbAkAzAgCCQEMSW50ZWdlckVudHJ5AgIWV0hJUkxQT09MIHRvdGFsIHN1cHBseQUPd2hpcmxwb29sU3VwcGx5CQDMCAIJAQxJbnRlZ2VyRW50cnkCAg5Ub3RhbCB0cmVhc3VyeQUNdG90YWxUcmVhc3VyeQkAzAgCCQEMSW50ZWdlckVudHJ5AgINTkFWIFdISVJMUE9PTAkAawMFAmQ4BQ10b3RhbFRyZWFzdXJ5BQ93aGlybHBvb2xTdXBwbHkJAMwIAgkBDEludGVnZXJFbnRyeQIFE2tleVdhdmVsZXRzUmVjZWl2ZWQJAQ10cnlHZXRJbnRlZ2VyAgUEdGhpcwUTa2V5V2F2ZWxldHNSZWNlaXZlZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUSa2V5U3VycGx1c1JlY2VpdmVkCQENdHJ5R2V0SW50ZWdlcgIFBHRoaXMFEmtleVN1cnBsdXNSZWNlaXZlZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUTa2V5V2F2ZWxldHNSZWNlaXZlZAkBDXRyeUdldEludGVnZXICBQR0aGlzBRNrZXlXYXZlbGV0c1JlY2VpdmVkCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRJrZXlXYXZlbGV0c1BhaWRPdXQJAQ10cnlHZXRJbnRlZ2VyAgUEdGhpcwUSa2V5V2F2ZWxldHNQYWlkT3V0CQDMCAIJAQxJbnRlZ2VyRW50cnkCAhR0b3RhbCBXQVZFUyByZWNlaXZlZAkAaQIJAQ10cnlHZXRJbnRlZ2VyAgUEdGhpcwUTa2V5V2F2ZWxldHNSZWNlaXZlZAUCZDgJAMwIAgkBDEludGVnZXJFbnRyeQICF1RvdGFsIHRyZWFzdXJ5IGluIFdBVkVTCQBpAgUNdG90YWxUcmVhc3VyeQUCZDgJAMwIAgkBDEludGVnZXJFbnRyeQICGXN1cnBsdXMgcmVjZWl2ZWQgaW4gV0FWRVMJAGkCCQENdHJ5R2V0SW50ZWdlcgIFBHRoaXMFEmtleVN1cnBsdXNSZWNlaXZlZAUCZDgJAMwIAgkBDEludGVnZXJFbnRyeQICJnRvdGFsIFdBVkVTIHJlY2VpdmVkIGZvciBiYXNlIHRyZWFzdXJ5CQBpAgkBDXRyeUdldEludGVnZXICBQR0aGlzBRNrZXlXYXZlbGV0c1JlY2VpdmVkBQJkOAkAzAgCCQEMSW50ZWdlckVudHJ5AgIddG90YWwgV0FWRVMgcGFpZCBvdXQgaW4gV0FWRVMJAGkCCQENdHJ5R2V0SW50ZWdlcgIFBHRoaXMFEmtleVdhdmVsZXRzUGFpZE91dAUCZDgJAMwIAgkBDEludGVnZXJFbnRyeQIFBmtleVJPSQkBDXRyeUdldEludGVnZXICBQR0aGlzBQZrZXlST0kFA25pbAFpAQxib29zdFBvb2xBUFkAAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQIcYWNjZXNzIG9ubHkgYnkgcHJvamVjdCBvd25lcgQHYmFsYW5jZQMJAGYCBQJkOAgJAO8HAQUEdGhpcwlhdmFpbGFibGUJAAIBAhBub3QgZW5vdWdoIFdBVkVTCQBlAggJAO8HAQUEdGhpcwlhdmFpbGFibGUFAmQ4BAdib29zdDgwCQBrAwUHYmFsYW5jZQBQAGQDCQAAAgUHYm9vc3Q4MAUHYm9vc3Q4MAQLYW1vdW50Qm9vc3QJAGsDBQdib29zdDgwAFAAZAMJAAACBQthbW91bnRCb29zdAULYW1vdW50Qm9vc3QEC2Ftb3VudE93bmVyCQBrAwUHYm9vc3Q4MAAUAGQDCQAAAgULYW1vdW50T3duZXIFC2Ftb3VudE93bmVyBAVib29zdAkA/AcECQEHQWRkcmVzcwEFC3Bvb2xib29zdFNDAgthZGRCb29zdGluZwkAzAgCCQDYBAEFD3doaXJscG9vbFBvb2xJZAkAzAgCAAcFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUEdW5pdAULYW1vdW50Qm9vc3QFA25pbAMJAAACBQVib29zdAUFYm9vc3QJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBB0FkZHJlc3MBBQxwcm9qZWN0T3duZXIFC2Ftb3VudE93bmVyBQR1bml0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBRJrZXlXYXZlbGV0c1BhaWRPdXQJAGQCBQthbW91bnRCb29zdAkBDXRyeUdldEludGVnZXICBQR0aGlzBRJrZXlXYXZlbGV0c1BhaWRPdXQJAMwIAgkBDEludGVnZXJFbnRyeQIFBmtleVJPSQkAawMJAQ10cnlHZXRJbnRlZ2VyAgUEdGhpcwUSa2V5V2F2ZWxldHNQYWlkT3V0AJBOCQENdHJ5R2V0SW50ZWdlcgIFBHRoaXMFE2tleVdhdmVsZXRzUmVjZWl2ZWQJAMwIAgkBDEludGVnZXJFbnRyeQIFDGtleUFjdGl2YXRlZAUGaGVpZ2h0BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEQYm9vc3RQb29sQVBZX2FsbAADCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhxhY2Nlc3Mgb25seSBieSBwcm9qZWN0IG93bmVyBAdiYWxhbmNlAwkAZgIFAmQ4CAkA7wcBBQR0aGlzCWF2YWlsYWJsZQkAAgECEG5vdCBlbm91Z2ggV0FWRVMJAGUCCAkA7wcBBQR0aGlzCWF2YWlsYWJsZQUCZDgEC2Ftb3VudEJvb3N0CQBrAwUHYmFsYW5jZQBQAGQDCQAAAgULYW1vdW50Qm9vc3QFC2Ftb3VudEJvb3N0BAthbW91bnRPd25lcgkAawMFB2JhbGFuY2UAFABkAwkAAAIFC2Ftb3VudE93bmVyBQthbW91bnRPd25lcgQFYm9vc3QJAPwHBAkBB0FkZHJlc3MBBQtwb29sYm9vc3RTQwILYWRkQm9vc3RpbmcJAMwIAgkA2AQBBQ93aGlybHBvb2xQb29sSWQJAMwIAgAHBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFBHVuaXQFC2Ftb3VudEJvb3N0BQNuaWwDCQAAAgUFYm9vc3QFBWJvb3N0CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJAQdBZGRyZXNzAQUMcHJvamVjdE93bmVyBQthbW91bnRPd25lcgUEdW5pdAkAzAgCCQEMSW50ZWdlckVudHJ5AgUSa2V5V2F2ZWxldHNQYWlkT3V0CQBkAgULYW1vdW50Qm9vc3QJAQ10cnlHZXRJbnRlZ2VyAgUEdGhpcwUSa2V5V2F2ZWxldHNQYWlkT3V0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQZrZXlST0kJAGsDCQENdHJ5R2V0SW50ZWdlcgIFBHRoaXMFEmtleVdhdmVsZXRzUGFpZE91dACQTgkBDXRyeUdldEludGVnZXICBQR0aGlzBRNrZXlXYXZlbGV0c1JlY2VpdmVkCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQxrZXlBY3RpdmF0ZWQFBmhlaWdodAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBD3RyYW5zZmVyUG9vbEFQWQADCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhxhY2Nlc3Mgb25seSBieSBwcm9qZWN0IG93bmVyBAdiYWxhbmNlAwkAZgIFAmQ4CAkA7wcBBQR0aGlzCWF2YWlsYWJsZQkAAgECEG5vdCBlbm91Z2ggV0FWRVMJAGUCCAkA7wcBBQR0aGlzCWF2YWlsYWJsZQUCZDgEB2Jvb3N0ODAJAGsDBQdiYWxhbmNlAFAAZAMJAAACBQdib29zdDgwBQdib29zdDgwBAthbW91bnRCb29zdAkAawMFB2Jvb3N0ODAAUABkAwkAAAIFC2Ftb3VudEJvb3N0BQthbW91bnRCb29zdAQLYW1vdW50T3duZXIJAGsDBQdib29zdDgwABQAZAMJAAACBQthbW91bnRPd25lcgULYW1vdW50T3duZXIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBB0FkZHJlc3MBBQ93aGlybHBvb2xQb29sSWQFC2Ftb3VudEJvb3N0BQR1bml0CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJAQdBZGRyZXNzAQUMcHJvamVjdE93bmVyBQthbW91bnRPd25lcgUEdW5pdAkAzAgCCQEMSW50ZWdlckVudHJ5AgUSa2V5V2F2ZWxldHNQYWlkT3V0CQBkAgULYW1vdW50Qm9vc3QJAQ10cnlHZXRJbnRlZ2VyAgUEdGhpcwUSa2V5V2F2ZWxldHNQYWlkT3V0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQZrZXlST0kJAGsDCQENdHJ5R2V0SW50ZWdlcgIFBHRoaXMFEmtleVdhdmVsZXRzUGFpZE91dACQTgkBDXRyeUdldEludGVnZXICBQR0aGlzBRNrZXlXYXZlbGV0c1JlY2VpdmVkCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQxrZXlBY3RpdmF0ZWQFBmhlaWdodAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBE3RyYW5zZmVyUG9vbEFQWV9hbGwAAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQIcYWNjZXNzIG9ubHkgYnkgcHJvamVjdCBvd25lcgQHYmFsYW5jZQMJAGYCBQJkOAgJAO8HAQUEdGhpcwlhdmFpbGFibGUJAAIBAhBub3QgZW5vdWdoIFdBVkVTCQBlAggJAO8HAQUEdGhpcwlhdmFpbGFibGUFAmQ4BAthbW91bnRCb29zdAkAawMFB2JhbGFuY2UAUABkAwkAAAIFC2Ftb3VudEJvb3N0BQthbW91bnRCb29zdAQLYW1vdW50T3duZXIJAGsDBQdiYWxhbmNlABQAZAMJAAACBQthbW91bnRPd25lcgULYW1vdW50T3duZXIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBB0FkZHJlc3MBBQ93aGlybHBvb2xQb29sSWQFC2Ftb3VudEJvb3N0BQR1bml0CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJAQdBZGRyZXNzAQUMcHJvamVjdE93bmVyBQthbW91bnRPd25lcgUEdW5pdAkAzAgCCQEMSW50ZWdlckVudHJ5AgUSa2V5V2F2ZWxldHNQYWlkT3V0CQBkAgULYW1vdW50Qm9vc3QJAQ10cnlHZXRJbnRlZ2VyAgUEdGhpcwUSa2V5V2F2ZWxldHNQYWlkT3V0CQDMCAIJAQxJbnRlZ2VyRW50cnkCBQZrZXlST0kJAGsDCQENdHJ5R2V0SW50ZWdlcgIFBHRoaXMFEmtleVdhdmVsZXRzUGFpZE91dACQTgkBDXRyeUdldEludGVnZXICBQR0aGlzBRNrZXlXYXZlbGV0c1JlY2VpdmVkCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQxrZXlBY3RpdmF0ZWQFBmhlaWdodAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBE3Bvb2xPbmVUb2tlblN1cnBsdXMAAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQIcYWNjZXNzIG9ubHkgYnkgcHJvamVjdCBvd25lcgQNc3VycGx1c0Ftb3VudAkBDXRyeUdldEludGVnZXICBQR0aGlzBRJrZXlTdXJwbHVzUmVjZWl2ZWQEE1Bvb2xPbmVUb2tlblN1cnBsdXMJAPwHBAkBB0FkZHJlc3MBARoBV/0lw71OYZRB77peEmOPxTlvSbWIOvXpbQIhZ2VuZXJhdGVJbmRleFdpdGhPbmVUb2tlbkFuZFN0YWtlCQDMCAIJANgEAQUQYnVybnh0blBQVHBvb2xJZAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQR1bml0BQ1zdXJwbHVzQW1vdW50BQNuaWwDCQAAAgUTUG9vbE9uZVRva2VuU3VycGx1cwUTUG9vbE9uZVRva2VuU3VycGx1cwkAzAgCCQEMSW50ZWdlckVudHJ5AgUSa2V5U3VycGx1c1JlY2VpdmVkCQBlAgkBDXRyeUdldEludGVnZXICBQR0aGlzBRJrZXlTdXJwbHVzUmVjZWl2ZWQFDXN1cnBsdXNBbW91bnQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQ9zdXJwbHVzSW52ZXN0ZWQBC2Ftb3VudFdBVkVTAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQIcYWNjZXNzIG9ubHkgYnkgcHJvamVjdCBvd25lcgQOaW52ZXN0ZWRBbW91bnQJAGgCBQthbW91bnRXQVZFUwUCZDgJAMwIAgkBDEludGVnZXJFbnRyeQIFEmtleVN1cnBsdXNSZWNlaXZlZAkAZQIJAQ10cnlHZXRJbnRlZ2VyAgUEdGhpcwUSa2V5U3VycGx1c1JlY2VpdmVkBQ5pbnZlc3RlZEFtb3VudAUDbmlsAWkBEmNoYW5nZUludGVnZXJFbnRyeQIJa2V5U3RyaW5nB2ludGVnZXIDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhxhY2Nlc3Mgb25seSBieSBwcm9qZWN0IG93bmVyCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQlrZXlTdHJpbmcFB2ludGVnZXIFA25pbAFpAQlhY3RpdmF0ZWQAAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQITeW91IGFyZSBub3QgYWxsb3dlZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUMa2V5QWN0aXZhdGVkBQZoZWlnaHQFA25pbAECdHgBBnZlcmlmeQADCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5BgMJAGYCCQBkAgkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwUMa2V5QWN0aXZhdGVkBQt1bmxvY2tCbG9jawUGaGVpZ2h0BwMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAFCmhlaXJQdWJLZXkGAwkAZgIJAGQCCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzBQxrZXlBY3RpdmF0ZWQFDHVubG9ja0Jsb2NrMgUGaGVpZ2h0BwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUSUHV6emxlTWFzdGVyUHViS2V5niSApA==", "height": 3925928, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 79Ch1ZbnU36vBpAxTEe9gWdvZodXYMDBhu4aTiLbPRc3 Next: BfjixFRijMbyFrua6ujJpJH7BoZ2hW1Ks42VKdBYqKtB Diff:
Old | New | Differences | |
---|---|---|---|
209 | 209 | let IssueAmount = if ((pmt.amount >= fraction(pmt.amount, d8, price))) | |
210 | 210 | then fraction(pmt.amount, d8, price) | |
211 | 211 | else throw("please contact project owner: issue amount error") | |
212 | - | let supplyAmount = ((pmt.amount - surplus) / 3) | |
213 | 212 | let cleanAmountIn = (pmt.amount - fraction(pmt.amount, 200, 10000)) | |
214 | 213 | let AmountOut = fraction(whirlInWhirlpool, ((d8 * d8) - toInt(pow(fraction(toBigInt(wavesInWhirlpool), toBigInt((d8 * d8)), toBigInt((wavesInWhirlpool + cleanAmountIn)), HALFUP), 16, toBigInt(fraction(100000, 10000, 900000)), 4, 16, CEILING))), (d8 * d8), DOWN) | |
215 | - | if ((pmt.assetId != unit)) | |
216 | - | then throw("attach WAVES token only") | |
217 | - | else { | |
218 | - | let buy = if ((AmountOut > IssueAmount)) | |
219 | - | then invoke(Address(whirlpoolPoolId), "swap", [whirlpoolString, (IssueAmount + 1)], [AttachedPayment(unit, pmt.amount)]) | |
220 | - | else unit | |
221 | - | if ((buy == buy)) | |
222 | - | then { | |
223 | - | let WhirlpoolBalanceAfter = assetBalance(this, whirlpool) | |
224 | - | let WhirlpoolFromSwap = (WhirlpoolBalanceAfter - WhirlpoolBalanceBefore) | |
214 | + | if (((d8 / 20) > pmt.amount)) | |
215 | + | then throw("minimum payment 0.05 WAVES") | |
216 | + | else if ((pmt.assetId != unit)) | |
217 | + | then throw("attach WAVES token only") | |
218 | + | else { | |
219 | + | let buy = if ((AmountOut > IssueAmount)) | |
220 | + | then invoke(Address(whirlpoolPoolId), "swap", [whirlpoolString, (IssueAmount + 1)], [AttachedPayment(unit, pmt.amount)]) | |
221 | + | else unit | |
222 | + | if ((buy == buy)) | |
223 | + | then { | |
224 | + | let WhirlpoolBalanceAfter = assetBalance(this, whirlpool) | |
225 | + | let WhirlpoolFromSwap = (WhirlpoolBalanceAfter - WhirlpoolBalanceBefore) | |
225 | 226 | [Reissue(whirlpool, if ((IssueAmount >= AmountOut)) | |
226 | - | then IssueAmount | |
227 | - | else 0, true), if ((AmountOut > IssueAmount)) | |
228 | - | then ScriptTransfer(i.caller, WhirlpoolFromSwap, whirlpool) | |
229 | - | else ScriptTransfer(i.caller, IssueAmount, whirlpool), IntegerEntry(keyWhirlpoolIssuePrice, price), IntegerEntry(if ((AmountOut > IssueAmount)) | |
230 | - | then "price WHIRLPOOL/WAVES" | |
231 | - | else "WHIRLPOOL/WAVES mid market price", if ((AmountOut > IssueAmount)) | |
232 | - | then fraction(d8, pmt.amount, WhirlpoolFromSwap) | |
233 | - | else fraction(d8, (wavesInWhirlpool * 9), whirlInWhirlpool)), IntegerEntry(keyWaveletsReceived, if ((IssueAmount >= AmountOut)) | |
234 | - | then (pmt.amount + tryGetInteger(this, keyWaveletsReceived)) | |
235 | - | else tryGetInteger(this, keyWaveletsReceived)), IntegerEntry(keyWaveletsReceived, if ((IssueAmount >= AmountOut)) | |
236 | - | then ((pmt.amount - surplus) + tryGetInteger(this, keyWaveletsReceived)) | |
237 | - | else tryGetInteger(this, keyWaveletsReceived)), IntegerEntry(keySurplusReceived, if ((AmountOut > IssueAmount)) | |
238 | - | then getIntegerValue(this, keySurplusReceived) | |
239 | - | else (surplus + getIntegerValue(this, keySurplusReceived)))] | |
240 | - | } | |
241 | - | else throw("Strict value is not equal to itself.") | |
242 | - | } | |
227 | + | then IssueAmount | |
228 | + | else 0, true), if ((AmountOut > IssueAmount)) | |
229 | + | then ScriptTransfer(i.caller, WhirlpoolFromSwap, whirlpool) | |
230 | + | else ScriptTransfer(i.caller, IssueAmount, whirlpool), IntegerEntry(keyWhirlpoolIssuePrice, price), IntegerEntry(if ((AmountOut > IssueAmount)) | |
231 | + | then "price WHIRLPOOL/WAVES" | |
232 | + | else "WHIRLPOOL/WAVES mid market price", if ((AmountOut > IssueAmount)) | |
233 | + | then fraction(d8, pmt.amount, WhirlpoolFromSwap) | |
234 | + | else fraction(d8, (wavesInWhirlpool * 9), whirlInWhirlpool)), IntegerEntry(keyWaveletsReceived, if ((IssueAmount >= AmountOut)) | |
235 | + | then (pmt.amount + tryGetInteger(this, keyWaveletsReceived)) | |
236 | + | else tryGetInteger(this, keyWaveletsReceived)), IntegerEntry(keyWaveletsReceived, if ((IssueAmount >= AmountOut)) | |
237 | + | then ((pmt.amount - surplus) + tryGetInteger(this, keyWaveletsReceived)) | |
238 | + | else tryGetInteger(this, keyWaveletsReceived)), IntegerEntry(keySurplusReceived, if ((AmountOut > IssueAmount)) | |
239 | + | then getIntegerValue(this, keySurplusReceived) | |
240 | + | else (surplus + getIntegerValue(this, keySurplusReceived)))] | |
241 | + | } | |
242 | + | else throw("Strict value is not equal to itself.") | |
243 | + | } | |
243 | 244 | } | |
244 | 245 | else throw("Strict value is not equal to itself.") | |
245 | 246 | } |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | func tryGetInteger (address,key) = match getInteger(address, key) { | |
5 | 5 | case b: Int => | |
6 | 6 | b | |
7 | 7 | case _ => | |
8 | 8 | 0 | |
9 | 9 | } | |
10 | 10 | ||
11 | 11 | ||
12 | 12 | func tryGetString (address,key) = match getString(address, key) { | |
13 | 13 | case b: String => | |
14 | 14 | b | |
15 | 15 | case _ => | |
16 | 16 | "" | |
17 | 17 | } | |
18 | 18 | ||
19 | 19 | ||
20 | 20 | let d8 = 100000000 | |
21 | 21 | ||
22 | 22 | let d16 = (d8 * d8) | |
23 | 23 | ||
24 | 24 | let unlockBlock = (30 * 1440) | |
25 | 25 | ||
26 | 26 | let heirPubKey = base58'2kpmuzw1ZbrtgAN3BrR7vbEW1XrJoJKCstL7mf7XNf2P' | |
27 | 27 | ||
28 | 28 | let unlockBlock2 = (90 * 1440) | |
29 | 29 | ||
30 | 30 | let PuzzleMasterPubKey = base58'4z8CKSYQBKkzx7PBb5uBP1YPa6YAHRNTApW1sQVHT5eU' | |
31 | 31 | ||
32 | 32 | let keyActivated = "Activated blockheight" | |
33 | 33 | ||
34 | 34 | let keySurplusReceived = "surplus received in wavelets" | |
35 | 35 | ||
36 | 36 | let keyWaveletsReceived = "total WAVES received in wavelets" | |
37 | 37 | ||
38 | 38 | let keyWaveletsReceivedBT = "total wavelets received for base treasury" | |
39 | 39 | ||
40 | 40 | let keyWaveletsPaidOut = "total WAVES paid out in wavelets" | |
41 | 41 | ||
42 | 42 | let keyROI = "ROI basis points" | |
43 | 43 | ||
44 | 44 | let keyWhirlpoolIssuePrice = "WHIRLPOOL issue price in wavelets" | |
45 | 45 | ||
46 | 46 | let burnxtnPPTpoolId = base58'3PQHndCUVrv3wBuQjbvVP9SnGmfbfitGxfx' | |
47 | 47 | ||
48 | 48 | let projectOwner = base58'3PEtLVxDT8mxAh1SDAn8m7JTGNkdpkaFxBk' | |
49 | 49 | ||
50 | 50 | let whirlpoolPoolId = base58'3P2myTbd5zpEHcYmNpdWTp5gXS5B8tL1RCY' | |
51 | 51 | ||
52 | 52 | let whirlpool = base58'fHJWWsh2hZAc4Atv8VRhKy3jNbHLeMwQMsLpdaBY51Y' | |
53 | 53 | ||
54 | 54 | let whirlpoolString = toBase58String(base58'73tY3E6Gd5AWYmsuq8m8Kek7KnJNAYyS3GoveTbc6jCi') | |
55 | 55 | ||
56 | 56 | let waves = base58'WAVES' | |
57 | 57 | ||
58 | 58 | let usdterc = base58'9wc3LXNA4TEBsXyKtoLE9mrbDD7WMHXvXrCjZvabLAsi' | |
59 | 59 | ||
60 | 60 | let usdcerc = base58'HGgabTqUS8WtVFUJzfmrTDMgEccJuZLBPhFgQFxvnsoW' | |
61 | 61 | ||
62 | 62 | let usdtbsc = base58'A81p1LTRyoq2rDR2TNxB2dWYxsiNwCSSi8sXef2SEkwb' | |
63 | 63 | ||
64 | 64 | let usdcbsc = base58'4BKKSp6NoNcrFHyorZogDyctq1fq6w7114Ym1pw6HUtC' | |
65 | 65 | ||
66 | 66 | let burnxtn = base58'3SjxA2YLdfF9fTRbzLm9xFn27C6MW34W1YsdJ6Axefns' | |
67 | 67 | ||
68 | 68 | let eth = base58'3VuV5WTmDz47Dmdn3QpcYjzbSdipjQE4JMdNe1xZpX13' | |
69 | 69 | ||
70 | 70 | let bnb = base58'66a1br3BrkoaJgP7yEar9hJcSTvJPoH6PYBLqscXcMGo' | |
71 | 71 | ||
72 | 72 | let wbtc = base58'2Fge5HEBRD3XTeg7Xg3FW5yiB9HVJFQtMXiWMQo72Up6' | |
73 | 73 | ||
74 | 74 | let btcb = base58'EW1uGLVo21Wd9i2Rhq8o4VKDTCQTGCGXE8DqayHGrLg8' | |
75 | 75 | ||
76 | 76 | let east = base58'6phK22ztGBW127gUFmdMEHKB3CVd6ZhWox2WtwJkbqTq' | |
77 | 77 | ||
78 | 78 | let steast = base58'GAB8JowY9UANZ4TQy2TzJyhxjPqXX3DUrb2cdMWrrJus' | |
79 | 79 | ||
80 | 80 | let swaves = base58'YiNbofFzC17jEHHCMwrRcpy9MrrjabMMLZxg8g5xmf7' | |
81 | 81 | ||
82 | 82 | let surf = base58'At8D6NFFpheCbvKVnjVoeLL84Eo8NZn6ovManxfLaFWL' | |
83 | 83 | ||
84 | 84 | let poolboostSC = base58'3P8eeDzUnoDNbQjW617pAe76cEUDQsP1m1V' | |
85 | 85 | ||
86 | 86 | let PL_Main = Address(base58'3P4uA5etnZi4AmBabKinq2bMiWU8KcnHZdH') | |
87 | 87 | ||
88 | 88 | let PL_Defi = Address(base58'3P4DK5VzDwL3vfc5ahUEhtoe5ByZNyacJ3X') | |
89 | 89 | ||
90 | 90 | let PL_Low = Address(base58'3PHpuQUPVUoR3AYzFeJzeWJfYLsLTmWssVH') | |
91 | 91 | ||
92 | 92 | let EAST_stake = Address(base58'3P2hbtheN5apNppqqUK7L7qAwmRFXy91CNa') | |
93 | 93 | ||
94 | 94 | let WX_WAVES_EAST = Address(base58'3PJVwjfi2fF5Jv9AauayU6xLxrYBn8bpGH1') | |
95 | 95 | ||
96 | 96 | let SWAVES_stake = Address(base58'3PDPzZVLhN1EuzGy4xAxjjTVkawKDLEaHiV') | |
97 | 97 | ||
98 | 98 | let WX_ETH_WAVES = Address(base58'3P2yiVnK48evTLr8MAZWavpE4WA4fw1weQg') | |
99 | 99 | ||
100 | 100 | let wavesInPool = tryGetInteger(Address(burnxtnPPTpoolId), (("global_" + toBase58String(waves)) + "_balance")) | |
101 | 101 | ||
102 | 102 | let projectStake = tryGetInteger(Address(burnxtnPPTpoolId), (toString(this) + "_indexStaked")) | |
103 | 103 | ||
104 | 104 | let totalStake = tryGetInteger(Address(burnxtnPPTpoolId), "global_poolToken_amount") | |
105 | 105 | ||
106 | 106 | func PL_value (dAppAddress,asset) = fraction(tryGetInteger(dAppAddress, ((toString(this) + "_supplied_") + toBase58String(asset))), tryGetInteger(dAppAddress, (toBase58String(asset) + "_sRate")), d16) | |
107 | 107 | ||
108 | 108 | ||
109 | 109 | func _loadInt (key_,default_) = match getInteger(SWAVES_stake, key_) { | |
110 | 110 | case a: Int => | |
111 | 111 | a | |
112 | 112 | case _ => | |
113 | 113 | default_ | |
114 | 114 | } | |
115 | 115 | ||
116 | 116 | ||
117 | 117 | func _loadBigInt (key_,default_) = match getBinary(SWAVES_stake, key_) { | |
118 | 118 | case a: ByteVector => | |
119 | 119 | toBigInt(a) | |
120 | 120 | case _ => | |
121 | 121 | default_ | |
122 | 122 | } | |
123 | 123 | ||
124 | 124 | ||
125 | 125 | let lastRate = _loadBigInt("LAST_RATE", toBigInt(1000000000000)) | |
126 | 126 | ||
127 | 127 | let currentRate = _loadBigInt("CURRENT_RATE", toBigInt(0)) | |
128 | 128 | ||
129 | 129 | let lastHeight = _loadInt("LAST_HEIGHT", 0) | |
130 | 130 | ||
131 | 131 | let targetHeight = min([_loadInt("TARGET_HEIGHT", 0), height]) | |
132 | 132 | ||
133 | 133 | let lastRateUpdated = (lastRate + (currentRate * toBigInt((targetHeight - lastHeight)))) | |
134 | 134 | ||
135 | 135 | let baseAmount = toInt(fraction(toBigInt(assetBalance(WX_WAVES_EAST, swaves)), lastRateUpdated, toBigInt(1000000000000), FLOOR)) | |
136 | 136 | ||
137 | 137 | let baseAmount2 = toInt(fraction(toBigInt(assetBalance(WX_ETH_WAVES, swaves)), lastRateUpdated, toBigInt(1000000000000), FLOOR)) | |
138 | 138 | ||
139 | 139 | let wavesInWX = (wavesBalance(WX_WAVES_EAST).regular + baseAmount) | |
140 | 140 | ||
141 | 141 | let eastInWX = assetBalance(WX_WAVES_EAST, east) | |
142 | 142 | ||
143 | 143 | let wavesEast = fraction((d8 * 100), eastInWX, wavesInWX) | |
144 | 144 | ||
145 | 145 | let waves2InWX = (wavesBalance(WX_ETH_WAVES).regular + baseAmount2) | |
146 | 146 | ||
147 | 147 | let ethInWX = assetBalance(WX_ETH_WAVES, eth) | |
148 | 148 | ||
149 | 149 | let ethWaves = fraction(d8, waves2InWX, ethInWX) | |
150 | 150 | ||
151 | 151 | let wavesInWhirlpool = tryGetInteger(Address(whirlpoolPoolId), (("global_" + toBase58String(waves)) + "_balance")) | |
152 | 152 | ||
153 | 153 | let whirlInWhirlpool = tryGetInteger(Address(whirlpoolPoolId), (("global_" + whirlpoolString) + "_balance")) | |
154 | 154 | ||
155 | 155 | let projectStakeWhirl = tryGetInteger(Address(whirlpoolPoolId), (toString(this) + "_indexStaked")) | |
156 | 156 | ||
157 | 157 | let totalStakeWhirl = tryGetInteger(Address(whirlpoolPoolId), "global_poolToken_amount") | |
158 | 158 | ||
159 | 159 | let stEastInWaves = (fraction((fraction(assetBalance(this, steast), tryGetInteger(EAST_stake, "%s__rate"), 1000000000000, HALFEVEN) / 100), d8, wavesEast) * 100) | |
160 | 160 | ||
161 | 161 | let eastInStaking = (fraction(assetBalance(this, steast), tryGetInteger(EAST_stake, "%s__rate"), 1000000000000, HALFEVEN) / 100) | |
162 | 162 | ||
163 | 163 | let keyVaultAsset = tryGetString(Address(base58'3PMtGnf3LXiEG6isDQLq1xMDKUqjQGqNHLb'), (("%s%s%s__vault__" + toString(this)) + "__WAVES")) | |
164 | 164 | ||
165 | 165 | let WAVESinEAST = parseIntValue(split(keyVaultAsset, "__")[2]) | |
166 | 166 | ||
167 | 167 | let dAppaddress = Address(base58'3PHxubMUtynEY2AeHq3K1kUizRPN9HUC2rt') | |
168 | 168 | ||
169 | 169 | let ETHatoken = tryGetInteger(dAppaddress, (toString(this) + "_aTokenBalance")) | |
170 | 170 | ||
171 | 171 | let ETHatokenTotal = tryGetInteger(dAppaddress, "aTokenCirculation") | |
172 | 172 | ||
173 | 173 | let reserveStr = tryGetString(dAppaddress, "reserveGlobalData") | |
174 | 174 | ||
175 | 175 | let get1Str = split(reserveStr, "|")[1] | |
176 | 176 | ||
177 | 177 | let strToInt = parseIntValue(get1Str) | |
178 | 178 | ||
179 | 179 | let ETHtotalReserve = parseIntValue(split(tryGetString(dAppaddress, "reserveGlobalData"), "|")[1]) | |
180 | 180 | ||
181 | 181 | let ETHinVires = fraction(ETHatoken, ETHtotalReserve, ETHatokenTotal) | |
182 | 182 | ||
183 | 183 | let ETHinViresWavelets = fraction(ETHinVires, ethWaves, d8) | |
184 | 184 | ||
185 | 185 | let tvlInWaves = ((fraction((wavesInPool * 10), projectStake, totalStake) + fraction((wavesInWhirlpool * 10), projectStakeWhirl, totalStakeWhirl)) + ETHinViresWavelets) | |
186 | 186 | ||
187 | 187 | let totalBT = WAVESinEAST | |
188 | 188 | ||
189 | 189 | let totalTreasury = (totalBT + tvlInWaves) | |
190 | 190 | ||
191 | 191 | let whirlpoolSupply = match assetInfo(whirlpool) { | |
192 | 192 | case asset: Asset => | |
193 | 193 | asset.quantity | |
194 | 194 | case _ => | |
195 | 195 | throw("Can't find asset") | |
196 | 196 | } | |
197 | 197 | ||
198 | 198 | let price = if (((fraction((tvlInWaves + tryGetInteger(this, keySurplusReceived)), d8, whirlpoolSupply) + d8) >= tryGetInteger(this, keyWhirlpoolIssuePrice))) | |
199 | 199 | then (fraction((tvlInWaves + tryGetInteger(this, keySurplusReceived)), d8, whirlpoolSupply) + d8) | |
200 | 200 | else tryGetInteger(this, keyWhirlpoolIssuePrice) | |
201 | 201 | ||
202 | 202 | @Callable(i) | |
203 | 203 | func buyWHIRLPOOLwithWAVES () = { | |
204 | 204 | let WhirlpoolBalanceBefore = assetBalance(this, whirlpool) | |
205 | 205 | if ((WhirlpoolBalanceBefore == WhirlpoolBalanceBefore)) | |
206 | 206 | then { | |
207 | 207 | let pmt = value(i.payments[0]) | |
208 | 208 | let surplus = fraction((price - d8), pmt.amount, d8) | |
209 | 209 | let IssueAmount = if ((pmt.amount >= fraction(pmt.amount, d8, price))) | |
210 | 210 | then fraction(pmt.amount, d8, price) | |
211 | 211 | else throw("please contact project owner: issue amount error") | |
212 | - | let supplyAmount = ((pmt.amount - surplus) / 3) | |
213 | 212 | let cleanAmountIn = (pmt.amount - fraction(pmt.amount, 200, 10000)) | |
214 | 213 | let AmountOut = fraction(whirlInWhirlpool, ((d8 * d8) - toInt(pow(fraction(toBigInt(wavesInWhirlpool), toBigInt((d8 * d8)), toBigInt((wavesInWhirlpool + cleanAmountIn)), HALFUP), 16, toBigInt(fraction(100000, 10000, 900000)), 4, 16, CEILING))), (d8 * d8), DOWN) | |
215 | - | if ((pmt.assetId != unit)) | |
216 | - | then throw("attach WAVES token only") | |
217 | - | else { | |
218 | - | let buy = if ((AmountOut > IssueAmount)) | |
219 | - | then invoke(Address(whirlpoolPoolId), "swap", [whirlpoolString, (IssueAmount + 1)], [AttachedPayment(unit, pmt.amount)]) | |
220 | - | else unit | |
221 | - | if ((buy == buy)) | |
222 | - | then { | |
223 | - | let WhirlpoolBalanceAfter = assetBalance(this, whirlpool) | |
224 | - | let WhirlpoolFromSwap = (WhirlpoolBalanceAfter - WhirlpoolBalanceBefore) | |
214 | + | if (((d8 / 20) > pmt.amount)) | |
215 | + | then throw("minimum payment 0.05 WAVES") | |
216 | + | else if ((pmt.assetId != unit)) | |
217 | + | then throw("attach WAVES token only") | |
218 | + | else { | |
219 | + | let buy = if ((AmountOut > IssueAmount)) | |
220 | + | then invoke(Address(whirlpoolPoolId), "swap", [whirlpoolString, (IssueAmount + 1)], [AttachedPayment(unit, pmt.amount)]) | |
221 | + | else unit | |
222 | + | if ((buy == buy)) | |
223 | + | then { | |
224 | + | let WhirlpoolBalanceAfter = assetBalance(this, whirlpool) | |
225 | + | let WhirlpoolFromSwap = (WhirlpoolBalanceAfter - WhirlpoolBalanceBefore) | |
225 | 226 | [Reissue(whirlpool, if ((IssueAmount >= AmountOut)) | |
226 | - | then IssueAmount | |
227 | - | else 0, true), if ((AmountOut > IssueAmount)) | |
228 | - | then ScriptTransfer(i.caller, WhirlpoolFromSwap, whirlpool) | |
229 | - | else ScriptTransfer(i.caller, IssueAmount, whirlpool), IntegerEntry(keyWhirlpoolIssuePrice, price), IntegerEntry(if ((AmountOut > IssueAmount)) | |
230 | - | then "price WHIRLPOOL/WAVES" | |
231 | - | else "WHIRLPOOL/WAVES mid market price", if ((AmountOut > IssueAmount)) | |
232 | - | then fraction(d8, pmt.amount, WhirlpoolFromSwap) | |
233 | - | else fraction(d8, (wavesInWhirlpool * 9), whirlInWhirlpool)), IntegerEntry(keyWaveletsReceived, if ((IssueAmount >= AmountOut)) | |
234 | - | then (pmt.amount + tryGetInteger(this, keyWaveletsReceived)) | |
235 | - | else tryGetInteger(this, keyWaveletsReceived)), IntegerEntry(keyWaveletsReceived, if ((IssueAmount >= AmountOut)) | |
236 | - | then ((pmt.amount - surplus) + tryGetInteger(this, keyWaveletsReceived)) | |
237 | - | else tryGetInteger(this, keyWaveletsReceived)), IntegerEntry(keySurplusReceived, if ((AmountOut > IssueAmount)) | |
238 | - | then getIntegerValue(this, keySurplusReceived) | |
239 | - | else (surplus + getIntegerValue(this, keySurplusReceived)))] | |
240 | - | } | |
241 | - | else throw("Strict value is not equal to itself.") | |
242 | - | } | |
227 | + | then IssueAmount | |
228 | + | else 0, true), if ((AmountOut > IssueAmount)) | |
229 | + | then ScriptTransfer(i.caller, WhirlpoolFromSwap, whirlpool) | |
230 | + | else ScriptTransfer(i.caller, IssueAmount, whirlpool), IntegerEntry(keyWhirlpoolIssuePrice, price), IntegerEntry(if ((AmountOut > IssueAmount)) | |
231 | + | then "price WHIRLPOOL/WAVES" | |
232 | + | else "WHIRLPOOL/WAVES mid market price", if ((AmountOut > IssueAmount)) | |
233 | + | then fraction(d8, pmt.amount, WhirlpoolFromSwap) | |
234 | + | else fraction(d8, (wavesInWhirlpool * 9), whirlInWhirlpool)), IntegerEntry(keyWaveletsReceived, if ((IssueAmount >= AmountOut)) | |
235 | + | then (pmt.amount + tryGetInteger(this, keyWaveletsReceived)) | |
236 | + | else tryGetInteger(this, keyWaveletsReceived)), IntegerEntry(keyWaveletsReceived, if ((IssueAmount >= AmountOut)) | |
237 | + | then ((pmt.amount - surplus) + tryGetInteger(this, keyWaveletsReceived)) | |
238 | + | else tryGetInteger(this, keyWaveletsReceived)), IntegerEntry(keySurplusReceived, if ((AmountOut > IssueAmount)) | |
239 | + | then getIntegerValue(this, keySurplusReceived) | |
240 | + | else (surplus + getIntegerValue(this, keySurplusReceived)))] | |
241 | + | } | |
242 | + | else throw("Strict value is not equal to itself.") | |
243 | + | } | |
243 | 244 | } | |
244 | 245 | else throw("Strict value is not equal to itself.") | |
245 | 246 | } | |
246 | 247 | ||
247 | 248 | ||
248 | 249 | ||
249 | 250 | @Callable(i) | |
250 | 251 | func priceAndTreasuryStats () = [IntegerEntry("ETH/WAVES price", ethWaves), IntegerEntry("BT WAVES in EAST vault", WAVESinEAST), IntegerEntry("ST BURN-XTN x PepeTeam in wavelets", fraction((wavesInPool * 10), projectStake, totalStake)), IntegerEntry("ST WHIRLPOOL AMM in wavelets", fraction((wavesInWhirlpool * 10), projectStakeWhirl, totalStakeWhirl)), IntegerEntry("ST vETH", ETHinVires), IntegerEntry("ST vETH in wavelets", ETHinViresWavelets), IntegerEntry("Total ST in wavelets", tvlInWaves), IntegerEntry(keyWhirlpoolIssuePrice, price), IntegerEntry("WHIRLPOOL/WAVES mid market price", fraction(d8, (wavesInWhirlpool * 9), whirlInWhirlpool)), IntegerEntry("WHIRLPOOL total supply", whirlpoolSupply), IntegerEntry("Total treasury", totalTreasury), IntegerEntry("NAV WHIRLPOOL", fraction(d8, totalTreasury, whirlpoolSupply)), IntegerEntry(keyWaveletsReceived, tryGetInteger(this, keyWaveletsReceived)), IntegerEntry(keySurplusReceived, tryGetInteger(this, keySurplusReceived)), IntegerEntry(keyWaveletsReceived, tryGetInteger(this, keyWaveletsReceived)), IntegerEntry(keyWaveletsPaidOut, tryGetInteger(this, keyWaveletsPaidOut)), IntegerEntry("total WAVES received", (tryGetInteger(this, keyWaveletsReceived) / d8)), IntegerEntry("Total treasury in WAVES", (totalTreasury / d8)), IntegerEntry("surplus received in WAVES", (tryGetInteger(this, keySurplusReceived) / d8)), IntegerEntry("total WAVES received for base treasury", (tryGetInteger(this, keyWaveletsReceived) / d8)), IntegerEntry("total WAVES paid out in WAVES", (tryGetInteger(this, keyWaveletsPaidOut) / d8)), IntegerEntry(keyROI, tryGetInteger(this, keyROI))] | |
251 | 252 | ||
252 | 253 | ||
253 | 254 | ||
254 | 255 | @Callable(i) | |
255 | 256 | func boostPoolAPY () = if ((i.caller != this)) | |
256 | 257 | then throw("access only by project owner") | |
257 | 258 | else { | |
258 | 259 | let balance = if ((d8 > wavesBalance(this).available)) | |
259 | 260 | then throw("not enough WAVES") | |
260 | 261 | else (wavesBalance(this).available - d8) | |
261 | 262 | let boost80 = fraction(balance, 80, 100) | |
262 | 263 | if ((boost80 == boost80)) | |
263 | 264 | then { | |
264 | 265 | let amountBoost = fraction(boost80, 80, 100) | |
265 | 266 | if ((amountBoost == amountBoost)) | |
266 | 267 | then { | |
267 | 268 | let amountOwner = fraction(boost80, 20, 100) | |
268 | 269 | if ((amountOwner == amountOwner)) | |
269 | 270 | then { | |
270 | 271 | let boost = invoke(Address(poolboostSC), "addBoosting", [toBase58String(whirlpoolPoolId), 7], [AttachedPayment(unit, amountBoost)]) | |
271 | 272 | if ((boost == boost)) | |
272 | 273 | then [ScriptTransfer(Address(projectOwner), amountOwner, unit), IntegerEntry(keyWaveletsPaidOut, (amountBoost + tryGetInteger(this, keyWaveletsPaidOut))), IntegerEntry(keyROI, fraction(tryGetInteger(this, keyWaveletsPaidOut), 10000, tryGetInteger(this, keyWaveletsReceived))), IntegerEntry(keyActivated, height)] | |
273 | 274 | else throw("Strict value is not equal to itself.") | |
274 | 275 | } | |
275 | 276 | else throw("Strict value is not equal to itself.") | |
276 | 277 | } | |
277 | 278 | else throw("Strict value is not equal to itself.") | |
278 | 279 | } | |
279 | 280 | else throw("Strict value is not equal to itself.") | |
280 | 281 | } | |
281 | 282 | ||
282 | 283 | ||
283 | 284 | ||
284 | 285 | @Callable(i) | |
285 | 286 | func boostPoolAPY_all () = if ((i.caller != this)) | |
286 | 287 | then throw("access only by project owner") | |
287 | 288 | else { | |
288 | 289 | let balance = if ((d8 > wavesBalance(this).available)) | |
289 | 290 | then throw("not enough WAVES") | |
290 | 291 | else (wavesBalance(this).available - d8) | |
291 | 292 | let amountBoost = fraction(balance, 80, 100) | |
292 | 293 | if ((amountBoost == amountBoost)) | |
293 | 294 | then { | |
294 | 295 | let amountOwner = fraction(balance, 20, 100) | |
295 | 296 | if ((amountOwner == amountOwner)) | |
296 | 297 | then { | |
297 | 298 | let boost = invoke(Address(poolboostSC), "addBoosting", [toBase58String(whirlpoolPoolId), 7], [AttachedPayment(unit, amountBoost)]) | |
298 | 299 | if ((boost == boost)) | |
299 | 300 | then [ScriptTransfer(Address(projectOwner), amountOwner, unit), IntegerEntry(keyWaveletsPaidOut, (amountBoost + tryGetInteger(this, keyWaveletsPaidOut))), IntegerEntry(keyROI, fraction(tryGetInteger(this, keyWaveletsPaidOut), 10000, tryGetInteger(this, keyWaveletsReceived))), IntegerEntry(keyActivated, height)] | |
300 | 301 | else throw("Strict value is not equal to itself.") | |
301 | 302 | } | |
302 | 303 | else throw("Strict value is not equal to itself.") | |
303 | 304 | } | |
304 | 305 | else throw("Strict value is not equal to itself.") | |
305 | 306 | } | |
306 | 307 | ||
307 | 308 | ||
308 | 309 | ||
309 | 310 | @Callable(i) | |
310 | 311 | func transferPoolAPY () = if ((i.caller != this)) | |
311 | 312 | then throw("access only by project owner") | |
312 | 313 | else { | |
313 | 314 | let balance = if ((d8 > wavesBalance(this).available)) | |
314 | 315 | then throw("not enough WAVES") | |
315 | 316 | else (wavesBalance(this).available - d8) | |
316 | 317 | let boost80 = fraction(balance, 80, 100) | |
317 | 318 | if ((boost80 == boost80)) | |
318 | 319 | then { | |
319 | 320 | let amountBoost = fraction(boost80, 80, 100) | |
320 | 321 | if ((amountBoost == amountBoost)) | |
321 | 322 | then { | |
322 | 323 | let amountOwner = fraction(boost80, 20, 100) | |
323 | 324 | if ((amountOwner == amountOwner)) | |
324 | 325 | then [ScriptTransfer(Address(whirlpoolPoolId), amountBoost, unit), ScriptTransfer(Address(projectOwner), amountOwner, unit), IntegerEntry(keyWaveletsPaidOut, (amountBoost + tryGetInteger(this, keyWaveletsPaidOut))), IntegerEntry(keyROI, fraction(tryGetInteger(this, keyWaveletsPaidOut), 10000, tryGetInteger(this, keyWaveletsReceived))), IntegerEntry(keyActivated, height)] | |
325 | 326 | else throw("Strict value is not equal to itself.") | |
326 | 327 | } | |
327 | 328 | else throw("Strict value is not equal to itself.") | |
328 | 329 | } | |
329 | 330 | else throw("Strict value is not equal to itself.") | |
330 | 331 | } | |
331 | 332 | ||
332 | 333 | ||
333 | 334 | ||
334 | 335 | @Callable(i) | |
335 | 336 | func transferPoolAPY_all () = if ((i.caller != this)) | |
336 | 337 | then throw("access only by project owner") | |
337 | 338 | else { | |
338 | 339 | let balance = if ((d8 > wavesBalance(this).available)) | |
339 | 340 | then throw("not enough WAVES") | |
340 | 341 | else (wavesBalance(this).available - d8) | |
341 | 342 | let amountBoost = fraction(balance, 80, 100) | |
342 | 343 | if ((amountBoost == amountBoost)) | |
343 | 344 | then { | |
344 | 345 | let amountOwner = fraction(balance, 20, 100) | |
345 | 346 | if ((amountOwner == amountOwner)) | |
346 | 347 | then [ScriptTransfer(Address(whirlpoolPoolId), amountBoost, unit), ScriptTransfer(Address(projectOwner), amountOwner, unit), IntegerEntry(keyWaveletsPaidOut, (amountBoost + tryGetInteger(this, keyWaveletsPaidOut))), IntegerEntry(keyROI, fraction(tryGetInteger(this, keyWaveletsPaidOut), 10000, tryGetInteger(this, keyWaveletsReceived))), IntegerEntry(keyActivated, height)] | |
347 | 348 | else throw("Strict value is not equal to itself.") | |
348 | 349 | } | |
349 | 350 | else throw("Strict value is not equal to itself.") | |
350 | 351 | } | |
351 | 352 | ||
352 | 353 | ||
353 | 354 | ||
354 | 355 | @Callable(i) | |
355 | 356 | func poolOneTokenSurplus () = if ((i.caller != this)) | |
356 | 357 | then throw("access only by project owner") | |
357 | 358 | else { | |
358 | 359 | let surplusAmount = tryGetInteger(this, keySurplusReceived) | |
359 | 360 | let PoolOneTokenSurplus = invoke(Address(base58'3PR1Qvi9mHT35SwWEkLSqqE2L8thiPLdVWU'), "generateIndexWithOneTokenAndStake", [toBase58String(burnxtnPPTpoolId)], [AttachedPayment(unit, surplusAmount)]) | |
360 | 361 | if ((PoolOneTokenSurplus == PoolOneTokenSurplus)) | |
361 | 362 | then [IntegerEntry(keySurplusReceived, (tryGetInteger(this, keySurplusReceived) - surplusAmount))] | |
362 | 363 | else throw("Strict value is not equal to itself.") | |
363 | 364 | } | |
364 | 365 | ||
365 | 366 | ||
366 | 367 | ||
367 | 368 | @Callable(i) | |
368 | 369 | func surplusInvested (amountWAVES) = if ((i.caller != this)) | |
369 | 370 | then throw("access only by project owner") | |
370 | 371 | else { | |
371 | 372 | let investedAmount = (amountWAVES * d8) | |
372 | 373 | [IntegerEntry(keySurplusReceived, (tryGetInteger(this, keySurplusReceived) - investedAmount))] | |
373 | 374 | } | |
374 | 375 | ||
375 | 376 | ||
376 | 377 | ||
377 | 378 | @Callable(i) | |
378 | 379 | func changeIntegerEntry (keyString,integer) = if ((i.caller != this)) | |
379 | 380 | then throw("access only by project owner") | |
380 | 381 | else [IntegerEntry(keyString, integer)] | |
381 | 382 | ||
382 | 383 | ||
383 | 384 | ||
384 | 385 | @Callable(i) | |
385 | 386 | func activated () = if ((i.caller != this)) | |
386 | 387 | then throw("you are not allowed") | |
387 | 388 | else [IntegerEntry(keyActivated, height)] | |
388 | 389 | ||
389 | 390 | ||
390 | 391 | @Verifier(tx) | |
391 | 392 | func verify () = if (sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)) | |
392 | 393 | then true | |
393 | 394 | else if (((getIntegerValue(this, keyActivated) + unlockBlock) > height)) | |
394 | 395 | then false | |
395 | 396 | else if (sigVerify(tx.bodyBytes, tx.proofs[0], heirPubKey)) | |
396 | 397 | then true | |
397 | 398 | else if (((getIntegerValue(this, keyActivated) + unlockBlock2) > height)) | |
398 | 399 | then false | |
399 | 400 | else sigVerify(tx.bodyBytes, tx.proofs[0], PuzzleMasterPubKey) | |
400 | 401 |
github/deemru/w8io/3ef1775 115.93 ms ◑