tx · iagmBQd5s4ACoPgKuu5dDpiEWRo7oDUQSJ43x9jpEQA

3N6LHjfGb6Fgcy7YsVcNxGyPTj49XbQAijq:  -0.01300000 Waves

2023.07.26 17:30 [2682953] smart account 3N6LHjfGb6Fgcy7YsVcNxGyPTj49XbQAijq > SELF 0.00000000 Waves

{ "type": 13, "id": "iagmBQd5s4ACoPgKuu5dDpiEWRo7oDUQSJ43x9jpEQA", "fee": 1300000, "feeAssetId": null, "timestamp": 1690381792563, "version": 2, "chainId": 84, "sender": "3N6LHjfGb6Fgcy7YsVcNxGyPTj49XbQAijq", "senderPublicKey": "2u2wYYcVBQv43Cc71zkhHPPitkqgg6dqTZ3nUMvYJ1uq", "proofs": [ "5GSX8sggvtxBGqmYWgnQsnssVgbV3rMd7EMurzCehxnf79q168Exn8wdv4xHEdc39xt1SqNcMufSnFd563zWPUFm" ], "script": "base64:BgIQCAISBQoDAQgIEgUKAwEICBgAA1NFUAICX18ACGZlZVNjYWxlCQC2AgEAgMLXLwEPZ2V0U3RyaW5nT3JGYWlsAQNrZXkJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQNrZXkJAKwCAgIVTm8gZGF0YSBmb3IgdGhpcy5rZXk9BQNrZXkADHBvb2xEaXNhYmxlZAkAAgECDVBvb2wgZGlzYWJsZWQADHBvb2xOb3RFeGlzdAkAAgECEVBvb2wgaXMgbm90IGV4aXN0AA5zbGlwcGFnZVRvb0JpZwkAAgECE1NsaXBwYWdlIGlzIHRvbyBiaWcBE2tleU1hbmFnZXJQdWJsaWNLZXkAAhQlc19fbWFuYWdlclB1YmxpY0tleQEWa2V5TWFuYWdlclZhdWx0QWRkcmVzcwACFyVzX19tYW5hZ2VyVmF1bHRBZGRyZXNzAQJmYwACEyVzX19mYWN0b3J5Q29udHJhY3QAD2ZhY3RvcnlDb250cmFjdAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBD2dldFN0cmluZ09yRmFpbAEJAQJmYwABC3Byb3RvY29sRmVlAAkAuQkCCQDMCAICAiVzCQDMCAICC3Byb3RvY29sRmVlBQNuaWwFA1NFUAEHcG9vbEZlZQAJALkJAgkAzAgCAgIlcwkAzAgCAgdwb29sRmVlBQNuaWwFA1NFUAEaZ2V0U3RyaW5nT3JGYWlsRnJvbUFkZHJlc3MCB2FkZHJlc3MDa2V5CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUHYWRkcmVzcwUDa2V5CQC5CQIJAMwIAgIKbWFuZGF0b3J5IAkAzAgCCQClCAEFB2FkZHJlc3MJAMwIAgIBLgkAzAgCBQNrZXkJAMwIAgIPIGlzIG5vdCBkZWZpbmVkBQNuaWwCAAAWa2V5RmVlQ29sbGVjdG9yQWRkcmVzcwIXJXNfX2ZlZUNvbGxlY3RvckFkZHJlc3MAE2ZlZUNvbGxlY3RvckFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARpnZXRTdHJpbmdPckZhaWxGcm9tQWRkcmVzcwIFD2ZhY3RvcnlDb250cmFjdAUWa2V5RmVlQ29sbGVjdG9yQWRkcmVzcwEcZ2V0TWFuYWdlclZhdWx0QWRkcmVzc09yVGhpcwAEByRtYXRjaDAJAKIIAQkBFmtleU1hbmFnZXJWYXVsdEFkZHJlc3MAAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAkBEUBleHRyTmF0aXZlKDEwNjIpAQUBcwUEdGhpcwEFYXNJbnQBA3ZhbAQHJG1hdGNoMAUDdmFsAwkAAQIFByRtYXRjaDACA0ludAQGdmFsSW50BQckbWF0Y2gwBQZ2YWxJbnQJAAIBAhVmYWlsIHRvIGNhc3QgaW50byBJbnQBFWRhdGFNYXBwaW5nUG9vbEFzc2V0cwIWaW50ZXJuYWxBbW91bnRBc3NldFN0chVpbnRlcm5hbFByaWNlQXNzZXRTdHIJALkJAgkAzAgCAgQlZCVkCQDMCAIJAKQDAQUWaW50ZXJuYWxBbW91bnRBc3NldFN0cgkAzAgCCQCkAwEFFWludGVybmFsUHJpY2VBc3NldFN0cgUDbmlsBQNTRVABFm1hbmFnZXJQdWJsaWNLZXlPclVuaXQABBNtYW5hZ2VyVmF1bHRBZGRyZXNzCQEcZ2V0TWFuYWdlclZhdWx0QWRkcmVzc09yVGhpcwAEByRtYXRjaDAJAJ0IAgUTbWFuYWdlclZhdWx0QWRkcmVzcwkBE2tleU1hbmFnZXJQdWJsaWNLZXkAAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAkA2QQBBQFzAwkAAQIFByRtYXRjaDACBFVuaXQFBHVuaXQJAAIBAgtNYXRjaCBlcnJvcgEJaXNNYW5hZ2VyAQFpBAckbWF0Y2gwCQEWbWFuYWdlclB1YmxpY0tleU9yVW5pdAADCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQCcGsFByRtYXRjaDAJAAACCAUBaQ9jYWxsZXJQdWJsaWNLZXkFAnBrAwkAAQIFByRtYXRjaDACBFVuaXQJAAACCAUBaQZjYWxsZXIFBHRoaXMJAAIBAgtNYXRjaCBlcnJvcgELbXVzdE1hbmFnZXIBAWkDCQEJaXNNYW5hZ2VyAQUBaQYJAAIBAhFwZXJtaXNzaW9uIGRlbmllZAENZ2V0QWNjQmFsYW5jZQEHYXNzZXRJZAMJAAACBQdhc3NldElkAgVXQVZFUwgJAO8HAQUEdGhpcwlhdmFpbGFibGUJAPAHAgUEdGhpcwkA2QQBBQdhc3NldElkAQtnZXRTd2FwRmVlcwEOcG9vbEFkZHJlc3NTdHIEDnBvb2xGZWVEZWZhdWx0CQEFdmFsdWUBCQCaCAIFBHRoaXMJAQdwb29sRmVlAAQScHJvdG9jb2xGZWVEZWZhdWx0CQEFdmFsdWUBCQCaCAIFBHRoaXMJAQtwcm90b2NvbEZlZQAEByRtYXRjaDAJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AhJnZXRTd2FwRmVlUkVBRE9OTFkJAMwIAgUOcG9vbEFkZHJlc3NTdHIFA25pbAUDbmlsAwkAAQIFByRtYXRjaDACCihJbnQsIEludCkEBGZlZXMFByRtYXRjaDAJAJQKAggFBGZlZXMCXzEIBQRmZWVzAl8yCQCUCgIFDnBvb2xGZWVEZWZhdWx0BRJwcm90b2NvbEZlZURlZmF1bHQBIGdldFBvb2xBZGRyZXNzQW5kQ2hlY2tQb29sU3RhdHVzAgdhc3NldEluCGFzc2V0T3V0BAxscE5vblJldmVyc2UKAAFACQD8BwQFD2ZhY3RvcnlDb250cmFjdAIgZ2V0THBBc3NldEZyb21Qb29sQXNzZXRzUkVBRE9OTFkJAMwIAgUHYXNzZXRJbgkAzAgCBQhhc3NldE91dAUDbmlsBQNuaWwDCQABAgUBQAIGU3RyaW5nBQFABQR1bml0BAlscFJldmVyc2UKAAFACQD8BwQFD2ZhY3RvcnlDb250cmFjdAIgZ2V0THBBc3NldEZyb21Qb29sQXNzZXRzUkVBRE9OTFkJAMwIAgUIYXNzZXRPdXQJAMwIAgUHYXNzZXRJbgUDbmlsBQNuaWwDCQABAgUBQAIGU3RyaW5nBQFABQR1bml0BAskdDAyOTk4MzQ1NwMJAQIhPQIFDGxwTm9uUmV2ZXJzZQUEdW5pdAQEcG9vbAoAAUAJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AiFnZXRQb29sQWRkcmVzc0Zyb21McEFzc2V0UkVBRE9OTFkJAMwIAgkBBXZhbHVlAQUMbHBOb25SZXZlcnNlBQNuaWwFA25pbAMJAAECBQFAAgZTdHJpbmcFAUAJAAIBCQCsAgIJAAMBBQFAAhsgY291bGRuJ3QgYmUgY2FzdCB0byBTdHJpbmcJAJQKAgcFBHBvb2wDCQECIT0CBQlscFJldmVyc2UFBHVuaXQEBHBvb2wKAAFACQD8BwQFD2ZhY3RvcnlDb250cmFjdAIhZ2V0UG9vbEFkZHJlc3NGcm9tTHBBc3NldFJFQURPTkxZCQDMCAIJAQV2YWx1ZQEFCWxwUmV2ZXJzZQUDbmlsBQNuaWwDCQABAgUBQAIGU3RyaW5nBQFACQACAQkArAICCQADAQUBQAIbIGNvdWxkbid0IGJlIGNhc3QgdG8gU3RyaW5nCQCUCgIGBQRwb29sBQxwb29sTm90RXhpc3QECWlzUmV2ZXJzZQgFCyR0MDI5OTgzNDU3Al8xBARwb29sCAULJHQwMjk5ODM0NTcCXzIECnBvb2xTdGF0dXMKAAFACQD8BwQFD2ZhY3RvcnlDb250cmFjdAIVZ2V0UG9vbFN0YXR1c1JFQURPTkxZCQDMCAIFBHBvb2wFA25pbAUDbmlsAwkAAQIFAUACA0ludAUBQAkAAgEJAKwCAgkAAwEFAUACGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAQFY2hlY2sDCQAAAgUKcG9vbFN0YXR1cwABBgUMcG9vbERpc2FibGVkAwkAAAIFBWNoZWNrBQVjaGVjawQHcG9vbEFkcgkBEUBleHRyTmF0aXZlKDEwNjIpAQkBC3ZhbHVlT3JFbHNlAgUEcG9vbAIACQCUCgIFB3Bvb2xBZHIFCWlzUmV2ZXJzZQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgIBaQEVc3dhcENhbGN1bGF0ZVJFQURPTkxZAwhhbW91bnRJbgdhc3NldEluCGFzc2V0T3V0BAskdDAzODUzMzkzMQkBIGdldFBvb2xBZGRyZXNzQW5kQ2hlY2tQb29sU3RhdHVzAgUHYXNzZXRJbgUIYXNzZXRPdXQEB3Bvb2xBZHIIBQskdDAzODUzMzkzMQJfMQQJaXNSZXZlcnNlCAULJHQwMzg1MzM5MzECXzIECyR0MDM5MzUzOTg3CQELZ2V0U3dhcEZlZXMBCQClCAEFB3Bvb2xBZHIEBXBsRmVlCAULJHQwMzkzNTM5ODcCXzEEBXByRmVlCAULJHQwMzkzNTM5ODcCXzIEFWZlZVByb3RvY29sQW1vdW50Q2FsYwkAvAIDCQC2AgEFCGFtb3VudEluCQC2AgEFBXByRmVlBQhmZWVTY2FsZQQRZmVlUG9vbEFtb3VudENhbGMJALwCAwkAtgIBBQhhbW91bnRJbgkAtgIBBQVwbEZlZQUIZmVlU2NhbGUEEWZlZVByb3RvY29sQW1vdW50AwkAAAIJAKADAQUVZmVlUHJvdG9jb2xBbW91bnRDYWxjAAAJALYCAQABBRVmZWVQcm90b2NvbEFtb3VudENhbGMEDWZlZVBvb2xBbW91bnQDCQAAAgkAoAMBBRFmZWVQb29sQW1vdW50Q2FsYwAACQC2AgEAAQURZmVlUG9vbEFtb3VudENhbGMEDWNsZWFuQW1vdW50SW4JALgCAgkAuAICCQC2AgEFCGFtb3VudEluBRFmZWVQcm90b2NvbEFtb3VudAUNZmVlUG9vbEFtb3VudAQDcmVzCgABQAkA/AcEBQdwb29sQWRyAiFjYWxjdWxhdGVBbW91bnRPdXRGb3JTd2FwUkVBRE9OTFkJAMwIAgkAoAMBBQ1jbGVhbkFtb3VudEluCQDMCAIFCWlzUmV2ZXJzZQkAzAgCCQCgAwEFDWZlZVBvb2xBbW91bnQFA25pbAUDbmlsAwkAAQIFAUACA0ludAUBQAkAAgEJAKwCAgkAAwEFAUACGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAkAlAoCBQNuaWwFA3JlcwFpAQRzd2FwAwxhbW91bnRPdXRNaW4LYXNzZXRPdXRSYXcJYWRkcmVzc1RvBAhhc3NldE91dAMJAAACBQthc3NldE91dFJhdwIAAgVXQVZFUwULYXNzZXRPdXRSYXcEA3BtdAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAABAdhc3NldEluAwkAAAIIBQNwbXQHYXNzZXRJZAUEdW5pdAIFV0FWRVMJANgEAQkBBXZhbHVlAQgFA3BtdAdhc3NldElkBAhhbW91bnRJbgkBBXZhbHVlAQgFA3BtdAZhbW91bnQECyR0MDUwMDA1MDc4CQEgZ2V0UG9vbEFkZHJlc3NBbmRDaGVja1Bvb2xTdGF0dXMCBQdhc3NldEluBQhhc3NldE91dAQHcG9vbEFkcggFCyR0MDUwMDA1MDc4Al8xBAlpc1JldmVyc2UIBQskdDA1MDAwNTA3OAJfMgQLJHQwNTA4MTUxMzMJAQtnZXRTd2FwRmVlcwEJAKUIAQUHcG9vbEFkcgQFcGxGZWUIBQskdDA1MDgxNTEzMwJfMQQFcHJGZWUIBQskdDA1MDgxNTEzMwJfMgQVZmVlUHJvdG9jb2xBbW91bnRDYWxjCQC8AgMJALYCAQUIYW1vdW50SW4JALYCAQUFcHJGZWUFCGZlZVNjYWxlBBFmZWVQb29sQW1vdW50Q2FsYwkAvAIDCQC2AgEFCGFtb3VudEluCQC2AgEFBXBsRmVlBQhmZWVTY2FsZQQRZmVlUHJvdG9jb2xBbW91bnQDCQAAAgkAoAMBBRVmZWVQcm90b2NvbEFtb3VudENhbGMAAAkAtgIBAAEFFWZlZVByb3RvY29sQW1vdW50Q2FsYwQNZmVlUG9vbEFtb3VudAMJAAACCQCgAwEFEWZlZVBvb2xBbW91bnRDYWxjAAAJALYCAQABBRFmZWVQb29sQW1vdW50Q2FsYwQNY2xlYW5BbW91bnRJbgkAuAICCQC4AgIJALYCAQUIYW1vdW50SW4FEWZlZVByb3RvY29sQW1vdW50BQ1mZWVQb29sQW1vdW50BAZjaGVja3MJAMwIAgMJAAACCQCQAwEIBQFpCHBheW1lbnRzAAEGCQACAQIeZXhhY3RseSAxIHBheW1lbnQgYXJlIGV4cGVjdGVkBQNuaWwDCQAAAgUGY2hlY2tzBQZjaGVja3MEFmFzc2V0SW5BdHRhY2hlZFBheW1lbnQDCQAAAgUHYXNzZXRJbgIFV0FWRVMFBHVuaXQJANkEAQUHYXNzZXRJbgQLdG90YWxHZXRSYXcKAAFACQD8BwQFB3Bvb2xBZHICJmNhbGN1bGF0ZUFtb3VudE91dEZvclN3YXBBbmRTZW5kVG9rZW5zCQDMCAIJAKADAQUNY2xlYW5BbW91bnRJbgkAzAgCBQlpc1JldmVyc2UJAMwIAgUMYW1vdW50T3V0TWluCQDMCAIFCWFkZHJlc3NUbwkAzAgCCQCgAwEFDWZlZVBvb2xBbW91bnQFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUWYXNzZXRJbkF0dGFjaGVkUGF5bWVudAkAoAMBBQ1jbGVhbkFtb3VudEluBQNuaWwDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50CQCUCgIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUTZmVlQ29sbGVjdG9yQWRkcmVzcwkAoAMBBRFmZWVQcm90b2NvbEFtb3VudAUWYXNzZXRJbkF0dGFjaGVkUGF5bWVudAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQdwb29sQWRyCQCgAwEFDWZlZVBvb2xBbW91bnQFFmFzc2V0SW5BdHRhY2hlZFBheW1lbnQFA25pbAULdG90YWxHZXRSYXcJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAnR4AQZ2ZXJpZnkABA90YXJnZXRQdWJsaWNLZXkEByRtYXRjaDAJARZtYW5hZ2VyUHVibGljS2V5T3JVbml0AAMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAJwawUHJG1hdGNoMAUCcGsDCQABAgUHJG1hdGNoMAIEVW5pdAgFAnR4D3NlbmRlclB1YmxpY0tleQkAAgECC01hdGNoIGVycm9yCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQ90YXJnZXRQdWJsaWNLZXnlJ/WP", "height": 2682953, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 6E7AJAL9JMV4gZg7a6XTZ5rDXmhx3wGLr2XpbPSi7f7f Next: none Diff:
OldNewDifferences
9090 else assetBalance(this, fromBase58String(assetId))
9191
9292
93+func getSwapFees (poolAddressStr) = {
94+ let poolFeeDefault = value(getInteger(this, poolFee()))
95+ let protocolFeeDefault = value(getInteger(this, protocolFee()))
96+ match invoke(factoryContract, "getSwapFeeREADONLY", [poolAddressStr], nil) {
97+ case fees: (Int, Int) =>
98+ $Tuple2(fees._1, fees._2)
99+ case _ =>
100+ $Tuple2(poolFeeDefault, protocolFeeDefault)
101+ }
102+ }
103+
104+
93105 func getPoolAddressAndCheckPoolStatus (assetIn,assetOut) = {
94106 let lpNonReverse = {
95107 let @ = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetIn, assetOut], nil)
103115 then @
104116 else unit
105117 }
106- let $t026163075 = if ((lpNonReverse != unit))
118+ let $t029983457 = if ((lpNonReverse != unit))
107119 then {
108120 let pool = {
109121 let @ = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [value(lpNonReverse)], nil)
124136 $Tuple2(true, pool)
125137 }
126138 else poolNotExist
127- let isReverse = $t026163075._1
128- let pool = $t026163075._2
139+ let isReverse = $t029983457._1
140+ let pool = $t029983457._2
129141 let poolStatus = {
130142 let @ = invoke(factoryContract, "getPoolStatusREADONLY", [pool], nil)
131143 if ($isInstanceOf(@, "Int"))
146158
147159 @Callable(i)
148160 func swapCalculateREADONLY (amountIn,assetIn,assetOut) = {
149- let prFee = value(getInteger(protocolFee()))
161+ let $t038533931 = getPoolAddressAndCheckPoolStatus(assetIn, assetOut)
162+ let poolAdr = $t038533931._1
163+ let isReverse = $t038533931._2
164+ let $t039353987 = getSwapFees(toString(poolAdr))
165+ let plFee = $t039353987._1
166+ let prFee = $t039353987._2
150167 let feeProtocolAmountCalc = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
151- let plFee = value(getInteger(poolFee()))
152168 let feePoolAmountCalc = fraction(toBigInt(amountIn), toBigInt(plFee), feeScale)
153169 let feeProtocolAmount = if ((toInt(feeProtocolAmountCalc) == 0))
154170 then toBigInt(1)
157173 then toBigInt(1)
158174 else feePoolAmountCalc
159175 let cleanAmountIn = ((toBigInt(amountIn) - feeProtocolAmount) - feePoolAmount)
160- let $t040634141 = getPoolAddressAndCheckPoolStatus(assetIn, assetOut)
161- let poolAdr = $t040634141._1
162- let isReverse = $t040634141._2
163176 let res = {
164177 let @ = invoke(poolAdr, "calculateAmountOutForSwapREADONLY", [toInt(cleanAmountIn), isReverse, toInt(feePoolAmount)], nil)
165178 if ($isInstanceOf(@, "Int"))
181194 then "WAVES"
182195 else toBase58String(value(pmt.assetId))
183196 let amountIn = value(pmt.amount)
184- let prFee = value(getInteger(protocolFee()))
197+ let $t050005078 = getPoolAddressAndCheckPoolStatus(assetIn, assetOut)
198+ let poolAdr = $t050005078._1
199+ let isReverse = $t050005078._2
200+ let $t050815133 = getSwapFees(toString(poolAdr))
201+ let plFee = $t050815133._1
202+ let prFee = $t050815133._2
185203 let feeProtocolAmountCalc = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
186- let plFee = value(getInteger(poolFee()))
187204 let feePoolAmountCalc = fraction(toBigInt(amountIn), toBigInt(plFee), feeScale)
188205 let feeProtocolAmount = if ((toInt(feeProtocolAmountCalc) == 0))
189206 then toBigInt(1)
197214 else throw("exactly 1 payment are expected")]
198215 if ((checks == checks))
199216 then {
200- let $t053435421 = getPoolAddressAndCheckPoolStatus(assetIn, assetOut)
201- let poolAdr = $t053435421._1
202- let isReverse = $t053435421._2
203217 let assetInAttachedPayment = if ((assetIn == "WAVES"))
204218 then unit
205219 else fromBase58String(assetIn)
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
93+func getSwapFees (poolAddressStr) = {
94+ let poolFeeDefault = value(getInteger(this, poolFee()))
95+ let protocolFeeDefault = value(getInteger(this, protocolFee()))
96+ match invoke(factoryContract, "getSwapFeeREADONLY", [poolAddressStr], nil) {
97+ case fees: (Int, Int) =>
98+ $Tuple2(fees._1, fees._2)
99+ case _ =>
100+ $Tuple2(poolFeeDefault, protocolFeeDefault)
101+ }
102+ }
103+
104+
93105 func getPoolAddressAndCheckPoolStatus (assetIn,assetOut) = {
94106 let lpNonReverse = {
95107 let @ = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetIn, assetOut], nil)
96108 if ($isInstanceOf(@, "String"))
97109 then @
98110 else unit
99111 }
100112 let lpReverse = {
101113 let @ = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetOut, assetIn], nil)
102114 if ($isInstanceOf(@, "String"))
103115 then @
104116 else unit
105117 }
106- let $t026163075 = if ((lpNonReverse != unit))
118+ let $t029983457 = if ((lpNonReverse != unit))
107119 then {
108120 let pool = {
109121 let @ = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [value(lpNonReverse)], nil)
110122 if ($isInstanceOf(@, "String"))
111123 then @
112124 else throw(($getType(@) + " couldn't be cast to String"))
113125 }
114126 $Tuple2(false, pool)
115127 }
116128 else if ((lpReverse != unit))
117129 then {
118130 let pool = {
119131 let @ = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [value(lpReverse)], nil)
120132 if ($isInstanceOf(@, "String"))
121133 then @
122134 else throw(($getType(@) + " couldn't be cast to String"))
123135 }
124136 $Tuple2(true, pool)
125137 }
126138 else poolNotExist
127- let isReverse = $t026163075._1
128- let pool = $t026163075._2
139+ let isReverse = $t029983457._1
140+ let pool = $t029983457._2
129141 let poolStatus = {
130142 let @ = invoke(factoryContract, "getPoolStatusREADONLY", [pool], nil)
131143 if ($isInstanceOf(@, "Int"))
132144 then @
133145 else throw(($getType(@) + " couldn't be cast to Int"))
134146 }
135147 let check = if ((poolStatus == 1))
136148 then true
137149 else poolDisabled
138150 if ((check == check))
139151 then {
140152 let poolAdr = addressFromStringValue(valueOrElse(pool, ""))
141153 $Tuple2(poolAdr, isReverse)
142154 }
143155 else throw("Strict value is not equal to itself.")
144156 }
145157
146158
147159 @Callable(i)
148160 func swapCalculateREADONLY (amountIn,assetIn,assetOut) = {
149- let prFee = value(getInteger(protocolFee()))
161+ let $t038533931 = getPoolAddressAndCheckPoolStatus(assetIn, assetOut)
162+ let poolAdr = $t038533931._1
163+ let isReverse = $t038533931._2
164+ let $t039353987 = getSwapFees(toString(poolAdr))
165+ let plFee = $t039353987._1
166+ let prFee = $t039353987._2
150167 let feeProtocolAmountCalc = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
151- let plFee = value(getInteger(poolFee()))
152168 let feePoolAmountCalc = fraction(toBigInt(amountIn), toBigInt(plFee), feeScale)
153169 let feeProtocolAmount = if ((toInt(feeProtocolAmountCalc) == 0))
154170 then toBigInt(1)
155171 else feeProtocolAmountCalc
156172 let feePoolAmount = if ((toInt(feePoolAmountCalc) == 0))
157173 then toBigInt(1)
158174 else feePoolAmountCalc
159175 let cleanAmountIn = ((toBigInt(amountIn) - feeProtocolAmount) - feePoolAmount)
160- let $t040634141 = getPoolAddressAndCheckPoolStatus(assetIn, assetOut)
161- let poolAdr = $t040634141._1
162- let isReverse = $t040634141._2
163176 let res = {
164177 let @ = invoke(poolAdr, "calculateAmountOutForSwapREADONLY", [toInt(cleanAmountIn), isReverse, toInt(feePoolAmount)], nil)
165178 if ($isInstanceOf(@, "Int"))
166179 then @
167180 else throw(($getType(@) + " couldn't be cast to Int"))
168181 }
169182 $Tuple2(nil, res)
170183 }
171184
172185
173186
174187 @Callable(i)
175188 func swap (amountOutMin,assetOutRaw,addressTo) = {
176189 let assetOut = if ((assetOutRaw == ""))
177190 then "WAVES"
178191 else assetOutRaw
179192 let pmt = value(i.payments[0])
180193 let assetIn = if ((pmt.assetId == unit))
181194 then "WAVES"
182195 else toBase58String(value(pmt.assetId))
183196 let amountIn = value(pmt.amount)
184- let prFee = value(getInteger(protocolFee()))
197+ let $t050005078 = getPoolAddressAndCheckPoolStatus(assetIn, assetOut)
198+ let poolAdr = $t050005078._1
199+ let isReverse = $t050005078._2
200+ let $t050815133 = getSwapFees(toString(poolAdr))
201+ let plFee = $t050815133._1
202+ let prFee = $t050815133._2
185203 let feeProtocolAmountCalc = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
186- let plFee = value(getInteger(poolFee()))
187204 let feePoolAmountCalc = fraction(toBigInt(amountIn), toBigInt(plFee), feeScale)
188205 let feeProtocolAmount = if ((toInt(feeProtocolAmountCalc) == 0))
189206 then toBigInt(1)
190207 else feeProtocolAmountCalc
191208 let feePoolAmount = if ((toInt(feePoolAmountCalc) == 0))
192209 then toBigInt(1)
193210 else feePoolAmountCalc
194211 let cleanAmountIn = ((toBigInt(amountIn) - feeProtocolAmount) - feePoolAmount)
195212 let checks = [if ((size(i.payments) == 1))
196213 then true
197214 else throw("exactly 1 payment are expected")]
198215 if ((checks == checks))
199216 then {
200- let $t053435421 = getPoolAddressAndCheckPoolStatus(assetIn, assetOut)
201- let poolAdr = $t053435421._1
202- let isReverse = $t053435421._2
203217 let assetInAttachedPayment = if ((assetIn == "WAVES"))
204218 then unit
205219 else fromBase58String(assetIn)
206220 let totalGetRaw = {
207221 let @ = invoke(poolAdr, "calculateAmountOutForSwapAndSendTokens", [toInt(cleanAmountIn), isReverse, amountOutMin, addressTo, toInt(feePoolAmount)], [AttachedPayment(assetInAttachedPayment, toInt(cleanAmountIn))])
208222 if ($isInstanceOf(@, "Int"))
209223 then @
210224 else throw(($getType(@) + " couldn't be cast to Int"))
211225 }
212226 $Tuple2([ScriptTransfer(feeCollectorAddress, toInt(feeProtocolAmount), assetInAttachedPayment), ScriptTransfer(poolAdr, toInt(feePoolAmount), assetInAttachedPayment)], totalGetRaw)
213227 }
214228 else throw("Strict value is not equal to itself.")
215229 }
216230
217231
218232 @Verifier(tx)
219233 func verify () = {
220234 let targetPublicKey = match managerPublicKeyOrUnit() {
221235 case pk: ByteVector =>
222236 pk
223237 case _: Unit =>
224238 tx.senderPublicKey
225239 case _ =>
226240 throw("Match error")
227241 }
228242 sigVerify(tx.bodyBytes, tx.proofs[0], targetPublicKey)
229243 }
230244

github/deemru/w8io/3ef1775 
209.73 ms