tx · 7eEhAXnF6SMHeW36PNssJPWho3MLthbziQheAzuLdeRB 3NBbFNBed9tcU5AmsJAuExWvgJyNmJxqjWq: -0.01000000 Waves 2023.08.30 02:13 [2732635] smart account 3NBbFNBed9tcU5AmsJAuExWvgJyNmJxqjWq > SELF 0.00000000 Waves
{ "type": 13, "id": "7eEhAXnF6SMHeW36PNssJPWho3MLthbziQheAzuLdeRB", "fee": 1000000, "feeAssetId": null, "timestamp": 1693350851060, "version": 2, "chainId": 84, "sender": "3NBbFNBed9tcU5AmsJAuExWvgJyNmJxqjWq", "senderPublicKey": "ERewvWFUFQfR1eCnipNAv9n7SdQhof2ESP6PGVjTueLd", "proofs": [ "4drFGTdwUFWhGSYZ6mY3EhJ28VN9togtj7YvJdQD3pHzMr6LzY861mUgFmcJ8BEHMZD5G18wkZjLhjVRNmdCPDHY" ], "script": "base64:BgIOCAISABIAEgASABIAEgAPAAl3YXZlczFMSWQJAQdBZGRyZXNzAQEgsfXkVqM/0+6J9kArnDxMgAk2oJh4WqfkxR9uWw/pRoUACXdhdmVzM0xJZAkBB0FkZHJlc3MBASB3Vww16jaU307TFdx6AQCZu00QR9cMiqtX4etxi+C4ZAAJd2F2ZXM1TElkCQEHQWRkcmVzcwEBIBtGaJJlOVgU0G5tRCLl1N4g5dbuu+aJfhfESzP16GakAAZ1c2RuSWQBIA/yHBKs5MQ8muxGGqslqLDsugcrRsxtiHLwteKSSQG0AANhcnIJAMwIAgABCQDMCAIAAgkAzAgCAAMJAMwIAgAECQDMCAIABQUDbmlsAARhcnIyCQDMCAIAAQkAzAgCAAIFA25pbAAEYXJyMwkAzAgCAAEJAMwIAgACCQDMCAIAAwUDbmlsAQNzdW0CAWEBYgkA/AcECQERQGV4dHJOYXRpdmUoMTA2MikBAiMzTjNEblZmZm5VeVp0ejJNUmJrNVU3Z2lOMTEyV2VtcE1OZAIGYm9ycm93CQDMCAICLDI1RkVxRWpSa3FLNnlDa2lUN0x6NlNBWXo3Z1VGQ3R4ZkNDaG5yVkZENUFUCQDMCAIAwIQ9BQNuaWwFA25pbAEKZ2V0QmFsYW5jZQIKYXNzZXRJZFN0cgdhZGRyZXNzAwkAAAIFCmFzc2V0SWRTdHICBVdBVkVTCAkA7wcBBQdhZGRyZXNzCWF2YWlsYWJsZQkA8AcCBQdhZGRyZXNzCQDZBAEFCmFzc2V0SWRTdHIBD2dldEN1cnJlbnRQcmljZQEKYXNzZXRJZFN0cgMJAAACBQphc3NldElkU3RyAgVXQVZFUwACCQACAQIFRXJyb3IBFGdldFdhdmVzQ3VycmVudFByaWNlAACAiXoBEGdldFdhdmVzTmV3UHJpY2UAAMCNtwEBFmdldFdhdmVzM0xDdXJyZW50UHJpY2UAAICfSQESZ2V0V2F2ZXMzTE5ld1ByaWNlAACAiXoBDXRyeUdldEludGVnZXIBA2tleQQHJG1hdGNoMAkAmggCBQR0aGlzBQNrZXkDCQABAgUHJG1hdGNoMAIDSW50BAFiBQckbWF0Y2gwBQFiAAAGAWkBDm1pbnRXYXZlczNMX3YxAAMDCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAEGCQAAAggJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQAAAkAAgECHDEgcGF5bWVudCBoYXMgdG8gYmUgYXR0YWNoZWQEB2FkZHJlc3MJAKUIAQgFAWkGY2FsbGVyBBBzdGFibGVDb2luQW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQUY29udmVydGVkV2F2ZXNBbW91bnQJAGgCCQBpAgUQc3RhYmxlQ29pbkFtb3VudAkBFGdldFdhdmVzQ3VycmVudFByaWNlAACAwtcvBA91c2VyV2F2ZXNBbW91bnQJAQpnZXRCYWxhbmNlAgIFV0FWRVMIBQFpBmNhbGxlcgMJAGYCBQ91c2VyV2F2ZXNBbW91bnQFFGNvbnZlcnRlZFdhdmVzQW1vdW50BA1kZXBvc2l0UmVzdWx0CQD8BwQJARFAZXh0ck5hdGl2ZSgxMDYyKQECIzNOM0RuVmZmblV5WnR6Mk1SYms1VTdnaU4xMTJXZW1wTU5kAgZzdXBwbHkFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUEdW5pdAUUY29udmVydGVkV2F2ZXNBbW91bnQFA25pbAMJAAACBQ1kZXBvc2l0UmVzdWx0BQ1kZXBvc2l0UmVzdWx0CgEKcmVwZWF0RnVuYwIFYWNjdW0EbmV4dAQMYm9ycm93UmVzdWx0CQD8BwQJARFAZXh0ck5hdGl2ZSgxMDYyKQECIzNOM0RuVmZmblV5WnR6Mk1SYms1VTdnaU4xMTJXZW1wTU5kAgZib3Jyb3cJAMwIAgIsMjVGRXFFalJrcUs2eUNraVQ3THo2U0FZejdnVUZDdHhmQ0NobnJWRkQ1QVQJAMwIAgUQc3RhYmxlQ29pbkFtb3VudAUDbmlsBQNuaWwDCQAAAgUMYm9ycm93UmVzdWx0BQxib3Jyb3dSZXN1bHQJAGQCBQVhY2N1bQUEbmV4dAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgQFYXJyYXkJAMwIAgUQc3RhYmxlQ29pbkFtb3VudAkAzAgCBRBzdGFibGVDb2luQW1vdW50CQDMCAIFEHN0YWJsZUNvaW5BbW91bnQFA25pbAQDcmVzCgACJGwFBWFycmF5CgACJHMJAJADAQUCJGwKAAUkYWNjMAAACgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQpyZXBlYXRGdW5jAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhNMaXN0IHNpemUgZXhjZWVkcyAzCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADBBNyZXR1cm5lZFRva2VuQW1vdW50CQBoAgkAaQIFA3JlcwkBFmdldFdhdmVzM0xDdXJyZW50UHJpY2UAAMCEPQkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQdhZGRyZXNzAgpfZ2F2ZV9VU0ROBRBzdGFibGVDb2luQW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFB2FkZHJlc3MCEF9kZXBvc2l0ZWRfV0FWRVMFFGNvbnZlcnRlZFdhdmVzQW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgUHYWRkcmVzcwIKX2JvcnJvd2VkXwIsMjVGRXFFalJrcUs2eUNraVQ3THo2U0FZejdnVUZDdHhmQ0NobnJWRkQ1QVQFA3JlcwkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQdhZGRyZXNzAhFfcmVjZWl2ZWRfV0FWRVMzTAUTcmV0dXJuZWRUb2tlbkFtb3VudAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFE3JldHVybmVkVG9rZW5BbW91bnQBIHdXDDXqNpTfTtMV3HoBAJm7TRBH1wyKq1fh63GL4LhkBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAhxOb3QgZW5vdWdoIFdBVkVTIHRvIGRlcG9zaXQhAWkBEHJlZGVlbVdhdmVzM0xfdjEAAwMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQYJAAACCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAAACQACAQIcMSBwYXltZW50IGhhcyB0byBiZSBhdHRhY2hlZAQHYWRkcmVzcwkApQgBCAUBaQZjYWxsZXIEC3Rva2VuQW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQScmV0dXJuZWRVU0ROQW1vdW50CQBoAgULdG9rZW5BbW91bnQJAGkCCQESZ2V0V2F2ZXMzTE5ld1ByaWNlAADAhD0JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUHYWRkcmVzcwIRX3JlZGVlbWVkX1dBVkVTM0wFC3Rva2VuQW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFB2FkZHJlc3MCDl9yZWNlaXZlZF9VU0ROBRJyZXR1cm5lZFVTRE5BbW91bnQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBRJyZXR1cm5lZFVTRE5BbW91bnQBIA/yHBKs5MQ8muxGGqslqLDsugcrRsxtiHLwteKSSQG0BQNuaWwBaQEObWludFdhdmVzM0xfdjIAAwMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQYJAAACCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAAACQACAQIcMSBwYXltZW50IGhhcyB0byBiZSBhdHRhY2hlZAQHYWRkcmVzcwkApQgBCAUBaQZjYWxsZXIEEHN0YWJsZUNvaW5BbW91bnQICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BBRjb252ZXJ0ZWRXYXZlc0Ftb3VudAkAaAIJAGkCBRBzdGFibGVDb2luQW1vdW50AICJegCAwtcvBA91c2VyV2F2ZXNBbW91bnQJAQpnZXRCYWxhbmNlAgIFV0FWRVMIBQFpBmNhbGxlcgQJYmVkaW5ndW5nCQBoAgkAZQIAAwABCQEUZ2V0V2F2ZXNDdXJyZW50UHJpY2UAAwkAZwIFEHN0YWJsZUNvaW5BbW91bnQFCWJlZGluZ3VuZwQNZGVwb3NpdFJlc3VsdAkA/AcECQERQGV4dHJOYXRpdmUoMTA2MikBAiMzTjNEblZmZm5VeVp0ejJNUmJrNVU3Z2lOMTEyV2VtcE1OZAIGc3VwcGx5BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFBHVuaXQFFGNvbnZlcnRlZFdhdmVzQW1vdW50BQNuaWwDCQAAAgUNZGVwb3NpdFJlc3VsdAUNZGVwb3NpdFJlc3VsdAoBCnJlcGVhdEZ1bmMCBWFjY3VtBG5leHQEDGJvcnJvd1Jlc3VsdAkA/AcECQERQGV4dHJOYXRpdmUoMTA2MikBAiMzTjNEblZmZm5VeVp0ejJNUmJrNVU3Z2lOMTEyV2VtcE1OZAIGYm9ycm93CQDMCAICLDI1RkVxRWpSa3FLNnlDa2lUN0x6NlNBWXo3Z1VGQ3R4ZkNDaG5yVkZENUFUCQDMCAIFEHN0YWJsZUNvaW5BbW91bnQFA25pbAUDbmlsAwkAAAIFDGJvcnJvd1Jlc3VsdAUMYm9ycm93UmVzdWx0CQBkAgUFYWNjdW0FBG5leHQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4EBWFycmF5CQDMCAIFEHN0YWJsZUNvaW5BbW91bnQJAMwIAgUQc3RhYmxlQ29pbkFtb3VudAkAzAgCBRBzdGFibGVDb2luQW1vdW50BQNuaWwEA3JlcwoAAiRsBQVhcnJheQoAAiRzCQCQAwEFAiRsCgAFJGFjYzAAAAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEKcmVwZWF0RnVuYwIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQITTGlzdCBzaXplIGV4Y2VlZHMgMwkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwQNYnlXYXZlc0thdWZlbgkAaAIJAGkCBQNyZXMJARRnZXRXYXZlc0N1cnJlbnRQcmljZQAAgMLXLwkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQdhZGRyZXNzAgpfZ2F2ZV9VU0ROBRBzdGFibGVDb2luQW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFB2FkZHJlc3MCEF9kZXBvc2l0ZWRfV0FWRVMFFGNvbnZlcnRlZFdhdmVzQW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgUHYWRkcmVzcwIKX2JvcnJvd2VkXwIsMjVGRXFFalJrcUs2eUNraVQ3THo2U0FZejdnVUZDdHhmQ0NobnJWRkQ1QVQFA3JlcwkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQdhZGRyZXNzAhFfcmVjZWl2ZWRfV0FWRVMzTADAhD0JAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyAMCEPQEgd1cMNeo2lN9O0xXcegEAmbtNEEfXDIqrV+HrcYvguGQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECHE5vdCBlbm91Z2ggV0FWRVMgdG8gZGVwb3NpdCEBaQEQcmVkZWVtV2F2ZXMzTF92MgADAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwABBgkAAAIICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50AAAJAAIBAhwxIHBheW1lbnQgaGFzIHRvIGJlIGF0dGFjaGVkBAdhZGRyZXNzCQClCAEIBQFpBmNhbGxlcgQLdG9rZW5BbW91bnQABgQScmV0dXJuZWRVU0ROQW1vdW50CQBoAgkAZQIJAGgCBQt0b2tlbkFtb3VudAkAaQIJARBnZXRXYXZlc05ld1ByaWNlAADAhD0ABADAhD0JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUHYWRkcmVzcwIRX3JlZGVlbWVkX1dBVkVTM0wFC3Rva2VuQW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFB2FkZHJlc3MCDl9yZWNlaXZlZF9VU0ROBRJyZXR1cm5lZFVTRE5BbW91bnQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBRJyZXR1cm5lZFVTRE5BbW91bnQBIA/yHBKs5MQ8muxGGqslqLDsugcrRsxtiHLwteKSSQG0BQNuaWwBaQEFbG9uZzIAAwMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQYJAAACCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAAACQACAQIcMSBwYXltZW50IGhhcyB0byBiZSBhdHRhY2hlZAQNZmlyc3RBbW91bnRJbggJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQEEmZpcnN0U3dhcHBlZEFtb3VudAkA/AcECQERQGV4dHJOYXRpdmUoMTA2MikBAiMzTXM4ZnFiWE00UmhtTTZDUFRyNDRoVXdIZTJDQ21WQ2ZWQQILc3dhcFRvV2F2ZXMFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUGdXNkbklkBQ1maXJzdEFtb3VudEluBQNuaWwDCQAAAgUSZmlyc3RTd2FwcGVkQW1vdW50BRJmaXJzdFN3YXBwZWRBbW91bnQEByRtYXRjaDAFEmZpcnN0U3dhcHBlZEFtb3VudAMJAAECBQckbWF0Y2gwAgNJbnQEAXIFByRtYXRjaDAEEWZpc3REZXBvc2l0UmVzdWx0CQD8BwQJARFAZXh0ck5hdGl2ZSgxMDYyKQECIzNOM0RuVmZmblV5WnR6Mk1SYms1VTdnaU4xMTJXZW1wTU5kAgZzdXBwbHkFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUEdW5pdAUBcgUDbmlsAwkAAAIFEWZpc3REZXBvc2l0UmVzdWx0BRFmaXN0RGVwb3NpdFJlc3VsdAQRZmlyc3RCb3Jyb3dSZXN1bHQJAPwHBAkBEUBleHRyTmF0aXZlKDEwNjIpAQIjM04zRG5WZmZuVXladHoyTVJiazVVN2dpTjExMldlbXBNTmQCBmJvcnJvdwkAzAgCAiwyNUZFcUVqUmtxSzZ5Q2tpVDdMejZTQVl6N2dVRkN0eGZDQ2huclZGRDVBVAkAzAgCCQBpAgkAaAIFDWZpcnN0QW1vdW50SW4ASwBkBQNuaWwFA25pbAMJAAACBRFmaXJzdEJvcnJvd1Jlc3VsdAURZmlyc3RCb3Jyb3dSZXN1bHQKAQpyZXBlYXRGdW5jAgVhY2N1bQRuZXh0CQBkAgUFYWNjdW0FBG5leHQEBWFycmF5CQDMCAIAAQkAzAgCAAEJAMwIAgABBQNuaWwEA3JlcwoAAiRsBQVhcnJheQoAAiRzCQCQAwEFAiRsCgAFJGFjYzAAAAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEKcmVwZWF0RnVuYwIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQITTGlzdCBzaXplIGV4Y2VlZHMgNQkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECF0luY29ycmVjdCBpbnZva2UgcmVzdWx0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBCWxvbmcydGVzdAADAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwABBgkAAAIICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50AAAJAAIBAhwxIHBheW1lbnQgaGFzIHRvIGJlIGF0dGFjaGVkBA1maXJzdEFtb3VudEluCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQIY2FsbGVySWQJAKUIAQgFAWkGY2FsbGVyBBJmaXJzdFN3YXBwZWRBbW91bnQJAPwHBAkBEUBleHRyTmF0aXZlKDEwNjIpAQIjM01zOGZxYlhNNFJobU02Q1BUcjQ0aFV3SGUyQ0NtVkNmVkECC3N3YXBUb1dhdmVzCQDMCAIJAKUIAQgFAWkGY2FsbGVyBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFBnVzZG5JZAUNZmlyc3RBbW91bnRJbgUDbmlsAwkAAAIFEmZpcnN0U3dhcHBlZEFtb3VudAUSZmlyc3RTd2FwcGVkQW1vdW50BAckbWF0Y2gwBRJmaXJzdFN3YXBwZWRBbW91bnQDCQABAgUHJG1hdGNoMAIDSW50BAFyBQckbWF0Y2gwBA1sYXN0QW1vdW50T3V0CQENdHJ5R2V0SW50ZWdlcgEJAKwCAgUIY2FsbGVySWQCFV9MYXN0X0Ftb3VudE91dF9XYXZlcwkAzAgCCQEMSW50ZWdlckVudHJ5AgIWUmV0dXJuZWRfU3dhcHBlZEFtb3VudAUBcgkAzAgCCQEMSW50ZWdlckVudHJ5AgIMRmlyc3RfQm9ycm93CQBpAgkAaAIFDWZpcnN0QW1vdW50SW4ARgBkCQDMCAIJAQxJbnRlZ2VyRW50cnkCAhdMYXN0X0Ftb3VudE91dF9XYXZlc19TQwUNbGFzdEFtb3VudE91dAUDbmlsCQACAQIXSW5jb3JyZWN0IGludm9rZSByZXN1bHQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAnR4AQZ2ZXJpZnkACQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5+N5IPw==", "height": 2732635, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: ESAKSDb6Gy2ms7wtvAy1tQk4ZFjagevk889MDjabEKds Next: HGMJdf9m2RMCWoi4dPd3bR9Bf4FbcsKgTYjezi4MhSe Diff:
Old | New | Differences | |
---|---|---|---|
38 | 38 | ||
39 | 39 | ||
40 | 40 | func getWaves3LNewPrice () = 2000000 | |
41 | + | ||
42 | + | ||
43 | + | func tryGetInteger (key) = match getInteger(this, key) { | |
44 | + | case b: Int => | |
45 | + | b | |
46 | + | case _ => | |
47 | + | 0 | |
48 | + | } | |
41 | 49 | ||
42 | 50 | ||
43 | 51 | @Callable(i) | |
222 | 230 | if ((firstSwappedAmount == firstSwappedAmount)) | |
223 | 231 | then match firstSwappedAmount { | |
224 | 232 | case r: Int => | |
225 | - | let lastAmountOut = | |
226 | - | [IntegerEntry("Returned_SwappedAmount", r), IntegerEntry("First_Borrow", ((firstAmountIn * 70) / 100)), IntegerEntry("Last_AmountOut_Waves", lastAmountOut)] | |
233 | + | let lastAmountOut = tryGetInteger((callerId + "_Last_AmountOut_Waves")) | |
234 | + | [IntegerEntry("Returned_SwappedAmount", r), IntegerEntry("First_Borrow", ((firstAmountIn * 70) / 100)), IntegerEntry("Last_AmountOut_Waves_SC", lastAmountOut)] | |
227 | 235 | case _ => | |
228 | 236 | throw("Incorrect invoke result") | |
229 | 237 | } |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let waves1LId = Address(base58'CygdaJKZfxRrHyYMwkNdz9ZgSD5FpJLtk5s5B4q1DKV6') | |
5 | 5 | ||
6 | 6 | let waves3LId = Address(base58'92rW5ucGkH84YeXLnLs8dMN1P7RAFocmR8zfBqUy4gPM') | |
7 | 7 | ||
8 | 8 | let waves5LId = Address(base58'2qUH6Nh6cgC8dxj8fwH3bTJi261PNr5nMQKRbBXBuwmM') | |
9 | 9 | ||
10 | 10 | let usdnId = base58'25FEqEjRkqK6yCkiT7Lz6SAYz7gUFCtxfCChnrVFD5AT' | |
11 | 11 | ||
12 | 12 | let arr = [1, 2, 3, 4, 5] | |
13 | 13 | ||
14 | 14 | let arr2 = [1, 2] | |
15 | 15 | ||
16 | 16 | let arr3 = [1, 2, 3] | |
17 | 17 | ||
18 | 18 | func sum (a,b) = invoke(addressFromStringValue("3N3DnVffnUyZtz2MRbk5U7giN112WempMNd"), "borrow", ["25FEqEjRkqK6yCkiT7Lz6SAYz7gUFCtxfCChnrVFD5AT", 1000000], nil) | |
19 | 19 | ||
20 | 20 | ||
21 | 21 | func getBalance (assetIdStr,address) = if ((assetIdStr == "WAVES")) | |
22 | 22 | then wavesBalance(address).available | |
23 | 23 | else assetBalance(address, fromBase58String(assetIdStr)) | |
24 | 24 | ||
25 | 25 | ||
26 | 26 | func getCurrentPrice (assetIdStr) = if ((assetIdStr == "WAVES")) | |
27 | 27 | then 2 | |
28 | 28 | else throw("Error") | |
29 | 29 | ||
30 | 30 | ||
31 | 31 | func getWavesCurrentPrice () = 2000000 | |
32 | 32 | ||
33 | 33 | ||
34 | 34 | func getWavesNewPrice () = 3000000 | |
35 | 35 | ||
36 | 36 | ||
37 | 37 | func getWaves3LCurrentPrice () = 1200000 | |
38 | 38 | ||
39 | 39 | ||
40 | 40 | func getWaves3LNewPrice () = 2000000 | |
41 | + | ||
42 | + | ||
43 | + | func tryGetInteger (key) = match getInteger(this, key) { | |
44 | + | case b: Int => | |
45 | + | b | |
46 | + | case _ => | |
47 | + | 0 | |
48 | + | } | |
41 | 49 | ||
42 | 50 | ||
43 | 51 | @Callable(i) | |
44 | 52 | func mintWaves3L_v1 () = if (if ((size(i.payments) != 1)) | |
45 | 53 | then true | |
46 | 54 | else (i.payments[0].amount == 0)) | |
47 | 55 | then throw("1 payment has to be attached") | |
48 | 56 | else { | |
49 | 57 | let address = toString(i.caller) | |
50 | 58 | let stableCoinAmount = i.payments[0].amount | |
51 | 59 | let convertedWavesAmount = ((stableCoinAmount / getWavesCurrentPrice()) * 100000000) | |
52 | 60 | let userWavesAmount = getBalance("WAVES", i.caller) | |
53 | 61 | if ((userWavesAmount > convertedWavesAmount)) | |
54 | 62 | then { | |
55 | 63 | let depositResult = invoke(addressFromStringValue("3N3DnVffnUyZtz2MRbk5U7giN112WempMNd"), "supply", nil, [AttachedPayment(unit, convertedWavesAmount)]) | |
56 | 64 | if ((depositResult == depositResult)) | |
57 | 65 | then { | |
58 | 66 | func repeatFunc (accum,next) = { | |
59 | 67 | let borrowResult = invoke(addressFromStringValue("3N3DnVffnUyZtz2MRbk5U7giN112WempMNd"), "borrow", ["25FEqEjRkqK6yCkiT7Lz6SAYz7gUFCtxfCChnrVFD5AT", stableCoinAmount], nil) | |
60 | 68 | if ((borrowResult == borrowResult)) | |
61 | 69 | then (accum + next) | |
62 | 70 | else throw("Strict value is not equal to itself.") | |
63 | 71 | } | |
64 | 72 | ||
65 | 73 | let array = [stableCoinAmount, stableCoinAmount, stableCoinAmount] | |
66 | 74 | let res = { | |
67 | 75 | let $l = array | |
68 | 76 | let $s = size($l) | |
69 | 77 | let $acc0 = 0 | |
70 | 78 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
71 | 79 | then $a | |
72 | 80 | else repeatFunc($a, $l[$i]) | |
73 | 81 | ||
74 | 82 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
75 | 83 | then $a | |
76 | 84 | else throw("List size exceeds 3") | |
77 | 85 | ||
78 | 86 | $f0_2($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3) | |
79 | 87 | } | |
80 | 88 | let returnedTokenAmount = ((res / getWaves3LCurrentPrice()) * 1000000) | |
81 | 89 | [IntegerEntry((address + "_gave_USDN"), stableCoinAmount), IntegerEntry((address + "_deposited_WAVES"), convertedWavesAmount), IntegerEntry(((address + "_borrowed_") + "25FEqEjRkqK6yCkiT7Lz6SAYz7gUFCtxfCChnrVFD5AT"), res), IntegerEntry((address + "_received_WAVES3L"), returnedTokenAmount), ScriptTransfer(i.caller, returnedTokenAmount, base58'92rW5ucGkH84YeXLnLs8dMN1P7RAFocmR8zfBqUy4gPM')] | |
82 | 90 | } | |
83 | 91 | else throw("Strict value is not equal to itself.") | |
84 | 92 | } | |
85 | 93 | else throw("Not enough WAVES to deposit!") | |
86 | 94 | } | |
87 | 95 | ||
88 | 96 | ||
89 | 97 | ||
90 | 98 | @Callable(i) | |
91 | 99 | func redeemWaves3L_v1 () = if (if ((size(i.payments) != 1)) | |
92 | 100 | then true | |
93 | 101 | else (i.payments[0].amount == 0)) | |
94 | 102 | then throw("1 payment has to be attached") | |
95 | 103 | else { | |
96 | 104 | let address = toString(i.caller) | |
97 | 105 | let tokenAmount = i.payments[0].amount | |
98 | 106 | let returnedUSDNAmount = (tokenAmount * (getWaves3LNewPrice() / 1000000)) | |
99 | 107 | [IntegerEntry((address + "_redeemed_WAVES3L"), tokenAmount), IntegerEntry((address + "_received_USDN"), returnedUSDNAmount), ScriptTransfer(i.caller, returnedUSDNAmount, base58'25FEqEjRkqK6yCkiT7Lz6SAYz7gUFCtxfCChnrVFD5AT')] | |
100 | 108 | } | |
101 | 109 | ||
102 | 110 | ||
103 | 111 | ||
104 | 112 | @Callable(i) | |
105 | 113 | func mintWaves3L_v2 () = if (if ((size(i.payments) != 1)) | |
106 | 114 | then true | |
107 | 115 | else (i.payments[0].amount == 0)) | |
108 | 116 | then throw("1 payment has to be attached") | |
109 | 117 | else { | |
110 | 118 | let address = toString(i.caller) | |
111 | 119 | let stableCoinAmount = i.payments[0].amount | |
112 | 120 | let convertedWavesAmount = ((stableCoinAmount / 2000000) * 100000000) | |
113 | 121 | let userWavesAmount = getBalance("WAVES", i.caller) | |
114 | 122 | let bedingung = ((3 - 1) * getWavesCurrentPrice()) | |
115 | 123 | if ((stableCoinAmount >= bedingung)) | |
116 | 124 | then { | |
117 | 125 | let depositResult = invoke(addressFromStringValue("3N3DnVffnUyZtz2MRbk5U7giN112WempMNd"), "supply", nil, [AttachedPayment(unit, convertedWavesAmount)]) | |
118 | 126 | if ((depositResult == depositResult)) | |
119 | 127 | then { | |
120 | 128 | func repeatFunc (accum,next) = { | |
121 | 129 | let borrowResult = invoke(addressFromStringValue("3N3DnVffnUyZtz2MRbk5U7giN112WempMNd"), "borrow", ["25FEqEjRkqK6yCkiT7Lz6SAYz7gUFCtxfCChnrVFD5AT", stableCoinAmount], nil) | |
122 | 130 | if ((borrowResult == borrowResult)) | |
123 | 131 | then (accum + next) | |
124 | 132 | else throw("Strict value is not equal to itself.") | |
125 | 133 | } | |
126 | 134 | ||
127 | 135 | let array = [stableCoinAmount, stableCoinAmount, stableCoinAmount] | |
128 | 136 | let res = { | |
129 | 137 | let $l = array | |
130 | 138 | let $s = size($l) | |
131 | 139 | let $acc0 = 0 | |
132 | 140 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
133 | 141 | then $a | |
134 | 142 | else repeatFunc($a, $l[$i]) | |
135 | 143 | ||
136 | 144 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
137 | 145 | then $a | |
138 | 146 | else throw("List size exceeds 3") | |
139 | 147 | ||
140 | 148 | $f0_2($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3) | |
141 | 149 | } | |
142 | 150 | let byWavesKaufen = ((res / getWavesCurrentPrice()) * 100000000) | |
143 | 151 | [IntegerEntry((address + "_gave_USDN"), stableCoinAmount), IntegerEntry((address + "_deposited_WAVES"), convertedWavesAmount), IntegerEntry(((address + "_borrowed_") + "25FEqEjRkqK6yCkiT7Lz6SAYz7gUFCtxfCChnrVFD5AT"), res), IntegerEntry((address + "_received_WAVES3L"), 1000000), ScriptTransfer(i.caller, 1000000, base58'92rW5ucGkH84YeXLnLs8dMN1P7RAFocmR8zfBqUy4gPM')] | |
144 | 152 | } | |
145 | 153 | else throw("Strict value is not equal to itself.") | |
146 | 154 | } | |
147 | 155 | else throw("Not enough WAVES to deposit!") | |
148 | 156 | } | |
149 | 157 | ||
150 | 158 | ||
151 | 159 | ||
152 | 160 | @Callable(i) | |
153 | 161 | func redeemWaves3L_v2 () = if (if ((size(i.payments) != 1)) | |
154 | 162 | then true | |
155 | 163 | else (i.payments[0].amount == 0)) | |
156 | 164 | then throw("1 payment has to be attached") | |
157 | 165 | else { | |
158 | 166 | let address = toString(i.caller) | |
159 | 167 | let tokenAmount = 6 | |
160 | 168 | let returnedUSDNAmount = (((tokenAmount * (getWavesNewPrice() / 1000000)) - 4) * 1000000) | |
161 | 169 | [IntegerEntry((address + "_redeemed_WAVES3L"), tokenAmount), IntegerEntry((address + "_received_USDN"), returnedUSDNAmount), ScriptTransfer(i.caller, returnedUSDNAmount, base58'25FEqEjRkqK6yCkiT7Lz6SAYz7gUFCtxfCChnrVFD5AT')] | |
162 | 170 | } | |
163 | 171 | ||
164 | 172 | ||
165 | 173 | ||
166 | 174 | @Callable(i) | |
167 | 175 | func long2 () = if (if ((size(i.payments) != 1)) | |
168 | 176 | then true | |
169 | 177 | else (i.payments[0].amount == 0)) | |
170 | 178 | then throw("1 payment has to be attached") | |
171 | 179 | else { | |
172 | 180 | let firstAmountIn = i.payments[0].amount | |
173 | 181 | let firstSwappedAmount = invoke(addressFromStringValue("3Ms8fqbXM4RhmM6CPTr44hUwHe2CCmVCfVA"), "swapToWaves", nil, [AttachedPayment(usdnId, firstAmountIn)]) | |
174 | 182 | if ((firstSwappedAmount == firstSwappedAmount)) | |
175 | 183 | then match firstSwappedAmount { | |
176 | 184 | case r: Int => | |
177 | 185 | let fistDepositResult = invoke(addressFromStringValue("3N3DnVffnUyZtz2MRbk5U7giN112WempMNd"), "supply", nil, [AttachedPayment(unit, r)]) | |
178 | 186 | if ((fistDepositResult == fistDepositResult)) | |
179 | 187 | then { | |
180 | 188 | let firstBorrowResult = invoke(addressFromStringValue("3N3DnVffnUyZtz2MRbk5U7giN112WempMNd"), "borrow", ["25FEqEjRkqK6yCkiT7Lz6SAYz7gUFCtxfCChnrVFD5AT", ((firstAmountIn * 75) / 100)], nil) | |
181 | 189 | if ((firstBorrowResult == firstBorrowResult)) | |
182 | 190 | then { | |
183 | 191 | func repeatFunc (accum,next) = (accum + next) | |
184 | 192 | ||
185 | 193 | let array = [1, 1, 1] | |
186 | 194 | let res = { | |
187 | 195 | let $l = array | |
188 | 196 | let $s = size($l) | |
189 | 197 | let $acc0 = 0 | |
190 | 198 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
191 | 199 | then $a | |
192 | 200 | else repeatFunc($a, $l[$i]) | |
193 | 201 | ||
194 | 202 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
195 | 203 | then $a | |
196 | 204 | else throw("List size exceeds 5") | |
197 | 205 | ||
198 | 206 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5) | |
199 | 207 | } | |
200 | 208 | nil | |
201 | 209 | } | |
202 | 210 | else throw("Strict value is not equal to itself.") | |
203 | 211 | } | |
204 | 212 | else throw("Strict value is not equal to itself.") | |
205 | 213 | case _ => | |
206 | 214 | throw("Incorrect invoke result") | |
207 | 215 | } | |
208 | 216 | else throw("Strict value is not equal to itself.") | |
209 | 217 | } | |
210 | 218 | ||
211 | 219 | ||
212 | 220 | ||
213 | 221 | @Callable(i) | |
214 | 222 | func long2test () = if (if ((size(i.payments) != 1)) | |
215 | 223 | then true | |
216 | 224 | else (i.payments[0].amount == 0)) | |
217 | 225 | then throw("1 payment has to be attached") | |
218 | 226 | else { | |
219 | 227 | let firstAmountIn = i.payments[0].amount | |
220 | 228 | let callerId = toString(i.caller) | |
221 | 229 | let firstSwappedAmount = invoke(addressFromStringValue("3Ms8fqbXM4RhmM6CPTr44hUwHe2CCmVCfVA"), "swapToWaves", [toString(i.caller)], [AttachedPayment(usdnId, firstAmountIn)]) | |
222 | 230 | if ((firstSwappedAmount == firstSwappedAmount)) | |
223 | 231 | then match firstSwappedAmount { | |
224 | 232 | case r: Int => | |
225 | - | let lastAmountOut = | |
226 | - | [IntegerEntry("Returned_SwappedAmount", r), IntegerEntry("First_Borrow", ((firstAmountIn * 70) / 100)), IntegerEntry("Last_AmountOut_Waves", lastAmountOut)] | |
233 | + | let lastAmountOut = tryGetInteger((callerId + "_Last_AmountOut_Waves")) | |
234 | + | [IntegerEntry("Returned_SwappedAmount", r), IntegerEntry("First_Borrow", ((firstAmountIn * 70) / 100)), IntegerEntry("Last_AmountOut_Waves_SC", lastAmountOut)] | |
227 | 235 | case _ => | |
228 | 236 | throw("Incorrect invoke result") | |
229 | 237 | } | |
230 | 238 | else throw("Strict value is not equal to itself.") | |
231 | 239 | } | |
232 | 240 | ||
233 | 241 | ||
234 | 242 | @Verifier(tx) | |
235 | 243 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
236 | 244 |
github/deemru/w8io/169f3d6 54.31 ms ◑