tx · 7RCQBYnNV6y55T3Yw8kRkD9BwgXFTZoxbCxHs5zGWRJC

3N6LHjfGb6Fgcy7YsVcNxGyPTj49XbQAijq:  -0.01300000 Waves

2023.02.09 13:26 [2441977] smart account 3N6LHjfGb6Fgcy7YsVcNxGyPTj49XbQAijq > SELF 0.00000000 Waves

{ "type": 13, "id": "7RCQBYnNV6y55T3Yw8kRkD9BwgXFTZoxbCxHs5zGWRJC", "fee": 1300000, "feeAssetId": null, "timestamp": 1675938373290, "version": 1, "sender": "3N6LHjfGb6Fgcy7YsVcNxGyPTj49XbQAijq", "senderPublicKey": "2u2wYYcVBQv43Cc71zkhHPPitkqgg6dqTZ3nUMvYJ1uq", "proofs": [ "YeaGVHJh8BgKT5HQvuKMZJtYxorKdh6of5n7Xj3ffRp5EBPEDkf72uii4DL8cAicicJELtScRPH4jXGCEbqjogf" ], "script": "base64:BgIXCAISBQoDAQgIEgUKAwEICBIDCgEIEgAUAANTRVACAl9fAAhmZWVTY2FsZQkAtgIBAKCNBgEPZ2V0U3RyaW5nT3JGYWlsAQNrZXkJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQNrZXkJAKwCAgIVTm8gZGF0YSBmb3IgdGhpcy5rZXk9BQNrZXkADHBvb2xEaXNhYmxlZAkAAgECDVBvb2wgZGlzYWJsZWQADHBvb2xOb3RFeGlzdAkAAgECEVBvb2wgaXMgbm90IGV4aXN0AA5zbGlwcGFnZVRvb0JpZwkAAgECE1NsaXBwYWdlIGlzIHRvbyBiaWcBE2tleU1hbmFnZXJQdWJsaWNLZXkAAhQlc19fbWFuYWdlclB1YmxpY0tleQEaa2V5UGVuZGluZ01hbmFnZXJQdWJsaWNLZXkAAhslc19fcGVuZGluZ01hbmFnZXJQdWJsaWNLZXkBAmZjAAITJXNfX2ZhY3RvcnlDb250cmFjdAAPZmFjdG9yeUNvbnRyYWN0CQERQGV4dHJOYXRpdmUoMTA2MikBCQEPZ2V0U3RyaW5nT3JGYWlsAQkBAmZjAAEaZmVlUHJvdG9jb2xDb250cmFjdEFkZHJlc3MACQC5CQIJAMwIAgICJXMJAMwIAgIaZmVlUHJvdG9jb2xDb250cmFjdEFkZHJlc3MFA25pbAUDU0VQAAtmZWVDb250cmFjdAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBD2dldFN0cmluZ09yRmFpbAEJARpmZWVQcm90b2NvbENvbnRyYWN0QWRkcmVzcwABC3Byb3RvY29sRmVlAAkAuQkCCQDMCAICAiVzCQDMCAICC3Byb3RvY29sRmVlBQNuaWwFA1NFUAEFYXNJbnQBA3ZhbAQHJG1hdGNoMAUDdmFsAwkAAQIFByRtYXRjaDACA0ludAQGdmFsSW50BQckbWF0Y2gwBQZ2YWxJbnQJAAIBAhVmYWlsIHRvIGNhc3QgaW50byBJbnQBFWRhdGFNYXBwaW5nUG9vbEFzc2V0cwIWaW50ZXJuYWxBbW91bnRBc3NldFN0chVpbnRlcm5hbFByaWNlQXNzZXRTdHIJALkJAgkAzAgCAgQlZCVkCQDMCAIJAKQDAQUWaW50ZXJuYWxBbW91bnRBc3NldFN0cgkAzAgCCQCkAwEFFWludGVybmFsUHJpY2VBc3NldFN0cgUDbmlsBQNTRVABFm1hbmFnZXJQdWJsaWNLZXlPclVuaXQABAckbWF0Y2gwCQCiCAEJARNrZXlNYW5hZ2VyUHVibGljS2V5AAMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXMFByRtYXRjaDAJANkEAQUBcwMJAAECBQckbWF0Y2gwAgRVbml0BQR1bml0CQACAQILTWF0Y2ggZXJyb3IBHXBlbmRpbmdNYW5hZ2VyUHVibGljS2V5T3JVbml0AAQHJG1hdGNoMAkAoggBCQEaa2V5UGVuZGluZ01hbmFnZXJQdWJsaWNLZXkAAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAkA2QQBBQFzAwkAAQIFByRtYXRjaDACBFVuaXQFBHVuaXQJAAIBAgtNYXRjaCBlcnJvcgEJaXNNYW5hZ2VyAQFpBAckbWF0Y2gwCQEWbWFuYWdlclB1YmxpY0tleU9yVW5pdAADCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQCcGsFByRtYXRjaDAJAAACCAUBaQ9jYWxsZXJQdWJsaWNLZXkFAnBrAwkAAQIFByRtYXRjaDACBFVuaXQJAAACCAUBaQZjYWxsZXIFBHRoaXMJAAIBAgtNYXRjaCBlcnJvcgELbXVzdE1hbmFnZXIBAWkDCQEJaXNNYW5hZ2VyAQUBaQYJAAIBAhFwZXJtaXNzaW9uIGRlbmllZAENZ2V0QWNjQmFsYW5jZQEHYXNzZXRJZAMJAAACBQdhc3NldElkAgVXQVZFUwgJAO8HAQUEdGhpcwlhdmFpbGFibGUJAPAHAgUEdGhpcwkA2QQBBQdhc3NldElkBAFpARVzd2FwQ2FsY3VsYXRlUkVBRE9OTFkDCGFtb3VudEluB2Fzc2V0SW4IYXNzZXRPdXQEBXByRmVlCQEFdmFsdWUBCQCfCAEJAQtwcm90b2NvbEZlZQAEEWZlZVByb3RvY29sQW1vdW50CQC8AgMJALYCAQUIYW1vdW50SW4JALYCAQUFcHJGZWUFCGZlZVNjYWxlBA1jbGVhbkFtb3VudEluAwkAAAIJAKADAQURZmVlUHJvdG9jb2xBbW91bnQAAAkAtgIBAAEJALgCAgkAtgIBBQhhbW91bnRJbgURZmVlUHJvdG9jb2xBbW91bnQEDWxwTm9uUmV2ZXJlc2UJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AiBnZXRMcEFzc2V0RnJvbVBvb2xBc3NldHNSRUFET05MWQkAzAgCBQdhc3NldEluCQDMCAIFCGFzc2V0T3V0BQNuaWwFA25pbAQJbHBSZXZlcnNlCQD8BwQFD2ZhY3RvcnlDb250cmFjdAIgZ2V0THBBc3NldEZyb21Qb29sQXNzZXRzUkVBRE9OTFkJAMwIAgUIYXNzZXRPdXQJAMwIAgUHYXNzZXRJbgUDbmlsBQNuaWwECyR0MDI1NjEzMDY2AwkBAiE9AgUNbHBOb25SZXZlcmVzZQUEdW5pdAQJaXNSZXZlcnNlBwQEcG9vbAoAAUAJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AiFnZXRQb29sQWRkcmVzc0Zyb21McEFzc2V0UkVBRE9OTFkJAMwIAgUNbHBOb25SZXZlcmVzZQUDbmlsBQNuaWwDCQABAgUBQAIGU3RyaW5nBQFACQACAQkArAICCQADAQUBQAIbIGNvdWxkbid0IGJlIGNhc3QgdG8gU3RyaW5nCQCUCgIFCWlzUmV2ZXJzZQUEcG9vbAMJAQIhPQIFCWxwUmV2ZXJzZQUEdW5pdAQJaXNSZXZlcnNlBgQEcG9vbAoAAUAJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AiFnZXRQb29sQWRkcmVzc0Zyb21McEFzc2V0UkVBRE9OTFkJAMwIAgUJbHBSZXZlcnNlBQNuaWwFA25pbAMJAAECBQFAAgZTdHJpbmcFAUAJAAIBCQCsAgIJAAMBBQFAAhsgY291bGRuJ3QgYmUgY2FzdCB0byBTdHJpbmcJAJQKAgUJaXNSZXZlcnNlBQRwb29sBQxwb29sTm90RXhpc3QECWlzUmV2ZXJzZQgFCyR0MDI1NjEzMDY2Al8xBARwb29sCAULJHQwMjU2MTMwNjYCXzIECnBvb2xTdGF0dXMKAAFACQD8BwQFD2ZhY3RvcnlDb250cmFjdAIVZ2V0UG9vbFN0YXR1c1JFQURPTkxZCQDMCAIFBHBvb2wFA25pbAUDbmlsAwkAAQIFAUACA0ludAUBQAkAAgEJAKwCAgkAAwEFAUACGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAQFY2hlY2sDCQAAAgUKcG9vbFN0YXR1cwABBgUMcG9vbERpc2FibGVkAwkAAAIFBWNoZWNrBQVjaGVjawQHcG9vbEFkcgkBEUBleHRyTmF0aXZlKDEwNjIpAQkBC3ZhbHVlT3JFbHNlAgUEcG9vbAIABANyZXMKAAFACQD8BwQFB3Bvb2xBZHICIWNhbGN1bGF0ZUFtb3VudE91dEZvclN3YXBSRUFET05MWQkAzAgCCQCgAwEFDWNsZWFuQW1vdW50SW4JAMwIAgUJaXNSZXZlcnNlBQNuaWwFA25pbAMJAAECBQFAAgNJbnQFAUAJAAIBCQCsAgIJAAMBBQFAAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQJAJQKAgUDbmlsBQNyZXMJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEEc3dhcAMMYW1vdW50T3V0TWluCGFzc2V0T3V0CWFkZHJlc3NUbwQDcG10CQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAAEB2Fzc2V0SW4DCQAAAggFA3BtdAdhc3NldElkBQR1bml0CQCbAwECBVdBVkVTCQEFdmFsdWUBCAUDcG10B2Fzc2V0SWQECGFtb3VudEluCQEFdmFsdWUBCAUDcG10BmFtb3VudAQFcHJGZWUJAQV2YWx1ZQEJAJ8IAQkBC3Byb3RvY29sRmVlAAQRZmVlUHJvdG9jb2xBbW91bnQJALwCAwkAtgIBBQhhbW91bnRJbgkAtgIBBQVwckZlZQUIZmVlU2NhbGUEDWNsZWFuQW1vdW50SW4JALgCAgkAtgIBBQhhbW91bnRJbgURZmVlUHJvdG9jb2xBbW91bnQEBmNoZWNrcwkAzAgCAwkAAAIJAJADAQgFAWkIcGF5bWVudHMAAQYJAAIBAh5leGFjdGx5IDEgcGF5bWVudCBhcmUgZXhwZWN0ZWQFA25pbAMJAAACBQZjaGVja3MFBmNoZWNrcwQNbHBOb25SZXZlcmVzZQoAAUAJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AiBnZXRMcEFzc2V0RnJvbVBvb2xBc3NldHNSRUFET05MWQkAzAgCCQDYBAEFB2Fzc2V0SW4JAMwIAgUIYXNzZXRPdXQFA25pbAUDbmlsAwkAAQIFAUACC1N0cmluZ3xVbml0BQFACQACAQkArAICCQADAQUBQAIgIGNvdWxkbid0IGJlIGNhc3QgdG8gU3RyaW5nfFVuaXQECWxwUmV2ZXJzZQoAAUAJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AiBnZXRMcEFzc2V0RnJvbVBvb2xBc3NldHNSRUFET05MWQkAzAgCBQhhc3NldE91dAkAzAgCCQDYBAEFB2Fzc2V0SW4FA25pbAUDbmlsAwkAAQIFAUACC1N0cmluZ3xVbml0BQFACQACAQkArAICCQADAQUBQAIgIGNvdWxkbid0IGJlIGNhc3QgdG8gU3RyaW5nfFVuaXQECyR0MDQzMjM0ODM2AwkBAiE9AgUNbHBOb25SZXZlcmVzZQUEdW5pdAQJaXNSZXZlcnNlBwQEcG9vbAoAAUAJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AiFnZXRQb29sQWRkcmVzc0Zyb21McEFzc2V0UkVBRE9OTFkJAMwIAgkBBXZhbHVlAQUNbHBOb25SZXZlcmVzZQUDbmlsBQNuaWwDCQABAgUBQAIGU3RyaW5nBQFACQACAQkArAICCQADAQUBQAIbIGNvdWxkbid0IGJlIGNhc3QgdG8gU3RyaW5nCQCUCgIFCWlzUmV2ZXJzZQUEcG9vbAMJAQIhPQIFCWxwUmV2ZXJzZQUEdW5pdAQJaXNSZXZlcnNlBgQEcG9vbAoAAUAJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AiFnZXRQb29sQWRkcmVzc0Zyb21McEFzc2V0UkVBRE9OTFkJAMwIAgUJbHBSZXZlcnNlBQNuaWwFA25pbAMJAAECBQFAAgZTdHJpbmcFAUAJAAIBCQCsAgIJAAMBBQFAAhsgY291bGRuJ3QgYmUgY2FzdCB0byBTdHJpbmcJAJQKAgUJaXNSZXZlcnNlBQRwb29sBQxwb29sTm90RXhpc3QECWlzUmV2ZXJzZQgFCyR0MDQzMjM0ODM2Al8xBARwb29sCAULJHQwNDMyMzQ4MzYCXzIECnBvb2xTdGF0dXMKAAFACQD8BwQFD2ZhY3RvcnlDb250cmFjdAIVZ2V0UG9vbFN0YXR1c1JFQURPTkxZCQDMCAIFBHBvb2wFA25pbAUDbmlsAwkAAQIFAUACA0ludAUBQAkAAgEJAKwCAgkAAwEFAUACGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAQFY2hlY2sDCQAAAgUKcG9vbFN0YXR1cwABBgUMcG9vbERpc2FibGVkAwkAAAIFBWNoZWNrBQVjaGVjawQHcG9vbEFkcgkBEUBleHRyTmF0aXZlKDEwNjIpAQUEcG9vbAQLdG90YWxHZXRSYXcKAAFACQD8BwQFB3Bvb2xBZHICJmNhbGN1bGF0ZUFtb3VudE91dEZvclN3YXBBbmRTZW5kVG9rZW5zCQDMCAIJAKADAQUNY2xlYW5BbW91bnRJbgkAzAgCBQlpc1JldmVyc2UJAMwIAgUMYW1vdW50T3V0TWluCQDMCAIFCWFkZHJlc3NUbwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQdhc3NldEluCQCgAwEFDWNsZWFuQW1vdW50SW4FA25pbAMJAAECBQFAAgNJbnQFAUAJAAIBCQCsAgIJAAMBBQFAAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQJAJQKAgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQtmZWVDb250cmFjdAkAoAMBBRFmZWVQcm90b2NvbEFtb3VudAUHYXNzZXRJbgUDbmlsBQt0b3RhbEdldFJhdwkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQpzZXRNYW5hZ2VyARdwZW5kaW5nTWFuYWdlclB1YmxpY0tleQQLY2hlY2tDYWxsZXIJAQttdXN0TWFuYWdlcgEFAWkDCQAAAgULY2hlY2tDYWxsZXIFC2NoZWNrQ2FsbGVyBBVjaGVja01hbmFnZXJQdWJsaWNLZXkJANkEAQUXcGVuZGluZ01hbmFnZXJQdWJsaWNLZXkDCQAAAgUVY2hlY2tNYW5hZ2VyUHVibGljS2V5BRVjaGVja01hbmFnZXJQdWJsaWNLZXkJAMwIAgkBC1N0cmluZ0VudHJ5AgkBGmtleVBlbmRpbmdNYW5hZ2VyUHVibGljS2V5AAUXcGVuZGluZ01hbmFnZXJQdWJsaWNLZXkFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQ5jb25maXJtTWFuYWdlcgAEAnBtCQEdcGVuZGluZ01hbmFnZXJQdWJsaWNLZXlPclVuaXQABAVoYXNQTQMJAQlpc0RlZmluZWQBBQJwbQYJAAIBAhJubyBwZW5kaW5nIG1hbmFnZXIDCQAAAgUFaGFzUE0FBWhhc1BNBAdjaGVja1BNAwkAAAIIBQFpD2NhbGxlclB1YmxpY0tleQkBBXZhbHVlAQUCcG0GCQACAQIbeW91IGFyZSBub3QgcGVuZGluZyBtYW5hZ2VyAwkAAAIFB2NoZWNrUE0FB2NoZWNrUE0JAMwIAgkBC1N0cmluZ0VudHJ5AgkBE2tleU1hbmFnZXJQdWJsaWNLZXkACQDYBAEJAQV2YWx1ZQEFAnBtCQDMCAIJAQtEZWxldGVFbnRyeQEJARprZXlQZW5kaW5nTWFuYWdlclB1YmxpY0tleQAFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgECdHgBBnZlcmlmeQAED3RhcmdldFB1YmxpY0tleQQHJG1hdGNoMAkBFm1hbmFnZXJQdWJsaWNLZXlPclVuaXQAAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAnBrBQckbWF0Y2gwBQJwawMJAAECBQckbWF0Y2gwAgRVbml0CAUCdHgPc2VuZGVyUHVibGljS2V5CQACAQILTWF0Y2ggZXJyb3IJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAFD3RhcmdldFB1YmxpY0tlefd3k1E=", "chainId": 84, "height": 2441977, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: DqUYMbqMi7EP2SrhxKQHm8GASJtcNP2DRTLDQjHd2Jtw Next: 4iwV8vX9FoEeAgufLwch2Qkx3ACHNyds8mRVMQgQxtcG Diff:
OldNewDifferences
158158 else throw("exactly 1 payment are expected")]
159159 if ((checks == checks))
160160 then {
161- let lpNonReverese = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [toBase58String(assetIn), assetOut], nil)
162- let lpReverse = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetOut, toBase58String(assetIn)], nil)
163- let $t042814786 = if ((lpNonReverese != unit))
161+ let lpNonReverese = {
162+ let @ = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [toBase58String(assetIn), assetOut], nil)
163+ if ($isInstanceOf(@, "String|Unit"))
164+ then @
165+ else throw(($getType(@) + " couldn't be cast to String|Unit"))
166+ }
167+ let lpReverse = {
168+ let @ = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetOut, toBase58String(assetIn)], nil)
169+ if ($isInstanceOf(@, "String|Unit"))
170+ then @
171+ else throw(($getType(@) + " couldn't be cast to String|Unit"))
172+ }
173+ let $t043234836 = if ((lpNonReverese != unit))
164174 then {
165175 let isReverse = false
166176 let pool = {
167- let @ = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [lpNonReverese], nil)
177+ let @ = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [value(lpNonReverese)], nil)
168178 if ($isInstanceOf(@, "String"))
169179 then @
170180 else throw(($getType(@) + " couldn't be cast to String"))
183193 $Tuple2(isReverse, pool)
184194 }
185195 else poolNotExist
186- let isReverse = $t042814786._1
187- let pool = $t042814786._2
196+ let isReverse = $t043234836._1
197+ let pool = $t043234836._2
188198 let poolStatus = {
189199 let @ = invoke(factoryContract, "getPoolStatusREADONLY", [pool], nil)
190200 if ($isInstanceOf(@, "Int"))
197207 if ((check == check))
198208 then {
199209 let poolAdr = addressFromStringValue(pool)
200- let res = {
210+ let totalGetRaw = {
201211 let @ = invoke(poolAdr, "calculateAmountOutForSwapAndSendTokens", [toInt(cleanAmountIn), isReverse, amountOutMin, addressTo], [AttachedPayment(assetIn, toInt(cleanAmountIn))])
202- if ($isInstanceOf(@, "Boolean"))
212+ if ($isInstanceOf(@, "Int"))
203213 then @
204- else throw(($getType(@) + " couldn't be cast to Boolean"))
214+ else throw(($getType(@) + " couldn't be cast to Int"))
205215 }
206- $Tuple2([ScriptTransfer(feeContract, toInt(feeProtocolAmount), assetIn)], res)
216+ $Tuple2([ScriptTransfer(feeContract, toInt(feeProtocolAmount), assetIn)], totalGetRaw)
207217 }
208218 else throw("Strict value is not equal to itself.")
209219 }
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let SEP = "__"
55
66 let feeScale = toBigInt(100000)
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 keyPendingManagerPublicKey () = "%s__pendingManagerPublicKey"
2121
2222
2323 func fc () = "%s__factoryContract"
2424
2525
2626 let factoryContract = addressFromStringValue(getStringOrFail(fc()))
2727
2828 func feeProtocolContractAddress () = makeString(["%s", "feeProtocolContractAddress"], SEP)
2929
3030
3131 let feeContract = addressFromStringValue(getStringOrFail(feeProtocolContractAddress()))
3232
3333 func protocolFee () = makeString(["%s", "protocolFee"], SEP)
3434
3535
3636 func asInt (val) = match val {
3737 case valInt: Int =>
3838 valInt
3939 case _ =>
4040 throw("fail to cast into Int")
4141 }
4242
4343
4444 func dataMappingPoolAssets (internalAmountAssetStr,internalPriceAssetStr) = makeString(["%d%d", toString(internalAmountAssetStr), toString(internalPriceAssetStr)], SEP)
4545
4646
4747 func managerPublicKeyOrUnit () = match getString(keyManagerPublicKey()) {
4848 case s: String =>
4949 fromBase58String(s)
5050 case _: Unit =>
5151 unit
5252 case _ =>
5353 throw("Match error")
5454 }
5555
5656
5757 func pendingManagerPublicKeyOrUnit () = match getString(keyPendingManagerPublicKey()) {
5858 case s: String =>
5959 fromBase58String(s)
6060 case _: Unit =>
6161 unit
6262 case _ =>
6363 throw("Match error")
6464 }
6565
6666
6767 func isManager (i) = match managerPublicKeyOrUnit() {
6868 case pk: ByteVector =>
6969 (i.callerPublicKey == pk)
7070 case _: Unit =>
7171 (i.caller == this)
7272 case _ =>
7373 throw("Match error")
7474 }
7575
7676
7777 func mustManager (i) = if (isManager(i))
7878 then true
7979 else throw("permission denied")
8080
8181
8282 func getAccBalance (assetId) = if ((assetId == "WAVES"))
8383 then wavesBalance(this).available
8484 else assetBalance(this, fromBase58String(assetId))
8585
8686
8787 @Callable(i)
8888 func swapCalculateREADONLY (amountIn,assetIn,assetOut) = {
8989 let prFee = value(getInteger(protocolFee()))
9090 let feeProtocolAmount = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
9191 let cleanAmountIn = if ((toInt(feeProtocolAmount) == 0))
9292 then toBigInt(1)
9393 else (toBigInt(amountIn) - feeProtocolAmount)
9494 let lpNonReverese = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetIn, assetOut], nil)
9595 let lpReverse = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetOut, assetIn], nil)
9696 let $t025613066 = if ((lpNonReverese != unit))
9797 then {
9898 let isReverse = false
9999 let pool = {
100100 let @ = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [lpNonReverese], nil)
101101 if ($isInstanceOf(@, "String"))
102102 then @
103103 else throw(($getType(@) + " couldn't be cast to String"))
104104 }
105105 $Tuple2(isReverse, pool)
106106 }
107107 else if ((lpReverse != unit))
108108 then {
109109 let isReverse = true
110110 let pool = {
111111 let @ = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [lpReverse], nil)
112112 if ($isInstanceOf(@, "String"))
113113 then @
114114 else throw(($getType(@) + " couldn't be cast to String"))
115115 }
116116 $Tuple2(isReverse, pool)
117117 }
118118 else poolNotExist
119119 let isReverse = $t025613066._1
120120 let pool = $t025613066._2
121121 let poolStatus = {
122122 let @ = invoke(factoryContract, "getPoolStatusREADONLY", [pool], nil)
123123 if ($isInstanceOf(@, "Int"))
124124 then @
125125 else throw(($getType(@) + " couldn't be cast to Int"))
126126 }
127127 let check = if ((poolStatus == 1))
128128 then true
129129 else poolDisabled
130130 if ((check == check))
131131 then {
132132 let poolAdr = addressFromStringValue(valueOrElse(pool, ""))
133133 let res = {
134134 let @ = invoke(poolAdr, "calculateAmountOutForSwapREADONLY", [toInt(cleanAmountIn), isReverse], nil)
135135 if ($isInstanceOf(@, "Int"))
136136 then @
137137 else throw(($getType(@) + " couldn't be cast to Int"))
138138 }
139139 $Tuple2(nil, res)
140140 }
141141 else throw("Strict value is not equal to itself.")
142142 }
143143
144144
145145
146146 @Callable(i)
147147 func swap (amountOutMin,assetOut,addressTo) = {
148148 let pmt = value(i.payments[0])
149149 let assetIn = if ((pmt.assetId == unit))
150150 then toBytes("WAVES")
151151 else value(pmt.assetId)
152152 let amountIn = value(pmt.amount)
153153 let prFee = value(getInteger(protocolFee()))
154154 let feeProtocolAmount = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
155155 let cleanAmountIn = (toBigInt(amountIn) - feeProtocolAmount)
156156 let checks = [if ((size(i.payments) == 1))
157157 then true
158158 else throw("exactly 1 payment are expected")]
159159 if ((checks == checks))
160160 then {
161- let lpNonReverese = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [toBase58String(assetIn), assetOut], nil)
162- let lpReverse = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetOut, toBase58String(assetIn)], nil)
163- let $t042814786 = if ((lpNonReverese != unit))
161+ let lpNonReverese = {
162+ let @ = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [toBase58String(assetIn), assetOut], nil)
163+ if ($isInstanceOf(@, "String|Unit"))
164+ then @
165+ else throw(($getType(@) + " couldn't be cast to String|Unit"))
166+ }
167+ let lpReverse = {
168+ let @ = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetOut, toBase58String(assetIn)], nil)
169+ if ($isInstanceOf(@, "String|Unit"))
170+ then @
171+ else throw(($getType(@) + " couldn't be cast to String|Unit"))
172+ }
173+ let $t043234836 = if ((lpNonReverese != unit))
164174 then {
165175 let isReverse = false
166176 let pool = {
167- let @ = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [lpNonReverese], nil)
177+ let @ = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [value(lpNonReverese)], nil)
168178 if ($isInstanceOf(@, "String"))
169179 then @
170180 else throw(($getType(@) + " couldn't be cast to String"))
171181 }
172182 $Tuple2(isReverse, pool)
173183 }
174184 else if ((lpReverse != unit))
175185 then {
176186 let isReverse = true
177187 let pool = {
178188 let @ = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [lpReverse], nil)
179189 if ($isInstanceOf(@, "String"))
180190 then @
181191 else throw(($getType(@) + " couldn't be cast to String"))
182192 }
183193 $Tuple2(isReverse, pool)
184194 }
185195 else poolNotExist
186- let isReverse = $t042814786._1
187- let pool = $t042814786._2
196+ let isReverse = $t043234836._1
197+ let pool = $t043234836._2
188198 let poolStatus = {
189199 let @ = invoke(factoryContract, "getPoolStatusREADONLY", [pool], nil)
190200 if ($isInstanceOf(@, "Int"))
191201 then @
192202 else throw(($getType(@) + " couldn't be cast to Int"))
193203 }
194204 let check = if ((poolStatus == 1))
195205 then true
196206 else poolDisabled
197207 if ((check == check))
198208 then {
199209 let poolAdr = addressFromStringValue(pool)
200- let res = {
210+ let totalGetRaw = {
201211 let @ = invoke(poolAdr, "calculateAmountOutForSwapAndSendTokens", [toInt(cleanAmountIn), isReverse, amountOutMin, addressTo], [AttachedPayment(assetIn, toInt(cleanAmountIn))])
202- if ($isInstanceOf(@, "Boolean"))
212+ if ($isInstanceOf(@, "Int"))
203213 then @
204- else throw(($getType(@) + " couldn't be cast to Boolean"))
214+ else throw(($getType(@) + " couldn't be cast to Int"))
205215 }
206- $Tuple2([ScriptTransfer(feeContract, toInt(feeProtocolAmount), assetIn)], res)
216+ $Tuple2([ScriptTransfer(feeContract, toInt(feeProtocolAmount), assetIn)], totalGetRaw)
207217 }
208218 else throw("Strict value is not equal to itself.")
209219 }
210220 else throw("Strict value is not equal to itself.")
211221 }
212222
213223
214224
215225 @Callable(i)
216226 func setManager (pendingManagerPublicKey) = {
217227 let checkCaller = mustManager(i)
218228 if ((checkCaller == checkCaller))
219229 then {
220230 let checkManagerPublicKey = fromBase58String(pendingManagerPublicKey)
221231 if ((checkManagerPublicKey == checkManagerPublicKey))
222232 then [StringEntry(keyPendingManagerPublicKey(), pendingManagerPublicKey)]
223233 else throw("Strict value is not equal to itself.")
224234 }
225235 else throw("Strict value is not equal to itself.")
226236 }
227237
228238
229239
230240 @Callable(i)
231241 func confirmManager () = {
232242 let pm = pendingManagerPublicKeyOrUnit()
233243 let hasPM = if (isDefined(pm))
234244 then true
235245 else throw("no pending manager")
236246 if ((hasPM == hasPM))
237247 then {
238248 let checkPM = if ((i.callerPublicKey == value(pm)))
239249 then true
240250 else throw("you are not pending manager")
241251 if ((checkPM == checkPM))
242252 then [StringEntry(keyManagerPublicKey(), toBase58String(value(pm))), DeleteEntry(keyPendingManagerPublicKey())]
243253 else throw("Strict value is not equal to itself.")
244254 }
245255 else throw("Strict value is not equal to itself.")
246256 }
247257
248258
249259 @Verifier(tx)
250260 func verify () = {
251261 let targetPublicKey = match managerPublicKeyOrUnit() {
252262 case pk: ByteVector =>
253263 pk
254264 case _: Unit =>
255265 tx.senderPublicKey
256266 case _ =>
257267 throw("Match error")
258268 }
259269 sigVerify(tx.bodyBytes, tx.proofs[0], targetPublicKey)
260270 }
261271

github/deemru/w8io/169f3d6 
76.48 ms