tx · EzydaTK6rzUmknGewLy9YWPQxjW3yL3SAZFYnmsB9YE9 3N5Z4dAWzfkEp4kNJZKQk6zf3uTVFFz5MFF: -0.01500000 Waves 2024.04.02 12:03 [3044945] smart account 3N5Z4dAWzfkEp4kNJZKQk6zf3uTVFFz5MFF > SELF 0.00000000 Waves
{ "type": 13, "id": "EzydaTK6rzUmknGewLy9YWPQxjW3yL3SAZFYnmsB9YE9", "fee": 1500000, "feeAssetId": null, "timestamp": 1712048536447, "version": 2, "chainId": 84, "sender": "3N5Z4dAWzfkEp4kNJZKQk6zf3uTVFFz5MFF", "senderPublicKey": "8Vp8fmB3ZGVRre7Cw5j9z6qXo3yD8ohPQ6agZ9mtVY5E", "proofs": [ "23ZeF4BqFofjRPpg7wjt7m5SmfvbUMTiNZ2Rn8fSYpDuJJJBsSy4kRuhNrTD674Z4WtRfrJWoz3wfPyF7rQTXGNs" ], "script": "base64:BwIyCAISBgoEAQgICBIAEgMKAQgSBQoDAQgIEgMKAQESBQoDCAgIEgASABIDCgEIEgMKAQg6AAlTRVBBUkFUT1ICAl9fAAxLRVlfTVVMVElTSUcCCE1VTFRJU0lHAApLRVlfU1RBVFVTAgZTVEFUVVMACEtFWV9JTklUAgRJTklUAApLRVlfUEFVU0VEAgZQQVVTRUQACktFWV9QQVVTRVICBlBBVVNFUgAJS0VZX0NIQUlOAgVDSEFJTgAUS0VZX0dBVEVXQVlfQ09OVFJBQ1QCEEdBVEVXQVlfQ09OVFJBQ1QAE0tFWV9TV0FWRVNfQ09OVFJBQ1QCD1NXQVZFU19DT05UUkFDVAAQS0VZX1NXQVZFU19BU1NFVAIFQVNTRVQADEtFWV9SRVNFUlZFUwIIUkVTRVJWRVMADEZVTkNfREVQT1NJVAIHZGVwb3NpdAAXRlVOQ19SRVFVRVNUX1dJVEhEUkFXQUwCEXJlcXVlc3RXaXRoZHJhd2FsABdGVU5DX0VYRUNVVEVfV0lUSERSQVdBTAIRZXhlY3V0ZVdpdGhkcmF3YWwADUZVTkNfR0VUX1JBVEUCB2dldFJhdGUADUZVTkNfV0lUSERSQVcCCHdpdGhkcmF3AAVXQVZFUwIFV0FWRVMADldBVkVTX0RFQ0lNQUxTAAgADERFWF9ERUNJTUFMUwAIAAdNQVhfSU5UAP//////////fwALWkVST19CSUdJTlQJALYCAQAAAApPTkVfQklHSU5UCQC2AgEAAQASU1dBVkVTX1JBVEVfRkFDVE9SCQC2AgEAgKCUpY0dARBfdmFsaWRhdGVBZGRyZXNzAghhZGRyZXNzXwRlcnJfBAckbWF0Y2gwCQCmCAEFCGFkZHJlc3NfAwkAAQIFByRtYXRjaDACB0FkZHJlc3MEAWEFByRtYXRjaDAGCQACAQUEZXJyXwEOX3ZhbGlkYXRlQXNzZXQCCGFzc2V0SWRfBGVycl8DCQAAAgUIYXNzZXRJZF8FBVdBVkVTBgQHJG1hdGNoMAkA7AcBCQDZBAEFCGFzc2V0SWRfAwkAAQIFByRtYXRjaDACBUFzc2V0BAFhBQckbWF0Y2gwBgkAAgEFBGVycl8BDF92YWxpZGF0ZUludAQEdmFsXw5sb3dlckJvdW5kYXJ5Xw51cHBlckJvdW5kYXJ5XwRlcnJfAwMJAGYCBQ5sb3dlckJvdW5kYXJ5XwUEdmFsXwYJAGYCBQR2YWxfBQ51cHBlckJvdW5kYXJ5XwkAAgEFBGVycl8GAQ9fdmFsaWRhdGVCaWdJbnQDBHZhbF8ObG93ZXJCb3VuZGFyeV8EZXJyXwMJAL8CAgUObG93ZXJCb3VuZGFyeV8FBHZhbF8JAAIBBQRlcnJfBgEPX3ZhbGlkYXRlU3RyaW5nAgR2YWxfBGVycl8DAwkAZwIAAAkAsQIBBQR2YWxfBgkBCGNvbnRhaW5zAgUEdmFsXwUJU0VQQVJBVE9SCQACAQUEZXJyXwYBFV92YWxpZGF0ZVBheW1lbnRzU2l6ZQMJcGF5bWVudHNfB3RhcmdldF8EZXJyXwMJAQIhPQIJAJADAQUJcGF5bWVudHNfBQd0YXJnZXRfCQACAQUEZXJyXwYBC19hc3NldFRvU3RyAQZhc3NldF8EByRtYXRjaDAFBmFzc2V0XwMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAFhBQckbWF0Y2gwCQDYBAEFAWEFBVdBVkVTAQtfc3RyVG9Bc3NldAEGYXNzZXRfAwkAAAIFBmFzc2V0XwUFV0FWRVMFBHVuaXQJANkEAQUGYXNzZXRfAQxfZ2V0RGVjaW1hbHMBCGFzc2V0SWRfAwkAAAIFCGFzc2V0SWRfBQVXQVZFUwUOV0FWRVNfREVDSU1BTFMEByRtYXRjaDAJAOwHAQkA2QQBBQhhc3NldElkXwMJAAECBQckbWF0Y2gwAgVBc3NldAQBYQUHJG1hdGNoMAgFAWEIZGVjaW1hbHMJAAIBCQCsAgICF19nZXREZWNpbWFsczogbm8gYXNzZXQ9BQhhc3NldElkXwESX25vcm1hbGl6ZURlY2ltYWxzAwdhbW91bnRfD3NvdXJjZURlY2ltYWxzXw90YXJnZXREZWNpbWFsc18DCQBnAgUPc291cmNlRGVjaW1hbHNfBQ90YXJnZXREZWNpbWFsc18JAGkCBQdhbW91bnRfCQBsBgAKAAAJAGUCBQ9zb3VyY2VEZWNpbWFsc18FD3RhcmdldERlY2ltYWxzXwAAAAAFBERPV04JAGgCBQdhbW91bnRfCQBsBgAKAAAJAGUCBQ90YXJnZXREZWNpbWFsc18FD3NvdXJjZURlY2ltYWxzXwAAAAAFBERPV04BCV9sb2FkSW5pdAAEByRtYXRjaDAJAKAIAQUIS0VZX0lOSVQDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBYQUHJG1hdGNoMAUBYQcBCV9zYXZlSW5pdAEHaXNJbml0XwkAzAgCCQEMQm9vbGVhbkVudHJ5AgUIS0VZX0lOSVQFB2lzSW5pdF8FA25pbAEKX2xvYWRQYXVzZQAEByRtYXRjaDAJAKAIAQUKS0VZX1BBVVNFRAMJAAECBQckbWF0Y2gwAgdCb29sZWFuBAFhBQckbWF0Y2gwBQFhBwEKX3NhdmVQYXVzZQEJaXNQYXVzZWRfCQDMCAIJAQxCb29sZWFuRW50cnkCBQpLRVlfUEFVU0VEBQlpc1BhdXNlZF8FA25pbAELX2xvYWRQYXVzZXIABAckbWF0Y2gwCQCiCAEFCktFWV9QQVVTRVIDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFhBQckbWF0Y2gwCQERQGV4dHJOYXRpdmUoMTA2MikBBQFhCQEHQWRkcmVzcwEBAAELX3NhdmVQYXVzZXIBB3BhdXNlcl8JAMwIAgkBC1N0cmluZ0VudHJ5AgUKS0VZX1BBVVNFUgkApQgBBQdwYXVzZXJfBQNuaWwBDV9sb2FkTXVsdGlzaWcABAckbWF0Y2gwCQCiCAEFDEtFWV9NVUxUSVNJRwMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAWEFByRtYXRjaDAJARFAZXh0ck5hdGl2ZSgxMDYyKQEFAWEJAQdBZGRyZXNzAQEAAQ1fc2F2ZU11bHRpc2lnAQltdWx0aXNpZ18JAMwIAgkBC1N0cmluZ0VudHJ5AgUMS0VZX01VTFRJU0lHCQClCAEFCW11bHRpc2lnXwUDbmlsAQxfbG9hZENoYWluSWQABAckbWF0Y2gwCQCfCAEFCUtFWV9DSEFJTgMJAAECBQckbWF0Y2gwAgNJbnQEAWEFByRtYXRjaDAFAWEAAAEMX3NhdmVDaGFpbklkAQhjaGFpbklkXwkAzAgCCQEMSW50ZWdlckVudHJ5AgUJS0VZX0NIQUlOBQhjaGFpbklkXwUDbmlsARRfbG9hZEdhdGV3YXlDb250cmFjdAAEByRtYXRjaDAJAKIIAQUUS0VZX0dBVEVXQVlfQ09OVFJBQ1QDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFhBQckbWF0Y2gwCQERQGV4dHJOYXRpdmUoMTA2MikBBQFhCQEHQWRkcmVzcwEBAAEUX3NhdmVHYXRld2F5Q29udHJhY3QBEGdhdGV3YXlDb250cmFjdF8JAMwIAgkBC1N0cmluZ0VudHJ5AgUUS0VZX0dBVEVXQVlfQ09OVFJBQ1QJAKUIAQUQZ2F0ZXdheUNvbnRyYWN0XwUDbmlsARNfbG9hZFNXYXZlc0NvbnRyYWN0AAQHJG1hdGNoMAkAoggBBRNLRVlfU1dBVkVTX0NPTlRSQUNUAwkAAQIFByRtYXRjaDACBlN0cmluZwQBYQUHJG1hdGNoMAkBEUBleHRyTmF0aXZlKDEwNjIpAQUBYQkBB0FkZHJlc3MBAQABE19zYXZlU1dhdmVzQ29udHJhY3QBD3NXYXZlc0NvbnRyYWN0XwkAzAgCCQELU3RyaW5nRW50cnkCBRNLRVlfU1dBVkVTX0NPTlRSQUNUCQClCAEFD3NXYXZlc0NvbnRyYWN0XwUDbmlsARBfbG9hZFNXYXZlc0Fzc2V0AQljb250cmFjdF8EByRtYXRjaDAJAJ0IAgUJY29udHJhY3RfBRBLRVlfU1dBVkVTX0FTU0VUAwkAAQIFByRtYXRjaDACBlN0cmluZwQBYQUHJG1hdGNoMAkA2QQBBQFhCQACAQIYX2xvYWRTV2F2ZXNBc3NldDogcmV2ZXJ0AQ1fbG9hZFJlc2VydmVzAQZhc3NldF8EByRtYXRjaDAJAJ8IAQkAuQkCCQDMCAIFDEtFWV9SRVNFUlZFUwkAzAgCBQZhc3NldF8FA25pbAUJU0VQQVJBVE9SAwkAAQIFByRtYXRjaDACA0ludAQBYQUHJG1hdGNoMAUBYQAAAQ1fc2F2ZVJlc2VydmVzAgZhc3NldF8JcmVzZXJ2ZXNfCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQC5CQIJAMwIAgUMS0VZX1JFU0VSVkVTCQDMCAIFBmFzc2V0XwUDbmlsBQlTRVBBUkFUT1IFCXJlc2VydmVzXwUDbmlsARFfb25seVRoaXNDb250cmFjdAEHY2FsbGVyXwMJAQIhPQIFB2NhbGxlcl8FBHRoaXMJAAIBAhlfb25seVRoaXNDb250cmFjdDogcmV2ZXJ0BgEQX3doZW5NdWx0aXNpZ1NldAADCQAAAgkBDV9sb2FkTXVsdGlzaWcACQEHQWRkcmVzcwEBAAkAAgECGF93aGVuTXVsdGlzaWdTZXQ6IHJldmVydAYBE193aGVuTm90SW5pdGlhbGl6ZWQAAwkBCV9sb2FkSW5pdAAJAAIBAhtfd2hlbk5vdEluaXRpYWxpemVkOiByZXZlcnQGARBfd2hlbkluaXRpYWxpemVkAAMJAQEhAQkBCV9sb2FkSW5pdAAJAAIBAhhfd2hlbkluaXRpYWxpemVkOiByZXZlcnQGAQ5fd2hlbk5vdFBhdXNlZAADCQEKX2xvYWRQYXVzZQAJAAIBAhZfd2hlbk5vdFBhdXNlZDogcmV2ZXJ0BgELX3doZW5QYXVzZWQAAwkBASEBCQEKX2xvYWRQYXVzZQAJAAIBAhNfd2hlblBhdXNlZDogcmV2ZXJ0BgELX29ubHlQYXVzZXIBB2NhbGxlcl8DCQECIT0CBQdjYWxsZXJfCQELX2xvYWRQYXVzZXIACQACAQITX29ubHlQYXVzZXI6IHJldmVydAYBEF92YWxpZGF0ZUdhdGV3YXkCBmNhbGxlcgRlcnJfAwkBAiE9AgkBFF9sb2FkR2F0ZXdheUNvbnRyYWN0AAUGY2FsbGVyCQACAQUEZXJyXwYKAWkBBGluaXQECGNoYWluSWRfB3BhdXNlcl8QZ2F0ZXdheUNvbnRyYWN0Xw9zV2F2ZXNDb250cmFjdF8EA2VycgMDAwMDAwkBEV9vbmx5VGhpc0NvbnRyYWN0AQgFAWkGY2FsbGVyCQETX3doZW5Ob3RJbml0aWFsaXplZAAHCQEQX3doZW5NdWx0aXNpZ1NldAAHCQEMX3ZhbGlkYXRlSW50BAUIY2hhaW5JZF8AAAUHTUFYX0lOVAIVaW5pdDogaW52YWxpZCBjaGFpbklkBwkBEF92YWxpZGF0ZUFkZHJlc3MCBQdwYXVzZXJfAhRpbml0OiBpbnZhbGlkIHBhdXNlcgcJARBfdmFsaWRhdGVBZGRyZXNzAgUQZ2F0ZXdheUNvbnRyYWN0XwIdaW5pdDogaW52YWxpZCBnYXRld2F5Q29udHJhY3QHCQEQX3ZhbGlkYXRlQWRkcmVzcwIFD3NXYXZlc0NvbnRyYWN0XwIcaW5pdDogaW52YWxpZCBzV2F2ZXNDb250cmFjdAcDCQAAAgUDZXJyBQNlcnIJAJQKAgkAzggCCQDOCAIJAM4IAgkAzggCCQEJX3NhdmVJbml0AQYJAQxfc2F2ZUNoYWluSWQBBQhjaGFpbklkXwkBC19zYXZlUGF1c2VyAQkBEUBleHRyTmF0aXZlKDEwNjIpAQUHcGF1c2VyXwkBFF9zYXZlR2F0ZXdheUNvbnRyYWN0AQkBEUBleHRyTmF0aXZlKDEwNjIpAQUQZ2F0ZXdheUNvbnRyYWN0XwkBE19zYXZlU1dhdmVzQ29udHJhY3QBCQERQGV4dHJOYXRpdmUoMTA2MikBBQ9zV2F2ZXNDb250cmFjdF8FBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEHZGVwb3NpdAAEA2VycgMDAwkBEF93aGVuSW5pdGlhbGl6ZWQACQEOX3doZW5Ob3RQYXVzZWQABwkBFV92YWxpZGF0ZVBheW1lbnRzU2l6ZQMIBQFpCHBheW1lbnRzAAECE2RlcG9zaXQ6IG5vIHBheW1lbnQHCQEMX3ZhbGlkYXRlSW50BAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQAAAUHTUFYX0lOVAIZZGVwb3NpdDogbmVnYXRpdmUgcGF5bWVudAcDCQAAAgUDZXJyBQNlcnIEBmNhbGxlcgkApQgBCAUBaQZjYWxsZXIEBWFzc2V0CQELX2Fzc2V0VG9TdHIBCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQEDWFzc2V0RGVjaW1hbHMJAQxfZ2V0RGVjaW1hbHMBBQVhc3NldAQGYW1vdW50CQESX25vcm1hbGl6ZURlY2ltYWxzAwgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQFDWFzc2V0RGVjaW1hbHMFDERFWF9ERUNJTUFMUwQEZXJyMQkBDF92YWxpZGF0ZUludAQFBmFtb3VudAABBQdNQVhfSU5UAh9kZXBvc2l0OiBpbnZhbGlkIHBheW1lbnQgYW1vdW50AwkAAAIFBGVycjEFBGVycjEEEWdhdGV3YXlJbnZvY2F0aW9uCQD8BwQJARRfbG9hZEdhdGV3YXlDb250cmFjdAAFDEZVTkNfREVQT1NJVAkAzAgCCQClCAEFBHRoaXMJAMwIAgUGY2FsbGVyCQDMCAIFBmNhbGxlcgkAzAgCCQCkAwEJAQxfbG9hZENoYWluSWQACQDMCAIFBWFzc2V0CQDMCAIJAKQDAQUGYW1vdW50BQNuaWwFA25pbAMJAAACBRFnYXRld2F5SW52b2NhdGlvbgURZ2F0ZXdheUludm9jYXRpb24EEXN0YWtpbmdJbnZvY2F0aW9uAwkAAAIFBWFzc2V0BQVXQVZFUwkA/AcECQETX2xvYWRTV2F2ZXNDb250cmFjdAAFDEZVTkNfREVQT1NJVAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQR1bml0CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAUDbmlsBQR1bml0AwkAAAIFEXN0YWtpbmdJbnZvY2F0aW9uBRFzdGFraW5nSW52b2NhdGlvbgkAlAoCCQENX3NhdmVSZXNlcnZlcwIFBWFzc2V0CQBkAgkBDV9sb2FkUmVzZXJ2ZXMBBQVhc3NldAUGYW1vdW50BQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBCWRlcG9zaXRUbwEDdG9fBANlcnIDAwMDCQEQX3doZW5Jbml0aWFsaXplZAAJAQ5fd2hlbk5vdFBhdXNlZAAHCQEVX3ZhbGlkYXRlUGF5bWVudHNTaXplAwgFAWkIcGF5bWVudHMAAQIVZGVwb3NpdFRvOiBubyBwYXltZW50BwkBDF92YWxpZGF0ZUludAQICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50AAAFB01BWF9JTlQCG2RlcG9zaXRUbzogbmVnYXRpdmUgcGF5bWVudAcJAQ9fdmFsaWRhdGVTdHJpbmcCBQN0b18CFWRlcG9zaXRUbzogaW52YWxpZCB0bwcDCQAAAgUDZXJyBQNlcnIEBmNhbGxlcgkApQgBCAUBaQZjYWxsZXIEBWFzc2V0CQELX2Fzc2V0VG9TdHIBCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQEDWFzc2V0RGVjaW1hbHMJAQxfZ2V0RGVjaW1hbHMBBQVhc3NldAQGYW1vdW50CQESX25vcm1hbGl6ZURlY2ltYWxzAwgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQFDWFzc2V0RGVjaW1hbHMFDERFWF9ERUNJTUFMUwQEZXJyMQkBDF92YWxpZGF0ZUludAQFBmFtb3VudAABBQdNQVhfSU5UAiFkZXBvc2l0VG86IGludmFsaWQgcGF5bWVudCBhbW91bnQDCQAAAgUEZXJyMQUEZXJyMQQRZ2F0ZXdheUludm9jYXRpb24JAPwHBAkBFF9sb2FkR2F0ZXdheUNvbnRyYWN0AAUMRlVOQ19ERVBPU0lUCQDMCAIJAKUIAQUEdGhpcwkAzAgCBQZjYWxsZXIJAMwIAgUDdG9fCQDMCAIJAKQDAQkBDF9sb2FkQ2hhaW5JZAAJAMwIAgUFYXNzZXQJAMwIAgkApAMBBQZhbW91bnQFA25pbAUDbmlsAwkAAAIFEWdhdGV3YXlJbnZvY2F0aW9uBRFnYXRld2F5SW52b2NhdGlvbgQRc3Rha2luZ0ludm9jYXRpb24DCQAAAgUFYXNzZXQFBVdBVkVTCQD8BwQJARNfbG9hZFNXYXZlc0NvbnRyYWN0AAUMRlVOQ19ERVBPU0lUBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFBHVuaXQICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BQNuaWwFBHVuaXQDCQAAAgURc3Rha2luZ0ludm9jYXRpb24FEXN0YWtpbmdJbnZvY2F0aW9uCQCUCgIJAQ1fc2F2ZVJlc2VydmVzAgUFYXNzZXQJAGQCCQENX2xvYWRSZXNlcnZlcwEFBWFzc2V0BQZhbW91bnQFBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQERcmVxdWVzdFdpdGhkcmF3YWwDCnRvQ2hhaW5JZF8GYXNzZXRfB2Ftb3VudF8EBmFtb3VudAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCoAwEFB2Ftb3VudF8CIXJlcXVlc3RXaXRoZHJhd2FsOiBhbW91bnQgbm90IGludAQDZXJyAwMDCQEQX3doZW5Jbml0aWFsaXplZAAJAQxfdmFsaWRhdGVJbnQEBQp0b0NoYWluSWRfAAAFB01BWF9JTlQCJHJlcXVlc3RXaXRoZHJhd2FsOiBpbnZhbGlkIHRvQ2hhaW5JZAcJAQ9fdmFsaWRhdGVTdHJpbmcCBQZhc3NldF8CIHJlcXVlc3RXaXRoZHJhd2FsOiBpbnZhbGlkIGFzc2V0BwkBD192YWxpZGF0ZUJpZ0ludAMFBmFtb3VudAUKT05FX0JJR0lOVAIicmVxdWVzdFdpdGhkcmF3YWw6IG5lZ2F0aXZlIGFtb3VudAcDCQAAAgUDZXJyBQNlcnIEBmNhbGxlcgkApQgBCAUBaQZjYWxsZXIEE3JlcXVlc3RXaXRoZHJhd2FsSWQEByRtYXRjaDAJAPwHBAkBFF9sb2FkR2F0ZXdheUNvbnRyYWN0AAUXRlVOQ19SRVFVRVNUX1dJVEhEUkFXQUwJAMwIAgkApQgBBQR0aGlzCQDMCAIFBmNhbGxlcgkAzAgCBQZjYWxsZXIJAMwIAgkApAMBCQEMX2xvYWRDaGFpbklkAAkAzAgCCQCkAwEFCnRvQ2hhaW5JZF8JAMwIAgUGYXNzZXRfCQDMCAIFB2Ftb3VudF8FA25pbAUDbmlsAwkAAQIFByRtYXRjaDACA0ludAQBYQUHJG1hdGNoMAUBYQkAAgECKHJlcXVlc3RXaXRoZHJhd2FsOiBjYWxsIHJldmVydGVkIGZyb20gZ3cDCQAAAgUTcmVxdWVzdFdpdGhkcmF3YWxJZAUTcmVxdWVzdFdpdGhkcmF3YWxJZAkAlAoCBQNuaWwFE3JlcXVlc3RXaXRoZHJhd2FsSWQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQERZXhlY3V0ZVdpdGhkcmF3YWwBFHJlcXVlc3RXaXRoZHJhd2FsSWRfBANlcnIDCQEQX3doZW5Jbml0aWFsaXplZAAJAQxfdmFsaWRhdGVJbnQEBRRyZXF1ZXN0V2l0aGRyYXdhbElkXwAABQdNQVhfSU5UAiRleGVjdXRlV2l0aGRyYXdhbDogaW52YWxpZCByZXF1ZXN0SWQHAwkAAAIFA2VycgUDZXJyBBFnYXRld2F5SW52b2NhdGlvbgkA/QcECQEUX2xvYWRHYXRld2F5Q29udHJhY3QABRdGVU5DX0VYRUNVVEVfV0lUSERSQVdBTAkAzAgCCQClCAEFBHRoaXMJAMwIAgkApAMBCQEMX2xvYWRDaGFpbklkAAkAzAgCCQCkAwEFFHJlcXVlc3RXaXRoZHJhd2FsSWRfBQNuaWwFA25pbAMJAAACBRFnYXRld2F5SW52b2NhdGlvbgURZ2F0ZXdheUludm9jYXRpb24JAJQKAgUDbmlsBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBCHdpdGhkcmF3AwN0b18GYXNzZXRfB2Ftb3VudF8EBmFtb3VudAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQC2CQEFB2Ftb3VudF8CGHdpdGhkcmF3OiBhbW91bnQgbm90IGludAQDZXJyAwMDAwkBEF93aGVuSW5pdGlhbGl6ZWQACQEQX3ZhbGlkYXRlR2F0ZXdheQIIBQFpBmNhbGxlcgIZd2l0aGRyYXc6IGludmFsaWQgZ2F0ZXdheQcJARBfdmFsaWRhdGVBZGRyZXNzAgUDdG9fAhl3aXRoZHJhdzogaW52YWxpZCBhZGRyZXNzBwkBDl92YWxpZGF0ZUFzc2V0AgUGYXNzZXRfAhd3aXRoZHJhdzogaW52YWxpZCBhc3NldAcJAQxfdmFsaWRhdGVJbnQEBQZhbW91bnQAAAUHTUFYX0lOVAIZd2l0aGRyYXc6IG5lZ2F0aXZlIGFtb3VudAcDCQAAAgUDZXJyBQNlcnIEDWFzc2V0RGVjaW1hbHMJAQxfZ2V0RGVjaW1hbHMBBQZhc3NldF8EEGFtb3VudE5vcm1hbGl6ZWQJARJfbm9ybWFsaXplRGVjaW1hbHMDBQZhbW91bnQFDERFWF9ERUNJTUFMUwUNYXNzZXREZWNpbWFscwQLbmV3UmVzZXJ2ZXMJAGUCCQENX2xvYWRSZXNlcnZlcwEFBmFzc2V0XwUGYW1vdW50BARlcnIxAwkBDF92YWxpZGF0ZUludAQFEGFtb3VudE5vcm1hbGl6ZWQAAQUHTUFYX0lOVAIYd2l0aGRyYXc6IGludmFsaWQgYW1vdW50CQEMX3ZhbGlkYXRlSW50BAULbmV3UmVzZXJ2ZXMAAAUHTUFYX0lOVAIed2l0aGRyYXc6IG5lZ2F0aXZlIG5ld1Jlc2VydmVzBwMJAAACBQRlcnIxBQRlcnIxBBN1bnN0YWtpbmdJbnZvY2F0aW9uAwkAAAIFBmFzc2V0XwUFV0FWRVMEDnNXYXZlc0NvbnRyYWN0CQETX2xvYWRTV2F2ZXNDb250cmFjdAAEC3NXYXZlc0Fzc2V0CQEQX2xvYWRTV2F2ZXNBc3NldAEFDnNXYXZlc0NvbnRyYWN0BAppbnZvY2F0aW9uCQD8BwQFDnNXYXZlc0NvbnRyYWN0BQ1GVU5DX0dFVF9SQVRFBQNuaWwFA25pbAQEcmF0ZQQHJG1hdGNoMAUKaW52b2NhdGlvbgMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAWEFByRtYXRjaDAJAKcDAQUBYQkAAgECIXdpdGhkcmF3OiBzV2F2ZXMgZ2V0UmF0ZSgpIHJldmVydAQQc1dhdmVzVG9XaXRoZHJhdwkAoAMBCQC9AgQJALYCAQUQYW1vdW50Tm9ybWFsaXplZAUSU1dBVkVTX1JBVEVfRkFDVE9SBQRyYXRlBQdDRUlMSU5HCQD8BwQFDnNXYXZlc0NvbnRyYWN0BQ1GVU5DX1dJVEhEUkFXBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFC3NXYXZlc0Fzc2V0BRBzV2F2ZXNUb1dpdGhkcmF3BQNuaWwFBHVuaXQDCQAAAgUTdW5zdGFraW5nSW52b2NhdGlvbgUTdW5zdGFraW5nSW52b2NhdGlvbgkAlAoCCQDOCAIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBEUBleHRyTmF0aXZlKDEwNjIpAQUDdG9fBRBhbW91bnROb3JtYWxpemVkCQELX3N0clRvQXNzZXQBBQZhc3NldF8FA25pbAkBDV9zYXZlUmVzZXJ2ZXMCBQZhc3NldF8FC25ld1Jlc2VydmVzBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBBXBhdXNlAAQDZXJyAwMJAQtfb25seVBhdXNlcgEIBQFpBmNhbGxlcgkBEF93aGVuSW5pdGlhbGl6ZWQABwkBDl93aGVuTm90UGF1c2VkAAcDCQAAAgUDZXJyBQNlcnIJAJQKAgkBCl9zYXZlUGF1c2UBBgUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQd1bnBhdXNlAAQDZXJyAwMJAQtfb25seVBhdXNlcgEIBQFpBmNhbGxlcgkBEF93aGVuSW5pdGlhbGl6ZWQABwkBC193aGVuUGF1c2VkAAcDCQAAAgUDZXJyBQNlcnIJAJQKAgkBCl9zYXZlUGF1c2UBBwUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQx1cGRhdGVQYXVzZXIBB3BhdXNlcl8EA2VycgMDCQERX29ubHlUaGlzQ29udHJhY3QBCAUBaQZjYWxsZXIJARBfd2hlbkluaXRpYWxpemVkAAcJARBfdmFsaWRhdGVBZGRyZXNzAgUHcGF1c2VyXwIcdXBkYXRlUGF1c2VyOiBpbnZhbGlkIHBhdXNlcgcDCQAAAgUDZXJyBQNlcnIJAJQKAgkBC19zYXZlUGF1c2VyAQkBEUBleHRyTmF0aXZlKDEwNjIpAQUHcGF1c2VyXwUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQtzZXRNdWx0aXNpZwEJbXVsdGlzaWdfBANlcnIDCQERX29ubHlUaGlzQ29udHJhY3QBCAUBaQZjYWxsZXIJARBfdmFsaWRhdGVBZGRyZXNzAgUJbXVsdGlzaWdfAh1zZXRNdWx0aXNpZzogaW52YWxpZCBtdWx0aXNpZwcDCQAAAgUDZXJyBQNlcnIJAJQKAgkBDV9zYXZlTXVsdGlzaWcBCQERQGV4dHJOYXRpdmUoMTA2MikBBQltdWx0aXNpZ18FBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAnR4AQZ2ZXJpZnkABAckbWF0Y2gwCQCiCAEFDEtFWV9NVUxUSVNJRwMJAAECBQckbWF0Y2gwAgZTdHJpbmcECG11bHRpc2lnBQckbWF0Y2gwCQELdmFsdWVPckVsc2UCCQCbCAIJARFAZXh0ck5hdGl2ZSgxMDYyKQEFCG11bHRpc2lnCQC5CQIJAMwIAgUKS0VZX1NUQVRVUwkAzAgCCQClCAEFBHRoaXMJAMwIAgkA2AQBCAUCdHgCaWQFA25pbAUJU0VQQVJBVE9SBwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAgFAnR4D3NlbmRlclB1YmxpY0tleSRtRiI=", "height": 3044945, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: GiVAXqKK9S95Kuu9jMqqdBeXcL1WCRBLc3Xk6yq5HFuL Next: none Diff:
Old | New | Differences | |
---|---|---|---|
41 | 41 | ||
42 | 42 | let MAX_INT = 9223372036854775807 | |
43 | 43 | ||
44 | + | let ZERO_BIGINT = toBigInt(0) | |
45 | + | ||
46 | + | let ONE_BIGINT = toBigInt(1) | |
47 | + | ||
44 | 48 | let SWAVES_RATE_FACTOR = toBigInt(1000000000000) | |
45 | 49 | ||
46 | 50 | func _validateAddress (address_,err_) = match addressFromString(address_) { | |
64 | 68 | func _validateInt (val_,lowerBoundary_,upperBoundary_,err_) = if (if ((lowerBoundary_ > val_)) | |
65 | 69 | then true | |
66 | 70 | else (val_ > upperBoundary_)) | |
71 | + | then throw(err_) | |
72 | + | else true | |
73 | + | ||
74 | + | ||
75 | + | func _validateBigInt (val_,lowerBoundary_,err_) = if ((lowerBoundary_ > val_)) | |
67 | 76 | then throw(err_) | |
68 | 77 | else true | |
69 | 78 | ||
344 | 353 | ||
345 | 354 | @Callable(i) | |
346 | 355 | func requestWithdrawal (toChainId_,asset_,amount_) = { | |
356 | + | let amount = valueOrErrorMessage(parseBigInt(amount_), "requestWithdrawal: amount not int") | |
347 | 357 | let err = if (if (if (_whenInitialized()) | |
348 | 358 | then _validateInt(toChainId_, 0, MAX_INT, "requestWithdrawal: invalid toChainId") | |
349 | 359 | else false) | |
350 | 360 | then _validateString(asset_, "requestWithdrawal: invalid asset") | |
351 | 361 | else false) | |
352 | - | then _ | |
362 | + | then _validateBigInt(amount, ONE_BIGINT, "requestWithdrawal: negative amount") | |
353 | 363 | else false | |
354 | 364 | if ((err == err)) | |
355 | 365 | then { | |
356 | 366 | let caller = toString(i.caller) | |
357 | - | let requestWithdrawalId = match invoke(_loadGatewayContract(), FUNC_REQUEST_WITHDRAWAL, [toString(this), caller, caller, toString(_loadChainId()), toString(toChainId_), asset_, | |
367 | + | let requestWithdrawalId = match invoke(_loadGatewayContract(), FUNC_REQUEST_WITHDRAWAL, [toString(this), caller, caller, toString(_loadChainId()), toString(toChainId_), asset_, amount_], nil) { | |
358 | 368 | case a: Int => | |
359 | 369 | a | |
360 | 370 | case _ => |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 7 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let SEPARATOR = "__" | |
5 | 5 | ||
6 | 6 | let KEY_MULTISIG = "MULTISIG" | |
7 | 7 | ||
8 | 8 | let KEY_STATUS = "STATUS" | |
9 | 9 | ||
10 | 10 | let KEY_INIT = "INIT" | |
11 | 11 | ||
12 | 12 | let KEY_PAUSED = "PAUSED" | |
13 | 13 | ||
14 | 14 | let KEY_PAUSER = "PAUSER" | |
15 | 15 | ||
16 | 16 | let KEY_CHAIN = "CHAIN" | |
17 | 17 | ||
18 | 18 | let KEY_GATEWAY_CONTRACT = "GATEWAY_CONTRACT" | |
19 | 19 | ||
20 | 20 | let KEY_SWAVES_CONTRACT = "SWAVES_CONTRACT" | |
21 | 21 | ||
22 | 22 | let KEY_SWAVES_ASSET = "ASSET" | |
23 | 23 | ||
24 | 24 | let KEY_RESERVES = "RESERVES" | |
25 | 25 | ||
26 | 26 | let FUNC_DEPOSIT = "deposit" | |
27 | 27 | ||
28 | 28 | let FUNC_REQUEST_WITHDRAWAL = "requestWithdrawal" | |
29 | 29 | ||
30 | 30 | let FUNC_EXECUTE_WITHDRAWAL = "executeWithdrawal" | |
31 | 31 | ||
32 | 32 | let FUNC_GET_RATE = "getRate" | |
33 | 33 | ||
34 | 34 | let FUNC_WITHDRAW = "withdraw" | |
35 | 35 | ||
36 | 36 | let WAVES = "WAVES" | |
37 | 37 | ||
38 | 38 | let WAVES_DECIMALS = 8 | |
39 | 39 | ||
40 | 40 | let DEX_DECIMALS = 8 | |
41 | 41 | ||
42 | 42 | let MAX_INT = 9223372036854775807 | |
43 | 43 | ||
44 | + | let ZERO_BIGINT = toBigInt(0) | |
45 | + | ||
46 | + | let ONE_BIGINT = toBigInt(1) | |
47 | + | ||
44 | 48 | let SWAVES_RATE_FACTOR = toBigInt(1000000000000) | |
45 | 49 | ||
46 | 50 | func _validateAddress (address_,err_) = match addressFromString(address_) { | |
47 | 51 | case a: Address => | |
48 | 52 | true | |
49 | 53 | case _ => | |
50 | 54 | throw(err_) | |
51 | 55 | } | |
52 | 56 | ||
53 | 57 | ||
54 | 58 | func _validateAsset (assetId_,err_) = if ((assetId_ == WAVES)) | |
55 | 59 | then true | |
56 | 60 | else match assetInfo(fromBase58String(assetId_)) { | |
57 | 61 | case a: Asset => | |
58 | 62 | true | |
59 | 63 | case _ => | |
60 | 64 | throw(err_) | |
61 | 65 | } | |
62 | 66 | ||
63 | 67 | ||
64 | 68 | func _validateInt (val_,lowerBoundary_,upperBoundary_,err_) = if (if ((lowerBoundary_ > val_)) | |
65 | 69 | then true | |
66 | 70 | else (val_ > upperBoundary_)) | |
71 | + | then throw(err_) | |
72 | + | else true | |
73 | + | ||
74 | + | ||
75 | + | func _validateBigInt (val_,lowerBoundary_,err_) = if ((lowerBoundary_ > val_)) | |
67 | 76 | then throw(err_) | |
68 | 77 | else true | |
69 | 78 | ||
70 | 79 | ||
71 | 80 | func _validateString (val_,err_) = if (if ((0 >= size(val_))) | |
72 | 81 | then true | |
73 | 82 | else contains(val_, SEPARATOR)) | |
74 | 83 | then throw(err_) | |
75 | 84 | else true | |
76 | 85 | ||
77 | 86 | ||
78 | 87 | func _validatePaymentsSize (payments_,target_,err_) = if ((size(payments_) != target_)) | |
79 | 88 | then throw(err_) | |
80 | 89 | else true | |
81 | 90 | ||
82 | 91 | ||
83 | 92 | func _assetToStr (asset_) = match asset_ { | |
84 | 93 | case a: ByteVector => | |
85 | 94 | toBase58String(a) | |
86 | 95 | case _ => | |
87 | 96 | WAVES | |
88 | 97 | } | |
89 | 98 | ||
90 | 99 | ||
91 | 100 | func _strToAsset (asset_) = if ((asset_ == WAVES)) | |
92 | 101 | then unit | |
93 | 102 | else fromBase58String(asset_) | |
94 | 103 | ||
95 | 104 | ||
96 | 105 | func _getDecimals (assetId_) = if ((assetId_ == WAVES)) | |
97 | 106 | then WAVES_DECIMALS | |
98 | 107 | else match assetInfo(fromBase58String(assetId_)) { | |
99 | 108 | case a: Asset => | |
100 | 109 | a.decimals | |
101 | 110 | case _ => | |
102 | 111 | throw(("_getDecimals: no asset=" + assetId_)) | |
103 | 112 | } | |
104 | 113 | ||
105 | 114 | ||
106 | 115 | func _normalizeDecimals (amount_,sourceDecimals_,targetDecimals_) = if ((sourceDecimals_ >= targetDecimals_)) | |
107 | 116 | then (amount_ / pow(10, 0, (sourceDecimals_ - targetDecimals_), 0, 0, DOWN)) | |
108 | 117 | else (amount_ * pow(10, 0, (targetDecimals_ - sourceDecimals_), 0, 0, DOWN)) | |
109 | 118 | ||
110 | 119 | ||
111 | 120 | func _loadInit () = match getBoolean(KEY_INIT) { | |
112 | 121 | case a: Boolean => | |
113 | 122 | a | |
114 | 123 | case _ => | |
115 | 124 | false | |
116 | 125 | } | |
117 | 126 | ||
118 | 127 | ||
119 | 128 | func _saveInit (isInit_) = [BooleanEntry(KEY_INIT, isInit_)] | |
120 | 129 | ||
121 | 130 | ||
122 | 131 | func _loadPause () = match getBoolean(KEY_PAUSED) { | |
123 | 132 | case a: Boolean => | |
124 | 133 | a | |
125 | 134 | case _ => | |
126 | 135 | false | |
127 | 136 | } | |
128 | 137 | ||
129 | 138 | ||
130 | 139 | func _savePause (isPaused_) = [BooleanEntry(KEY_PAUSED, isPaused_)] | |
131 | 140 | ||
132 | 141 | ||
133 | 142 | func _loadPauser () = match getString(KEY_PAUSER) { | |
134 | 143 | case a: String => | |
135 | 144 | addressFromStringValue(a) | |
136 | 145 | case _ => | |
137 | 146 | Address(base58'') | |
138 | 147 | } | |
139 | 148 | ||
140 | 149 | ||
141 | 150 | func _savePauser (pauser_) = [StringEntry(KEY_PAUSER, toString(pauser_))] | |
142 | 151 | ||
143 | 152 | ||
144 | 153 | func _loadMultisig () = match getString(KEY_MULTISIG) { | |
145 | 154 | case a: String => | |
146 | 155 | addressFromStringValue(a) | |
147 | 156 | case _ => | |
148 | 157 | Address(base58'') | |
149 | 158 | } | |
150 | 159 | ||
151 | 160 | ||
152 | 161 | func _saveMultisig (multisig_) = [StringEntry(KEY_MULTISIG, toString(multisig_))] | |
153 | 162 | ||
154 | 163 | ||
155 | 164 | func _loadChainId () = match getInteger(KEY_CHAIN) { | |
156 | 165 | case a: Int => | |
157 | 166 | a | |
158 | 167 | case _ => | |
159 | 168 | 0 | |
160 | 169 | } | |
161 | 170 | ||
162 | 171 | ||
163 | 172 | func _saveChainId (chainId_) = [IntegerEntry(KEY_CHAIN, chainId_)] | |
164 | 173 | ||
165 | 174 | ||
166 | 175 | func _loadGatewayContract () = match getString(KEY_GATEWAY_CONTRACT) { | |
167 | 176 | case a: String => | |
168 | 177 | addressFromStringValue(a) | |
169 | 178 | case _ => | |
170 | 179 | Address(base58'') | |
171 | 180 | } | |
172 | 181 | ||
173 | 182 | ||
174 | 183 | func _saveGatewayContract (gatewayContract_) = [StringEntry(KEY_GATEWAY_CONTRACT, toString(gatewayContract_))] | |
175 | 184 | ||
176 | 185 | ||
177 | 186 | func _loadSWavesContract () = match getString(KEY_SWAVES_CONTRACT) { | |
178 | 187 | case a: String => | |
179 | 188 | addressFromStringValue(a) | |
180 | 189 | case _ => | |
181 | 190 | Address(base58'') | |
182 | 191 | } | |
183 | 192 | ||
184 | 193 | ||
185 | 194 | func _saveSWavesContract (sWavesContract_) = [StringEntry(KEY_SWAVES_CONTRACT, toString(sWavesContract_))] | |
186 | 195 | ||
187 | 196 | ||
188 | 197 | func _loadSWavesAsset (contract_) = match getString(contract_, KEY_SWAVES_ASSET) { | |
189 | 198 | case a: String => | |
190 | 199 | fromBase58String(a) | |
191 | 200 | case _ => | |
192 | 201 | throw("_loadSWavesAsset: revert") | |
193 | 202 | } | |
194 | 203 | ||
195 | 204 | ||
196 | 205 | func _loadReserves (asset_) = match getInteger(makeString([KEY_RESERVES, asset_], SEPARATOR)) { | |
197 | 206 | case a: Int => | |
198 | 207 | a | |
199 | 208 | case _ => | |
200 | 209 | 0 | |
201 | 210 | } | |
202 | 211 | ||
203 | 212 | ||
204 | 213 | func _saveReserves (asset_,reserves_) = [IntegerEntry(makeString([KEY_RESERVES, asset_], SEPARATOR), reserves_)] | |
205 | 214 | ||
206 | 215 | ||
207 | 216 | func _onlyThisContract (caller_) = if ((caller_ != this)) | |
208 | 217 | then throw("_onlyThisContract: revert") | |
209 | 218 | else true | |
210 | 219 | ||
211 | 220 | ||
212 | 221 | func _whenMultisigSet () = if ((_loadMultisig() == Address(base58''))) | |
213 | 222 | then throw("_whenMultisigSet: revert") | |
214 | 223 | else true | |
215 | 224 | ||
216 | 225 | ||
217 | 226 | func _whenNotInitialized () = if (_loadInit()) | |
218 | 227 | then throw("_whenNotInitialized: revert") | |
219 | 228 | else true | |
220 | 229 | ||
221 | 230 | ||
222 | 231 | func _whenInitialized () = if (!(_loadInit())) | |
223 | 232 | then throw("_whenInitialized: revert") | |
224 | 233 | else true | |
225 | 234 | ||
226 | 235 | ||
227 | 236 | func _whenNotPaused () = if (_loadPause()) | |
228 | 237 | then throw("_whenNotPaused: revert") | |
229 | 238 | else true | |
230 | 239 | ||
231 | 240 | ||
232 | 241 | func _whenPaused () = if (!(_loadPause())) | |
233 | 242 | then throw("_whenPaused: revert") | |
234 | 243 | else true | |
235 | 244 | ||
236 | 245 | ||
237 | 246 | func _onlyPauser (caller_) = if ((caller_ != _loadPauser())) | |
238 | 247 | then throw("_onlyPauser: revert") | |
239 | 248 | else true | |
240 | 249 | ||
241 | 250 | ||
242 | 251 | func _validateGateway (caller,err_) = if ((_loadGatewayContract() != caller)) | |
243 | 252 | then throw(err_) | |
244 | 253 | else true | |
245 | 254 | ||
246 | 255 | ||
247 | 256 | @Callable(i) | |
248 | 257 | func init (chainId_,pauser_,gatewayContract_,sWavesContract_) = { | |
249 | 258 | let err = if (if (if (if (if (if (_onlyThisContract(i.caller)) | |
250 | 259 | then _whenNotInitialized() | |
251 | 260 | else false) | |
252 | 261 | then _whenMultisigSet() | |
253 | 262 | else false) | |
254 | 263 | then _validateInt(chainId_, 0, MAX_INT, "init: invalid chainId") | |
255 | 264 | else false) | |
256 | 265 | then _validateAddress(pauser_, "init: invalid pauser") | |
257 | 266 | else false) | |
258 | 267 | then _validateAddress(gatewayContract_, "init: invalid gatewayContract") | |
259 | 268 | else false) | |
260 | 269 | then _validateAddress(sWavesContract_, "init: invalid sWavesContract") | |
261 | 270 | else false | |
262 | 271 | if ((err == err)) | |
263 | 272 | then $Tuple2(((((_saveInit(true) ++ _saveChainId(chainId_)) ++ _savePauser(addressFromStringValue(pauser_))) ++ _saveGatewayContract(addressFromStringValue(gatewayContract_))) ++ _saveSWavesContract(addressFromStringValue(sWavesContract_))), unit) | |
264 | 273 | else throw("Strict value is not equal to itself.") | |
265 | 274 | } | |
266 | 275 | ||
267 | 276 | ||
268 | 277 | ||
269 | 278 | @Callable(i) | |
270 | 279 | func deposit () = { | |
271 | 280 | let err = if (if (if (_whenInitialized()) | |
272 | 281 | then _whenNotPaused() | |
273 | 282 | else false) | |
274 | 283 | then _validatePaymentsSize(i.payments, 1, "deposit: no payment") | |
275 | 284 | else false) | |
276 | 285 | then _validateInt(i.payments[0].amount, 0, MAX_INT, "deposit: negative payment") | |
277 | 286 | else false | |
278 | 287 | if ((err == err)) | |
279 | 288 | then { | |
280 | 289 | let caller = toString(i.caller) | |
281 | 290 | let asset = _assetToStr(i.payments[0].assetId) | |
282 | 291 | let assetDecimals = _getDecimals(asset) | |
283 | 292 | let amount = _normalizeDecimals(i.payments[0].amount, assetDecimals, DEX_DECIMALS) | |
284 | 293 | let err1 = _validateInt(amount, 1, MAX_INT, "deposit: invalid payment amount") | |
285 | 294 | if ((err1 == err1)) | |
286 | 295 | then { | |
287 | 296 | let gatewayInvocation = invoke(_loadGatewayContract(), FUNC_DEPOSIT, [toString(this), caller, caller, toString(_loadChainId()), asset, toString(amount)], nil) | |
288 | 297 | if ((gatewayInvocation == gatewayInvocation)) | |
289 | 298 | then { | |
290 | 299 | let stakingInvocation = if ((asset == WAVES)) | |
291 | 300 | then invoke(_loadSWavesContract(), FUNC_DEPOSIT, nil, [AttachedPayment(unit, i.payments[0].amount)]) | |
292 | 301 | else unit | |
293 | 302 | if ((stakingInvocation == stakingInvocation)) | |
294 | 303 | then $Tuple2(_saveReserves(asset, (_loadReserves(asset) + amount)), unit) | |
295 | 304 | else throw("Strict value is not equal to itself.") | |
296 | 305 | } | |
297 | 306 | else throw("Strict value is not equal to itself.") | |
298 | 307 | } | |
299 | 308 | else throw("Strict value is not equal to itself.") | |
300 | 309 | } | |
301 | 310 | else throw("Strict value is not equal to itself.") | |
302 | 311 | } | |
303 | 312 | ||
304 | 313 | ||
305 | 314 | ||
306 | 315 | @Callable(i) | |
307 | 316 | func depositTo (to_) = { | |
308 | 317 | let err = if (if (if (if (_whenInitialized()) | |
309 | 318 | then _whenNotPaused() | |
310 | 319 | else false) | |
311 | 320 | then _validatePaymentsSize(i.payments, 1, "depositTo: no payment") | |
312 | 321 | else false) | |
313 | 322 | then _validateInt(i.payments[0].amount, 0, MAX_INT, "depositTo: negative payment") | |
314 | 323 | else false) | |
315 | 324 | then _validateString(to_, "depositTo: invalid to") | |
316 | 325 | else false | |
317 | 326 | if ((err == err)) | |
318 | 327 | then { | |
319 | 328 | let caller = toString(i.caller) | |
320 | 329 | let asset = _assetToStr(i.payments[0].assetId) | |
321 | 330 | let assetDecimals = _getDecimals(asset) | |
322 | 331 | let amount = _normalizeDecimals(i.payments[0].amount, assetDecimals, DEX_DECIMALS) | |
323 | 332 | let err1 = _validateInt(amount, 1, MAX_INT, "depositTo: invalid payment amount") | |
324 | 333 | if ((err1 == err1)) | |
325 | 334 | then { | |
326 | 335 | let gatewayInvocation = invoke(_loadGatewayContract(), FUNC_DEPOSIT, [toString(this), caller, to_, toString(_loadChainId()), asset, toString(amount)], nil) | |
327 | 336 | if ((gatewayInvocation == gatewayInvocation)) | |
328 | 337 | then { | |
329 | 338 | let stakingInvocation = if ((asset == WAVES)) | |
330 | 339 | then invoke(_loadSWavesContract(), FUNC_DEPOSIT, nil, [AttachedPayment(unit, i.payments[0].amount)]) | |
331 | 340 | else unit | |
332 | 341 | if ((stakingInvocation == stakingInvocation)) | |
333 | 342 | then $Tuple2(_saveReserves(asset, (_loadReserves(asset) + amount)), unit) | |
334 | 343 | else throw("Strict value is not equal to itself.") | |
335 | 344 | } | |
336 | 345 | else throw("Strict value is not equal to itself.") | |
337 | 346 | } | |
338 | 347 | else throw("Strict value is not equal to itself.") | |
339 | 348 | } | |
340 | 349 | else throw("Strict value is not equal to itself.") | |
341 | 350 | } | |
342 | 351 | ||
343 | 352 | ||
344 | 353 | ||
345 | 354 | @Callable(i) | |
346 | 355 | func requestWithdrawal (toChainId_,asset_,amount_) = { | |
356 | + | let amount = valueOrErrorMessage(parseBigInt(amount_), "requestWithdrawal: amount not int") | |
347 | 357 | let err = if (if (if (_whenInitialized()) | |
348 | 358 | then _validateInt(toChainId_, 0, MAX_INT, "requestWithdrawal: invalid toChainId") | |
349 | 359 | else false) | |
350 | 360 | then _validateString(asset_, "requestWithdrawal: invalid asset") | |
351 | 361 | else false) | |
352 | - | then _ | |
362 | + | then _validateBigInt(amount, ONE_BIGINT, "requestWithdrawal: negative amount") | |
353 | 363 | else false | |
354 | 364 | if ((err == err)) | |
355 | 365 | then { | |
356 | 366 | let caller = toString(i.caller) | |
357 | - | let requestWithdrawalId = match invoke(_loadGatewayContract(), FUNC_REQUEST_WITHDRAWAL, [toString(this), caller, caller, toString(_loadChainId()), toString(toChainId_), asset_, | |
367 | + | let requestWithdrawalId = match invoke(_loadGatewayContract(), FUNC_REQUEST_WITHDRAWAL, [toString(this), caller, caller, toString(_loadChainId()), toString(toChainId_), asset_, amount_], nil) { | |
358 | 368 | case a: Int => | |
359 | 369 | a | |
360 | 370 | case _ => | |
361 | 371 | throw("requestWithdrawal: call reverted from gw") | |
362 | 372 | } | |
363 | 373 | if ((requestWithdrawalId == requestWithdrawalId)) | |
364 | 374 | then $Tuple2(nil, requestWithdrawalId) | |
365 | 375 | else throw("Strict value is not equal to itself.") | |
366 | 376 | } | |
367 | 377 | else throw("Strict value is not equal to itself.") | |
368 | 378 | } | |
369 | 379 | ||
370 | 380 | ||
371 | 381 | ||
372 | 382 | @Callable(i) | |
373 | 383 | func executeWithdrawal (requestWithdrawalId_) = { | |
374 | 384 | let err = if (_whenInitialized()) | |
375 | 385 | then _validateInt(requestWithdrawalId_, 0, MAX_INT, "executeWithdrawal: invalid requestId") | |
376 | 386 | else false | |
377 | 387 | if ((err == err)) | |
378 | 388 | then { | |
379 | 389 | let gatewayInvocation = reentrantInvoke(_loadGatewayContract(), FUNC_EXECUTE_WITHDRAWAL, [toString(this), toString(_loadChainId()), toString(requestWithdrawalId_)], nil) | |
380 | 390 | if ((gatewayInvocation == gatewayInvocation)) | |
381 | 391 | then $Tuple2(nil, unit) | |
382 | 392 | else throw("Strict value is not equal to itself.") | |
383 | 393 | } | |
384 | 394 | else throw("Strict value is not equal to itself.") | |
385 | 395 | } | |
386 | 396 | ||
387 | 397 | ||
388 | 398 | ||
389 | 399 | @Callable(i) | |
390 | 400 | func withdraw (to_,asset_,amount_) = { | |
391 | 401 | let amount = valueOrErrorMessage(parseInt(amount_), "withdraw: amount not int") | |
392 | 402 | let err = if (if (if (if (_whenInitialized()) | |
393 | 403 | then _validateGateway(i.caller, "withdraw: invalid gateway") | |
394 | 404 | else false) | |
395 | 405 | then _validateAddress(to_, "withdraw: invalid address") | |
396 | 406 | else false) | |
397 | 407 | then _validateAsset(asset_, "withdraw: invalid asset") | |
398 | 408 | else false) | |
399 | 409 | then _validateInt(amount, 0, MAX_INT, "withdraw: negative amount") | |
400 | 410 | else false | |
401 | 411 | if ((err == err)) | |
402 | 412 | then { | |
403 | 413 | let assetDecimals = _getDecimals(asset_) | |
404 | 414 | let amountNormalized = _normalizeDecimals(amount, DEX_DECIMALS, assetDecimals) | |
405 | 415 | let newReserves = (_loadReserves(asset_) - amount) | |
406 | 416 | let err1 = if (_validateInt(amountNormalized, 1, MAX_INT, "withdraw: invalid amount")) | |
407 | 417 | then _validateInt(newReserves, 0, MAX_INT, "withdraw: negative newReserves") | |
408 | 418 | else false | |
409 | 419 | if ((err1 == err1)) | |
410 | 420 | then { | |
411 | 421 | let unstakingInvocation = if ((asset_ == WAVES)) | |
412 | 422 | then { | |
413 | 423 | let sWavesContract = _loadSWavesContract() | |
414 | 424 | let sWavesAsset = _loadSWavesAsset(sWavesContract) | |
415 | 425 | let invocation = invoke(sWavesContract, FUNC_GET_RATE, nil, nil) | |
416 | 426 | let rate = match invocation { | |
417 | 427 | case a: String => | |
418 | 428 | parseBigIntValue(a) | |
419 | 429 | case _ => | |
420 | 430 | throw("withdraw: sWaves getRate() revert") | |
421 | 431 | } | |
422 | 432 | let sWavesToWithdraw = toInt(fraction(toBigInt(amountNormalized), SWAVES_RATE_FACTOR, rate, CEILING)) | |
423 | 433 | invoke(sWavesContract, FUNC_WITHDRAW, nil, [AttachedPayment(sWavesAsset, sWavesToWithdraw)]) | |
424 | 434 | } | |
425 | 435 | else unit | |
426 | 436 | if ((unstakingInvocation == unstakingInvocation)) | |
427 | 437 | then $Tuple2(([ScriptTransfer(addressFromStringValue(to_), amountNormalized, _strToAsset(asset_))] ++ _saveReserves(asset_, newReserves)), unit) | |
428 | 438 | else throw("Strict value is not equal to itself.") | |
429 | 439 | } | |
430 | 440 | else throw("Strict value is not equal to itself.") | |
431 | 441 | } | |
432 | 442 | else throw("Strict value is not equal to itself.") | |
433 | 443 | } | |
434 | 444 | ||
435 | 445 | ||
436 | 446 | ||
437 | 447 | @Callable(i) | |
438 | 448 | func pause () = { | |
439 | 449 | let err = if (if (_onlyPauser(i.caller)) | |
440 | 450 | then _whenInitialized() | |
441 | 451 | else false) | |
442 | 452 | then _whenNotPaused() | |
443 | 453 | else false | |
444 | 454 | if ((err == err)) | |
445 | 455 | then $Tuple2(_savePause(true), unit) | |
446 | 456 | else throw("Strict value is not equal to itself.") | |
447 | 457 | } | |
448 | 458 | ||
449 | 459 | ||
450 | 460 | ||
451 | 461 | @Callable(i) | |
452 | 462 | func unpause () = { | |
453 | 463 | let err = if (if (_onlyPauser(i.caller)) | |
454 | 464 | then _whenInitialized() | |
455 | 465 | else false) | |
456 | 466 | then _whenPaused() | |
457 | 467 | else false | |
458 | 468 | if ((err == err)) | |
459 | 469 | then $Tuple2(_savePause(false), unit) | |
460 | 470 | else throw("Strict value is not equal to itself.") | |
461 | 471 | } | |
462 | 472 | ||
463 | 473 | ||
464 | 474 | ||
465 | 475 | @Callable(i) | |
466 | 476 | func updatePauser (pauser_) = { | |
467 | 477 | let err = if (if (_onlyThisContract(i.caller)) | |
468 | 478 | then _whenInitialized() | |
469 | 479 | else false) | |
470 | 480 | then _validateAddress(pauser_, "updatePauser: invalid pauser") | |
471 | 481 | else false | |
472 | 482 | if ((err == err)) | |
473 | 483 | then $Tuple2(_savePauser(addressFromStringValue(pauser_)), unit) | |
474 | 484 | else throw("Strict value is not equal to itself.") | |
475 | 485 | } | |
476 | 486 | ||
477 | 487 | ||
478 | 488 | ||
479 | 489 | @Callable(i) | |
480 | 490 | func setMultisig (multisig_) = { | |
481 | 491 | let err = if (_onlyThisContract(i.caller)) | |
482 | 492 | then _validateAddress(multisig_, "setMultisig: invalid multisig") | |
483 | 493 | else false | |
484 | 494 | if ((err == err)) | |
485 | 495 | then $Tuple2(_saveMultisig(addressFromStringValue(multisig_)), unit) | |
486 | 496 | else throw("Strict value is not equal to itself.") | |
487 | 497 | } | |
488 | 498 | ||
489 | 499 | ||
490 | 500 | @Verifier(tx) | |
491 | 501 | func verify () = match getString(KEY_MULTISIG) { | |
492 | 502 | case multisig: String => | |
493 | 503 | valueOrElse(getBoolean(addressFromStringValue(multisig), makeString([KEY_STATUS, toString(this), toBase58String(tx.id)], SEPARATOR)), false) | |
494 | 504 | case _ => | |
495 | 505 | sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
496 | 506 | } | |
497 | 507 |
github/deemru/w8io/3ef1775 66.77 ms ◑