tx · Hdr2qht6YgFPXdN3fvAwRQhRZQq7LZRt5cDfuzKK2ehC

3N6LHjfGb6Fgcy7YsVcNxGyPTj49XbQAijq:  -0.01100000 Waves

2024.07.15 10:18 [3194838] smart account 3N6LHjfGb6Fgcy7YsVcNxGyPTj49XbQAijq > SELF 0.00000000 Waves

{ "type": 13, "id": "Hdr2qht6YgFPXdN3fvAwRQhRZQq7LZRt5cDfuzKK2ehC", "fee": 1100000, "feeAssetId": null, "timestamp": 1721027930313, "version": 1, "sender": "3N6LHjfGb6Fgcy7YsVcNxGyPTj49XbQAijq", "senderPublicKey": "2u2wYYcVBQv43Cc71zkhHPPitkqgg6dqTZ3nUMvYJ1uq", "proofs": [ "4sYSRTsUsfARdBz2APngBpKiCf6tEDupdH36c6eH91hhRo5iEmWL9tkw3QiPfadVHvLcEABHyd8XFPCpE4jB9xqJ" ], "script": "base64:BgIQCAISBQoDAQgIEgUKAwEICBkAA1NFUAICX18ACGZlZVNjYWxlCQC2AgEAgMLXLwEPZ2V0U3RyaW5nT3JGYWlsAQNrZXkJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQNrZXkJAKwCAgIVTm8gZGF0YSBmb3IgdGhpcy5rZXk9BQNrZXkADHBvb2xEaXNhYmxlZAkAAgECDVBvb2wgZGlzYWJsZWQADHBvb2xOb3RFeGlzdAkAAgECEVBvb2wgaXMgbm90IGV4aXN0AA5zbGlwcGFnZVRvb0JpZwkAAgECE1NsaXBwYWdlIGlzIHRvbyBiaWcBE2tleU1hbmFnZXJQdWJsaWNLZXkAAhQlc19fbWFuYWdlclB1YmxpY0tleQEWa2V5TWFuYWdlclZhdWx0QWRkcmVzcwACFyVzX19tYW5hZ2VyVmF1bHRBZGRyZXNzAQJmYwACEyVzX19mYWN0b3J5Q29udHJhY3QAD2ZhY3RvcnlDb250cmFjdAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBD2dldFN0cmluZ09yRmFpbAEJAQJmYwABC3Byb3RvY29sRmVlAAkAuQkCCQDMCAICAiVzCQDMCAICC3Byb3RvY29sRmVlBQNuaWwFA1NFUAEHcG9vbEZlZQAJALkJAgkAzAgCAgIlcwkAzAgCAgdwb29sRmVlBQNuaWwFA1NFUAEaZ2V0U3RyaW5nT3JGYWlsRnJvbUFkZHJlc3MCB2FkZHJlc3MDa2V5CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUHYWRkcmVzcwUDa2V5CQC5CQIJAMwIAgIKbWFuZGF0b3J5IAkAzAgCCQClCAEFB2FkZHJlc3MJAMwIAgIBLgkAzAgCBQNrZXkJAMwIAgIPIGlzIG5vdCBkZWZpbmVkBQNuaWwCAAAWa2V5RmVlQ29sbGVjdG9yQWRkcmVzcwIXJXNfX2ZlZUNvbGxlY3RvckFkZHJlc3MAE2ZlZUNvbGxlY3RvckFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARpnZXRTdHJpbmdPckZhaWxGcm9tQWRkcmVzcwIFD2ZhY3RvcnlDb250cmFjdAUWa2V5RmVlQ29sbGVjdG9yQWRkcmVzcwEcZ2V0TWFuYWdlclZhdWx0QWRkcmVzc09yVGhpcwAEByRtYXRjaDAJAKIIAQkBFmtleU1hbmFnZXJWYXVsdEFkZHJlc3MAAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAkBEUBleHRyTmF0aXZlKDEwNjIpAQUBcwUEdGhpcwEFYXNJbnQBA3ZhbAQHJG1hdGNoMAUDdmFsAwkAAQIFByRtYXRjaDACA0ludAQGdmFsSW50BQckbWF0Y2gwBQZ2YWxJbnQJAAIBAhVmYWlsIHRvIGNhc3QgaW50byBJbnQBFWRhdGFNYXBwaW5nUG9vbEFzc2V0cwIWaW50ZXJuYWxBbW91bnRBc3NldFN0chVpbnRlcm5hbFByaWNlQXNzZXRTdHIJALkJAgkAzAgCAgQlZCVkCQDMCAIJAKQDAQUWaW50ZXJuYWxBbW91bnRBc3NldFN0cgkAzAgCCQCkAwEFFWludGVybmFsUHJpY2VBc3NldFN0cgUDbmlsBQNTRVABFm1hbmFnZXJQdWJsaWNLZXlPclVuaXQABBNtYW5hZ2VyVmF1bHRBZGRyZXNzCQEcZ2V0TWFuYWdlclZhdWx0QWRkcmVzc09yVGhpcwAEByRtYXRjaDAJAJ0IAgUTbWFuYWdlclZhdWx0QWRkcmVzcwkBE2tleU1hbmFnZXJQdWJsaWNLZXkAAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAkA2QQBBQFzAwkAAQIFByRtYXRjaDACBFVuaXQFBHVuaXQJAAIBAgtNYXRjaCBlcnJvcgEJaXNNYW5hZ2VyAQFpBAckbWF0Y2gwCQEWbWFuYWdlclB1YmxpY0tleU9yVW5pdAADCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQCcGsFByRtYXRjaDAJAAACCAUBaQ9jYWxsZXJQdWJsaWNLZXkFAnBrAwkAAQIFByRtYXRjaDACBFVuaXQJAAACCAUBaQZjYWxsZXIFBHRoaXMJAAIBAgtNYXRjaCBlcnJvcgELbXVzdE1hbmFnZXIBAWkDCQEJaXNNYW5hZ2VyAQUBaQYJAAIBAhFwZXJtaXNzaW9uIGRlbmllZAENZ2V0QWNjQmFsYW5jZQEHYXNzZXRJZAMJAAACBQdhc3NldElkAgVXQVZFUwgJAO8HAQUEdGhpcwlhdmFpbGFibGUJAPAHAgUEdGhpcwkA2QQBBQdhc3NldElkAQ9zdHJpbmdUb0Fzc2V0SWQBDWFzc2V0SWRTdHJpbmcDCQAAAgUNYXNzZXRJZFN0cmluZwIFV0FWRVMFBHVuaXQJANkEAQUNYXNzZXRJZFN0cmluZwELZ2V0U3dhcEZlZXMBDnBvb2xBZGRyZXNzU3RyBA5wb29sRmVlRGVmYXVsdAkBBXZhbHVlAQkAmggCBQR0aGlzCQEHcG9vbEZlZQAEEnByb3RvY29sRmVlRGVmYXVsdAkBBXZhbHVlAQkAmggCBQR0aGlzCQELcHJvdG9jb2xGZWUABAckbWF0Y2gwCQD8BwQFD2ZhY3RvcnlDb250cmFjdAISZ2V0U3dhcEZlZVJFQURPTkxZCQDMCAIFDnBvb2xBZGRyZXNzU3RyBQNuaWwFA25pbAMJAAECBQckbWF0Y2gwAgooSW50LCBJbnQpBARmZWVzBQckbWF0Y2gwCQCUCgIIBQRmZWVzAl8xCAUEZmVlcwJfMgkAlAoCBQ5wb29sRmVlRGVmYXVsdAUScHJvdG9jb2xGZWVEZWZhdWx0ASBnZXRQb29sQWRkcmVzc0FuZENoZWNrUG9vbFN0YXR1cwIHYXNzZXRJbghhc3NldE91dAQMbHBOb25SZXZlcnNlCgABQAkA/AcEBQ9mYWN0b3J5Q29udHJhY3QCIGdldExwQXNzZXRGcm9tUG9vbEFzc2V0c1JFQURPTkxZCQDMCAIFB2Fzc2V0SW4JAMwIAgUIYXNzZXRPdXQFA25pbAUDbmlsAwkAAQIFAUACBlN0cmluZwUBQAUEdW5pdAQJbHBSZXZlcnNlCgABQAkA/AcEBQ9mYWN0b3J5Q29udHJhY3QCIGdldExwQXNzZXRGcm9tUG9vbEFzc2V0c1JFQURPTkxZCQDMCAIFCGFzc2V0T3V0CQDMCAIFB2Fzc2V0SW4FA25pbAUDbmlsAwkAAQIFAUACBlN0cmluZwUBQAUEdW5pdAQLJHQwMzEyODM1ODcDCQECIT0CBQxscE5vblJldmVyc2UFBHVuaXQEBHBvb2wKAAFACQD8BwQFD2ZhY3RvcnlDb250cmFjdAIhZ2V0UG9vbEFkZHJlc3NGcm9tTHBBc3NldFJFQURPTkxZCQDMCAIJAQV2YWx1ZQEFDGxwTm9uUmV2ZXJzZQUDbmlsBQNuaWwDCQABAgUBQAIGU3RyaW5nBQFACQACAQkArAICCQADAQUBQAIbIGNvdWxkbid0IGJlIGNhc3QgdG8gU3RyaW5nCQCUCgIHBQRwb29sAwkBAiE9AgUJbHBSZXZlcnNlBQR1bml0BARwb29sCgABQAkA/AcEBQ9mYWN0b3J5Q29udHJhY3QCIWdldFBvb2xBZGRyZXNzRnJvbUxwQXNzZXRSRUFET05MWQkAzAgCCQEFdmFsdWUBBQlscFJldmVyc2UFA25pbAUDbmlsAwkAAQIFAUACBlN0cmluZwUBQAkAAgEJAKwCAgkAAwEFAUACGyBjb3VsZG4ndCBiZSBjYXN0IHRvIFN0cmluZwkAlAoCBgUEcG9vbAUMcG9vbE5vdEV4aXN0BAlpc1JldmVyc2UIBQskdDAzMTI4MzU4NwJfMQQEcG9vbAgFCyR0MDMxMjgzNTg3Al8yBApwb29sU3RhdHVzCgABQAkA/AcEBQ9mYWN0b3J5Q29udHJhY3QCFWdldFBvb2xTdGF0dXNSRUFET05MWQkAzAgCBQRwb29sBQNuaWwFA25pbAMJAAECBQFAAgNJbnQFAUAJAAIBCQCsAgIJAAMBBQFAAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQEBWNoZWNrAwkAAAIFCnBvb2xTdGF0dXMAAQYFDHBvb2xEaXNhYmxlZAMJAAACBQVjaGVjawUFY2hlY2sEB3Bvb2xBZHIJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQt2YWx1ZU9yRWxzZQIFBHBvb2wCAAkAlAoCBQdwb29sQWRyBQlpc1JldmVyc2UJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CAWkBFXN3YXBDYWxjdWxhdGVSRUFET05MWQMIYW1vdW50SW4HYXNzZXRJbghhc3NldE91dAQLJHQwMzk4MzQwNjEJASBnZXRQb29sQWRkcmVzc0FuZENoZWNrUG9vbFN0YXR1cwIFB2Fzc2V0SW4FCGFzc2V0T3V0BAdwb29sQWRyCAULJHQwMzk4MzQwNjECXzEECWlzUmV2ZXJzZQgFCyR0MDM5ODM0MDYxAl8yBAskdDA0MDY1NDExNwkBC2dldFN3YXBGZWVzAQkApQgBBQdwb29sQWRyBAVwbEZlZQgFCyR0MDQwNjU0MTE3Al8xBAVwckZlZQgFCyR0MDQwNjU0MTE3Al8yBBVmZWVQcm90b2NvbEFtb3VudENhbGMJALwCAwkAtgIBBQhhbW91bnRJbgkAtgIBBQVwckZlZQUIZmVlU2NhbGUEEWZlZVBvb2xBbW91bnRDYWxjCQC8AgMJALYCAQUIYW1vdW50SW4JALYCAQUFcGxGZWUFCGZlZVNjYWxlBBFmZWVQcm90b2NvbEFtb3VudAMJAAACCQCgAwEFFWZlZVByb3RvY29sQW1vdW50Q2FsYwAACQC2AgEAAQUVZmVlUHJvdG9jb2xBbW91bnRDYWxjBA1mZWVQb29sQW1vdW50AwkAAAIJAKADAQURZmVlUG9vbEFtb3VudENhbGMAAAkAtgIBAAEFEWZlZVBvb2xBbW91bnRDYWxjBA1jbGVhbkFtb3VudEluAwkAAAIFCWlzUmV2ZXJzZQYJALgCAgkAuAICCQC2AgEFCGFtb3VudEluBRFmZWVQcm90b2NvbEFtb3VudAUNZmVlUG9vbEFtb3VudAkAuAICCQC2AgEFCGFtb3VudEluBQ1mZWVQb29sQW1vdW50BAt0b3RhbEdldFJhdwoAAUAJAPwHBAUHcG9vbEFkcgIhY2FsY3VsYXRlQW1vdW50T3V0Rm9yU3dhcFJFQURPTkxZCQDMCAIJAKADAQUNY2xlYW5BbW91bnRJbgkAzAgCBQlpc1JldmVyc2UJAMwIAgkAoAMBBQ1mZWVQb29sQW1vdW50BQNuaWwFA25pbAMJAAECBQFAAgNJbnQFAUAJAAIBCQCsAgIJAAMBBQFAAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQEC25ld1RvdGFsR2V0AwkAAAIFCWlzUmV2ZXJzZQYFC3RvdGFsR2V0UmF3BBZmZWVQcm90b2NvbEZyb21HZXRDYWxjCQC8AgMJALYCAQULdG90YWxHZXRSYXcJALYCAQUFcHJGZWUFCGZlZVNjYWxlBBhmZWVQcm90b2NvbEFtb3VudEZyb21HZXQDCQAAAgkAoAMBBRZmZWVQcm90b2NvbEZyb21HZXRDYWxjAAAJAKADAQkAtgIBAAEJAKADAQUWZmVlUHJvdG9jb2xGcm9tR2V0Q2FsYwkAZQIFC3RvdGFsR2V0UmF3BRhmZWVQcm90b2NvbEFtb3VudEZyb21HZXQJAJQKAgUDbmlsBQtuZXdUb3RhbEdldAFpAQRzd2FwAwxhbW91bnRPdXRNaW4LYXNzZXRPdXRSYXcJYWRkcmVzc1RvBAZjaGVja3MJAMwIAgMJAAACCQCQAwEIBQFpCHBheW1lbnRzAAEGCQACAQIeZXhhY3RseSAxIHBheW1lbnQgYXJlIGV4cGVjdGVkBQNuaWwDCQAAAgUGY2hlY2tzBQZjaGVja3MECGFzc2V0T3V0AwkAAAIFC2Fzc2V0T3V0UmF3AgACBVdBVkVTBQthc3NldE91dFJhdwQDcG10CQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAAEB2Fzc2V0SW4DCQAAAggFA3BtdAdhc3NldElkBQR1bml0AgVXQVZFUwkA2AQBCQEFdmFsdWUBCAUDcG10B2Fzc2V0SWQECGFtb3VudEluCQEFdmFsdWUBCAUDcG10BmFtb3VudAQLJHQwNTkxNjU5OTQJASBnZXRQb29sQWRkcmVzc0FuZENoZWNrUG9vbFN0YXR1cwIFB2Fzc2V0SW4FCGFzc2V0T3V0BAdwb29sQWRyCAULJHQwNTkxNjU5OTQCXzEECWlzUmV2ZXJzZQgFCyR0MDU5MTY1OTk0Al8yBAskdDA1OTk3NjA0OQkBC2dldFN3YXBGZWVzAQkApQgBBQdwb29sQWRyBAVwbEZlZQgFCyR0MDU5OTc2MDQ5Al8xBAVwckZlZQgFCyR0MDU5OTc2MDQ5Al8yBBVmZWVQcm90b2NvbEFtb3VudENhbGMJALwCAwkAtgIBBQhhbW91bnRJbgkAtgIBBQVwckZlZQUIZmVlU2NhbGUEEWZlZVBvb2xBbW91bnRDYWxjCQC8AgMJALYCAQUIYW1vdW50SW4JALYCAQUFcGxGZWUFCGZlZVNjYWxlBAthZGRyZXNzVG9fYQkBEUBleHRyTmF0aXZlKDEwNjIpAQUJYWRkcmVzc1RvBBFmZWVQcm90b2NvbEFtb3VudAMJAAACCQCgAwEFFWZlZVByb3RvY29sQW1vdW50Q2FsYwAACQC2AgEAAQUVZmVlUHJvdG9jb2xBbW91bnRDYWxjBA1mZWVQb29sQW1vdW50AwkAAAIJAKADAQURZmVlUG9vbEFtb3VudENhbGMAAAkAtgIBAAEFEWZlZVBvb2xBbW91bnRDYWxjBA1jbGVhbkFtb3VudEluAwkAAAIFCWlzUmV2ZXJzZQYJALgCAgkAuAICCQC2AgEFCGFtb3VudEluBRFmZWVQcm90b2NvbEFtb3VudAUNZmVlUG9vbEFtb3VudAkAuAICCQC2AgEFCGFtb3VudEluBQ1mZWVQb29sQW1vdW50BBZhc3NldEluQXR0YWNoZWRQYXltZW50CQEPc3RyaW5nVG9Bc3NldElkAQUHYXNzZXRJbgQLdG90YWxHZXRSYXcKAAFACQD8BwQFB3Bvb2xBZHICJmNhbGN1bGF0ZUFtb3VudE91dEZvclN3YXBBbmRTZW5kVG9rZW5zCQDMCAIJAKADAQUNY2xlYW5BbW91bnRJbgkAzAgCBQlpc1JldmVyc2UJAMwIAgUMYW1vdW50T3V0TWluCQDMCAIJAKUIAQUEdGhpcwkAzAgCCQCgAwEFDWZlZVBvb2xBbW91bnQFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUWYXNzZXRJbkF0dGFjaGVkUGF5bWVudAkAoAMBBQ1jbGVhbkFtb3VudEluBQNuaWwDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50BAskdDA3MjA3NzgwMQMJAAACBQlpc1JldmVyc2UGCQCUCgIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUTZmVlQ29sbGVjdG9yQWRkcmVzcwkAoAMBBRFmZWVQcm90b2NvbEFtb3VudAUWYXNzZXRJbkF0dGFjaGVkUGF5bWVudAUDbmlsBQt0b3RhbEdldFJhdwQWZmVlUHJvdG9jb2xGcm9tR2V0Q2FsYwkAvAIDCQC2AgEFC3RvdGFsR2V0UmF3CQC2AgEFBXByRmVlBQhmZWVTY2FsZQQYZmVlUHJvdG9jb2xBbW91bnRGcm9tR2V0AwkAAAIJAKADAQUWZmVlUHJvdG9jb2xGcm9tR2V0Q2FsYwAACQCgAwEJALYCAQABCQCgAwEFFmZlZVByb3RvY29sRnJvbUdldENhbGMJAJQKAgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBRNmZWVDb2xsZWN0b3JBZGRyZXNzBRhmZWVQcm90b2NvbEFtb3VudEZyb21HZXQJAQ9zdHJpbmdUb0Fzc2V0SWQBBQhhc3NldE91dAUDbmlsCQBlAgULdG90YWxHZXRSYXcFGGZlZVByb3RvY29sQW1vdW50RnJvbUdldAQScHJvdG9jb2xGZWVBY3Rpb25zCAULJHQwNzIwNzc4MDECXzEEC25ld1RvdGFsR2V0CAULJHQwNzIwNzc4MDECXzIJAJQKAgkAzggCBRJwcm90b2NvbEZlZUFjdGlvbnMJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUHcG9vbEFkcgkAoAMBBQ1mZWVQb29sQW1vdW50BRZhc3NldEluQXR0YWNoZWRQYXltZW50CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFC2FkZHJlc3NUb19hBQtuZXdUb3RhbEdldAkBD3N0cmluZ1RvQXNzZXRJZAEFCGFzc2V0T3V0BQNuaWwFC25ld1RvdGFsR2V0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJ0eAEGdmVyaWZ5AAQPdGFyZ2V0UHVibGljS2V5BAckbWF0Y2gwCQEWbWFuYWdlclB1YmxpY0tleU9yVW5pdAADCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQCcGsFByRtYXRjaDAFAnBrAwkAAQIFByRtYXRjaDACBFVuaXQIBQJ0eA9zZW5kZXJQdWJsaWNLZXkJAAIBAgtNYXRjaCBlcnJvcgkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUPdGFyZ2V0UHVibGljS2V5lOXcVg==", "chainId": 84, "height": 3194838, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: EtVYfFaBUbs2evGPSU4RvB9nEUHYpAzej2tNzNm6ijmM Next: 4mAEE6mkGF31F2dz8awaZhAakdKKC1Xv3dWeoB8AAyR3 Diff:
OldNewDifferences
177177 let feePoolAmount = if ((toInt(feePoolAmountCalc) == 0))
178178 then toBigInt(1)
179179 else feePoolAmountCalc
180- let cleanAmountIn = ((toBigInt(amountIn) - feeProtocolAmount) - feePoolAmount)
181- let res = {
180+ let cleanAmountIn = if ((isReverse == true))
181+ then ((toBigInt(amountIn) - feeProtocolAmount) - feePoolAmount)
182+ else (toBigInt(amountIn) - feePoolAmount)
183+ let totalGetRaw = {
182184 let @ = invoke(poolAdr, "calculateAmountOutForSwapREADONLY", [toInt(cleanAmountIn), isReverse, toInt(feePoolAmount)], nil)
183185 if ($isInstanceOf(@, "Int"))
184186 then @
185187 else throw(($getType(@) + " couldn't be cast to Int"))
186188 }
187- $Tuple2(nil, res)
189+ let newTotalGet = if ((isReverse == true))
190+ then totalGetRaw
191+ else {
192+ let feeProtocolFromGetCalc = fraction(toBigInt(totalGetRaw), toBigInt(prFee), feeScale)
193+ let feeProtocolAmountFromGet = if ((toInt(feeProtocolFromGetCalc) == 0))
194+ then toInt(toBigInt(1))
195+ else toInt(feeProtocolFromGetCalc)
196+ (totalGetRaw - feeProtocolAmountFromGet)
197+ }
198+ $Tuple2(nil, newTotalGet)
188199 }
189200
190201
191202
192203 @Callable(i)
193204 func swap (amountOutMin,assetOutRaw,addressTo) = {
194- let assetOut = if ((assetOutRaw == ""))
195- then "WAVES"
196- else assetOutRaw
197- let pmt = value(i.payments[0])
198- let assetIn = if ((pmt.assetId == unit))
199- then "WAVES"
200- else toBase58String(value(pmt.assetId))
201- let amountIn = value(pmt.amount)
202- let $t051305208 = getPoolAddressAndCheckPoolStatus(assetIn, assetOut)
203- let poolAdr = $t051305208._1
204- let isReverse = $t051305208._2
205- let $t052115263 = getSwapFees(toString(poolAdr))
206- let plFee = $t052115263._1
207- let prFee = $t052115263._2
208- let feeProtocolAmountCalc = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
209- let feePoolAmountCalc = fraction(toBigInt(amountIn), toBigInt(plFee), feeScale)
210- let addressTo_a = addressFromStringValue(addressTo)
211- let feeProtocolAmount = if ((toInt(feeProtocolAmountCalc) == 0))
212- then toBigInt(1)
213- else feeProtocolAmountCalc
214- let feePoolAmount = if ((toInt(feePoolAmountCalc) == 0))
215- then toBigInt(1)
216- else feePoolAmountCalc
217- let cleanAmountIn = if ((isReverse == true))
218- then ((toBigInt(amountIn) - feeProtocolAmount) - feePoolAmount)
219- else (toBigInt(amountIn) - feePoolAmount)
220205 let checks = [if ((size(i.payments) == 1))
221206 then true
222207 else throw("exactly 1 payment are expected")]
223208 if ((checks == checks))
224209 then {
210+ let assetOut = if ((assetOutRaw == ""))
211+ then "WAVES"
212+ else assetOutRaw
213+ let pmt = value(i.payments[0])
214+ let assetIn = if ((pmt.assetId == unit))
215+ then "WAVES"
216+ else toBase58String(value(pmt.assetId))
217+ let amountIn = value(pmt.amount)
218+ let $t059165994 = getPoolAddressAndCheckPoolStatus(assetIn, assetOut)
219+ let poolAdr = $t059165994._1
220+ let isReverse = $t059165994._2
221+ let $t059976049 = getSwapFees(toString(poolAdr))
222+ let plFee = $t059976049._1
223+ let prFee = $t059976049._2
224+ let feeProtocolAmountCalc = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
225+ let feePoolAmountCalc = fraction(toBigInt(amountIn), toBigInt(plFee), feeScale)
226+ let addressTo_a = addressFromStringValue(addressTo)
227+ let feeProtocolAmount = if ((toInt(feeProtocolAmountCalc) == 0))
228+ then toBigInt(1)
229+ else feeProtocolAmountCalc
230+ let feePoolAmount = if ((toInt(feePoolAmountCalc) == 0))
231+ then toBigInt(1)
232+ else feePoolAmountCalc
233+ let cleanAmountIn = if ((isReverse == true))
234+ then ((toBigInt(amountIn) - feeProtocolAmount) - feePoolAmount)
235+ else (toBigInt(amountIn) - feePoolAmount)
225236 let assetInAttachedPayment = stringToAssetId(assetIn)
226237 let totalGetRaw = {
227238 let @ = invoke(poolAdr, "calculateAmountOutForSwapAndSendTokens", [toInt(cleanAmountIn), isReverse, amountOutMin, toString(this), toInt(feePoolAmount)], [AttachedPayment(assetInAttachedPayment, toInt(cleanAmountIn))])
229240 then @
230241 else throw(($getType(@) + " couldn't be cast to Int"))
231242 }
232- let $t065177111 = if ((isReverse == true))
243+ let $t072077801 = if ((isReverse == true))
233244 then $Tuple2([ScriptTransfer(feeCollectorAddress, toInt(feeProtocolAmount), assetInAttachedPayment)], totalGetRaw)
234245 else {
235246 let feeProtocolFromGetCalc = fraction(toBigInt(totalGetRaw), toBigInt(prFee), feeScale)
238249 else toInt(feeProtocolFromGetCalc)
239250 $Tuple2([ScriptTransfer(feeCollectorAddress, feeProtocolAmountFromGet, stringToAssetId(assetOut))], (totalGetRaw - feeProtocolAmountFromGet))
240251 }
241- let protocolFeeActions = $t065177111._1
242- let newTotalGet = $t065177111._2
252+ let protocolFeeActions = $t072077801._1
253+ let newTotalGet = $t072077801._2
243254 $Tuple2((protocolFeeActions ++ [ScriptTransfer(poolAdr, toInt(feePoolAmount), assetInAttachedPayment), ScriptTransfer(addressTo_a, newTotalGet, stringToAssetId(assetOut))]), newTotalGet)
244255 }
245256 else throw("Strict value is not equal to itself.")
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let SEP = "__"
55
66 let feeScale = toBigInt(100000000)
77
88 func getStringOrFail (key) = valueOrErrorMessage(getString(this, key), ("No data for this.key=" + key))
99
1010
1111 let poolDisabled = throw("Pool disabled")
1212
1313 let poolNotExist = throw("Pool is not exist")
1414
1515 let slippageTooBig = throw("Slippage is too big")
1616
1717 func keyManagerPublicKey () = "%s__managerPublicKey"
1818
1919
2020 func keyManagerVaultAddress () = "%s__managerVaultAddress"
2121
2222
2323 func fc () = "%s__factoryContract"
2424
2525
2626 let factoryContract = addressFromStringValue(getStringOrFail(fc()))
2727
2828 func protocolFee () = makeString(["%s", "protocolFee"], SEP)
2929
3030
3131 func poolFee () = makeString(["%s", "poolFee"], SEP)
3232
3333
3434 func getStringOrFailFromAddress (address,key) = valueOrErrorMessage(getString(address, key), makeString(["mandatory ", toString(address), ".", key, " is not defined"], ""))
3535
3636
3737 let keyFeeCollectorAddress = "%s__feeCollectorAddress"
3838
3939 let feeCollectorAddress = addressFromStringValue(getStringOrFailFromAddress(factoryContract, keyFeeCollectorAddress))
4040
4141 func getManagerVaultAddressOrThis () = match getString(keyManagerVaultAddress()) {
4242 case s: String =>
4343 addressFromStringValue(s)
4444 case _ =>
4545 this
4646 }
4747
4848
4949 func asInt (val) = match val {
5050 case valInt: Int =>
5151 valInt
5252 case _ =>
5353 throw("fail to cast into Int")
5454 }
5555
5656
5757 func dataMappingPoolAssets (internalAmountAssetStr,internalPriceAssetStr) = makeString(["%d%d", toString(internalAmountAssetStr), toString(internalPriceAssetStr)], SEP)
5858
5959
6060 func managerPublicKeyOrUnit () = {
6161 let managerVaultAddress = getManagerVaultAddressOrThis()
6262 match getString(managerVaultAddress, keyManagerPublicKey()) {
6363 case s: String =>
6464 fromBase58String(s)
6565 case _: Unit =>
6666 unit
6767 case _ =>
6868 throw("Match error")
6969 }
7070 }
7171
7272
7373 func isManager (i) = match managerPublicKeyOrUnit() {
7474 case pk: ByteVector =>
7575 (i.callerPublicKey == pk)
7676 case _: Unit =>
7777 (i.caller == this)
7878 case _ =>
7979 throw("Match error")
8080 }
8181
8282
8383 func mustManager (i) = if (isManager(i))
8484 then true
8585 else throw("permission denied")
8686
8787
8888 func getAccBalance (assetId) = if ((assetId == "WAVES"))
8989 then wavesBalance(this).available
9090 else assetBalance(this, fromBase58String(assetId))
9191
9292
9393 func stringToAssetId (assetIdString) = if ((assetIdString == "WAVES"))
9494 then unit
9595 else fromBase58String(assetIdString)
9696
9797
9898 func getSwapFees (poolAddressStr) = {
9999 let poolFeeDefault = value(getInteger(this, poolFee()))
100100 let protocolFeeDefault = value(getInteger(this, protocolFee()))
101101 match invoke(factoryContract, "getSwapFeeREADONLY", [poolAddressStr], nil) {
102102 case fees: (Int, Int) =>
103103 $Tuple2(fees._1, fees._2)
104104 case _ =>
105105 $Tuple2(poolFeeDefault, protocolFeeDefault)
106106 }
107107 }
108108
109109
110110 func getPoolAddressAndCheckPoolStatus (assetIn,assetOut) = {
111111 let lpNonReverse = {
112112 let @ = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetIn, assetOut], nil)
113113 if ($isInstanceOf(@, "String"))
114114 then @
115115 else unit
116116 }
117117 let lpReverse = {
118118 let @ = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetOut, assetIn], nil)
119119 if ($isInstanceOf(@, "String"))
120120 then @
121121 else unit
122122 }
123123 let $t031283587 = if ((lpNonReverse != unit))
124124 then {
125125 let pool = {
126126 let @ = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [value(lpNonReverse)], nil)
127127 if ($isInstanceOf(@, "String"))
128128 then @
129129 else throw(($getType(@) + " couldn't be cast to String"))
130130 }
131131 $Tuple2(false, pool)
132132 }
133133 else if ((lpReverse != unit))
134134 then {
135135 let pool = {
136136 let @ = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [value(lpReverse)], nil)
137137 if ($isInstanceOf(@, "String"))
138138 then @
139139 else throw(($getType(@) + " couldn't be cast to String"))
140140 }
141141 $Tuple2(true, pool)
142142 }
143143 else poolNotExist
144144 let isReverse = $t031283587._1
145145 let pool = $t031283587._2
146146 let poolStatus = {
147147 let @ = invoke(factoryContract, "getPoolStatusREADONLY", [pool], nil)
148148 if ($isInstanceOf(@, "Int"))
149149 then @
150150 else throw(($getType(@) + " couldn't be cast to Int"))
151151 }
152152 let check = if ((poolStatus == 1))
153153 then true
154154 else poolDisabled
155155 if ((check == check))
156156 then {
157157 let poolAdr = addressFromStringValue(valueOrElse(pool, ""))
158158 $Tuple2(poolAdr, isReverse)
159159 }
160160 else throw("Strict value is not equal to itself.")
161161 }
162162
163163
164164 @Callable(i)
165165 func swapCalculateREADONLY (amountIn,assetIn,assetOut) = {
166166 let $t039834061 = getPoolAddressAndCheckPoolStatus(assetIn, assetOut)
167167 let poolAdr = $t039834061._1
168168 let isReverse = $t039834061._2
169169 let $t040654117 = getSwapFees(toString(poolAdr))
170170 let plFee = $t040654117._1
171171 let prFee = $t040654117._2
172172 let feeProtocolAmountCalc = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
173173 let feePoolAmountCalc = fraction(toBigInt(amountIn), toBigInt(plFee), feeScale)
174174 let feeProtocolAmount = if ((toInt(feeProtocolAmountCalc) == 0))
175175 then toBigInt(1)
176176 else feeProtocolAmountCalc
177177 let feePoolAmount = if ((toInt(feePoolAmountCalc) == 0))
178178 then toBigInt(1)
179179 else feePoolAmountCalc
180- let cleanAmountIn = ((toBigInt(amountIn) - feeProtocolAmount) - feePoolAmount)
181- let res = {
180+ let cleanAmountIn = if ((isReverse == true))
181+ then ((toBigInt(amountIn) - feeProtocolAmount) - feePoolAmount)
182+ else (toBigInt(amountIn) - feePoolAmount)
183+ let totalGetRaw = {
182184 let @ = invoke(poolAdr, "calculateAmountOutForSwapREADONLY", [toInt(cleanAmountIn), isReverse, toInt(feePoolAmount)], nil)
183185 if ($isInstanceOf(@, "Int"))
184186 then @
185187 else throw(($getType(@) + " couldn't be cast to Int"))
186188 }
187- $Tuple2(nil, res)
189+ let newTotalGet = if ((isReverse == true))
190+ then totalGetRaw
191+ else {
192+ let feeProtocolFromGetCalc = fraction(toBigInt(totalGetRaw), toBigInt(prFee), feeScale)
193+ let feeProtocolAmountFromGet = if ((toInt(feeProtocolFromGetCalc) == 0))
194+ then toInt(toBigInt(1))
195+ else toInt(feeProtocolFromGetCalc)
196+ (totalGetRaw - feeProtocolAmountFromGet)
197+ }
198+ $Tuple2(nil, newTotalGet)
188199 }
189200
190201
191202
192203 @Callable(i)
193204 func swap (amountOutMin,assetOutRaw,addressTo) = {
194- let assetOut = if ((assetOutRaw == ""))
195- then "WAVES"
196- else assetOutRaw
197- let pmt = value(i.payments[0])
198- let assetIn = if ((pmt.assetId == unit))
199- then "WAVES"
200- else toBase58String(value(pmt.assetId))
201- let amountIn = value(pmt.amount)
202- let $t051305208 = getPoolAddressAndCheckPoolStatus(assetIn, assetOut)
203- let poolAdr = $t051305208._1
204- let isReverse = $t051305208._2
205- let $t052115263 = getSwapFees(toString(poolAdr))
206- let plFee = $t052115263._1
207- let prFee = $t052115263._2
208- let feeProtocolAmountCalc = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
209- let feePoolAmountCalc = fraction(toBigInt(amountIn), toBigInt(plFee), feeScale)
210- let addressTo_a = addressFromStringValue(addressTo)
211- let feeProtocolAmount = if ((toInt(feeProtocolAmountCalc) == 0))
212- then toBigInt(1)
213- else feeProtocolAmountCalc
214- let feePoolAmount = if ((toInt(feePoolAmountCalc) == 0))
215- then toBigInt(1)
216- else feePoolAmountCalc
217- let cleanAmountIn = if ((isReverse == true))
218- then ((toBigInt(amountIn) - feeProtocolAmount) - feePoolAmount)
219- else (toBigInt(amountIn) - feePoolAmount)
220205 let checks = [if ((size(i.payments) == 1))
221206 then true
222207 else throw("exactly 1 payment are expected")]
223208 if ((checks == checks))
224209 then {
210+ let assetOut = if ((assetOutRaw == ""))
211+ then "WAVES"
212+ else assetOutRaw
213+ let pmt = value(i.payments[0])
214+ let assetIn = if ((pmt.assetId == unit))
215+ then "WAVES"
216+ else toBase58String(value(pmt.assetId))
217+ let amountIn = value(pmt.amount)
218+ let $t059165994 = getPoolAddressAndCheckPoolStatus(assetIn, assetOut)
219+ let poolAdr = $t059165994._1
220+ let isReverse = $t059165994._2
221+ let $t059976049 = getSwapFees(toString(poolAdr))
222+ let plFee = $t059976049._1
223+ let prFee = $t059976049._2
224+ let feeProtocolAmountCalc = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
225+ let feePoolAmountCalc = fraction(toBigInt(amountIn), toBigInt(plFee), feeScale)
226+ let addressTo_a = addressFromStringValue(addressTo)
227+ let feeProtocolAmount = if ((toInt(feeProtocolAmountCalc) == 0))
228+ then toBigInt(1)
229+ else feeProtocolAmountCalc
230+ let feePoolAmount = if ((toInt(feePoolAmountCalc) == 0))
231+ then toBigInt(1)
232+ else feePoolAmountCalc
233+ let cleanAmountIn = if ((isReverse == true))
234+ then ((toBigInt(amountIn) - feeProtocolAmount) - feePoolAmount)
235+ else (toBigInt(amountIn) - feePoolAmount)
225236 let assetInAttachedPayment = stringToAssetId(assetIn)
226237 let totalGetRaw = {
227238 let @ = invoke(poolAdr, "calculateAmountOutForSwapAndSendTokens", [toInt(cleanAmountIn), isReverse, amountOutMin, toString(this), toInt(feePoolAmount)], [AttachedPayment(assetInAttachedPayment, toInt(cleanAmountIn))])
228239 if ($isInstanceOf(@, "Int"))
229240 then @
230241 else throw(($getType(@) + " couldn't be cast to Int"))
231242 }
232- let $t065177111 = if ((isReverse == true))
243+ let $t072077801 = if ((isReverse == true))
233244 then $Tuple2([ScriptTransfer(feeCollectorAddress, toInt(feeProtocolAmount), assetInAttachedPayment)], totalGetRaw)
234245 else {
235246 let feeProtocolFromGetCalc = fraction(toBigInt(totalGetRaw), toBigInt(prFee), feeScale)
236247 let feeProtocolAmountFromGet = if ((toInt(feeProtocolFromGetCalc) == 0))
237248 then toInt(toBigInt(1))
238249 else toInt(feeProtocolFromGetCalc)
239250 $Tuple2([ScriptTransfer(feeCollectorAddress, feeProtocolAmountFromGet, stringToAssetId(assetOut))], (totalGetRaw - feeProtocolAmountFromGet))
240251 }
241- let protocolFeeActions = $t065177111._1
242- let newTotalGet = $t065177111._2
252+ let protocolFeeActions = $t072077801._1
253+ let newTotalGet = $t072077801._2
243254 $Tuple2((protocolFeeActions ++ [ScriptTransfer(poolAdr, toInt(feePoolAmount), assetInAttachedPayment), ScriptTransfer(addressTo_a, newTotalGet, stringToAssetId(assetOut))]), newTotalGet)
244255 }
245256 else throw("Strict value is not equal to itself.")
246257 }
247258
248259
249260 @Verifier(tx)
250261 func verify () = {
251262 let targetPublicKey = match managerPublicKeyOrUnit() {
252263 case pk: ByteVector =>
253264 pk
254265 case _: Unit =>
255266 tx.senderPublicKey
256267 case _ =>
257268 throw("Match error")
258269 }
259270 sigVerify(tx.bodyBytes, tx.proofs[0], targetPublicKey)
260271 }
261272

github/deemru/w8io/169f3d6 
63.03 ms