tx · D4gE1QToDk9m8N56ZWVvZiZ6t7uXjAFkWPziCE8m9ocB

3N6LHjfGb6Fgcy7YsVcNxGyPTj49XbQAijq:  -0.01300000 Waves

2023.02.03 13:54 [2433347] smart account 3N6LHjfGb6Fgcy7YsVcNxGyPTj49XbQAijq > SELF 0.00000000 Waves

{ "type": 13, "id": "D4gE1QToDk9m8N56ZWVvZiZ6t7uXjAFkWPziCE8m9ocB", "fee": 1300000, "feeAssetId": null, "timestamp": 1675421686473, "version": 1, "sender": "3N6LHjfGb6Fgcy7YsVcNxGyPTj49XbQAijq", "senderPublicKey": "2u2wYYcVBQv43Cc71zkhHPPitkqgg6dqTZ3nUMvYJ1uq", "proofs": [ "2dj5zzSPMYd5E6moPyum3jqVHQFCX17eSk6PmMzEx5xFeJ9VRJKvY6nwrc2j8UNY6xJ4JnzfHG8dVaf7AuWcqQx4" ], "script": "base64:BgIXCAISBQoDAQgIEgUKAwEICBIDCgEIEgAUAANTRVACAl9fAAhmZWVTY2FsZQkAtgIBAKCNBgEPZ2V0U3RyaW5nT3JGYWlsAQNrZXkJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQNrZXkJAKwCAgIVTm8gZGF0YSBmb3IgdGhpcy5rZXk9BQNrZXkADHBvb2xEaXNhYmxlZAkAAgECDVBvb2wgZGlzYWJsZWQADHBvb2xOb3RFeGlzdAkAAgECEVBvb2wgaXMgbm90IGV4aXN0AA5zbGlwcGFnZVRvb0JpZwkAAgECE1NsaXBwYWdlIGlzIHRvbyBiaWcBE2tleU1hbmFnZXJQdWJsaWNLZXkAAhQlc19fbWFuYWdlclB1YmxpY0tleQEaa2V5UGVuZGluZ01hbmFnZXJQdWJsaWNLZXkAAhslc19fcGVuZGluZ01hbmFnZXJQdWJsaWNLZXkBAmZjAAITJXNfX2ZhY3RvcnlDb250cmFjdAAPZmFjdG9yeUNvbnRyYWN0CQERQGV4dHJOYXRpdmUoMTA2MikBCQEPZ2V0U3RyaW5nT3JGYWlsAQkBAmZjAAEbZmVlTGlxdWlkaXR5Q29udHJhY3RBZGRyZXNzAAkAuQkCCQDMCAICAiVzCQDMCAICG2ZlZUxpcXVpZGl0eUNvbnRyYWN0QWRkcmVzcwUDbmlsBQNTRVABDGZlZUxpcXVpZGl0eQAJALkJAgkAzAgCAgIlcwkAzAgCAgxmZWVMaXF1aWRpdHkFA25pbAUDU0VQAQtwcm90b2NvbEZlZQAJALkJAgkAzAgCAgIlcwkAzAgCAgtwcm90b2NvbEZlZQUDbmlsBQNTRVABBWFzSW50AQN2YWwEByRtYXRjaDAFA3ZhbAMJAAECBQckbWF0Y2gwAgNJbnQEBnZhbEludAUHJG1hdGNoMAUGdmFsSW50CQACAQIVZmFpbCB0byBjYXN0IGludG8gSW50ARVkYXRhTWFwcGluZ1Bvb2xBc3NldHMCFmludGVybmFsQW1vdW50QXNzZXRTdHIVaW50ZXJuYWxQcmljZUFzc2V0U3RyCQC5CQIJAMwIAgIEJWQlZAkAzAgCCQCkAwEFFmludGVybmFsQW1vdW50QXNzZXRTdHIJAMwIAgkApAMBBRVpbnRlcm5hbFByaWNlQXNzZXRTdHIFA25pbAUDU0VQARZtYW5hZ2VyUHVibGljS2V5T3JVbml0AAQHJG1hdGNoMAkAoggBCQETa2V5TWFuYWdlclB1YmxpY0tleQADCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFzBQckbWF0Y2gwCQDZBAEFAXMDCQABAgUHJG1hdGNoMAIEVW5pdAUEdW5pdAkAAgECC01hdGNoIGVycm9yAR1wZW5kaW5nTWFuYWdlclB1YmxpY0tleU9yVW5pdAAEByRtYXRjaDAJAKIIAQkBGmtleVBlbmRpbmdNYW5hZ2VyUHVibGljS2V5AAMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXMFByRtYXRjaDAJANkEAQUBcwMJAAECBQckbWF0Y2gwAgRVbml0BQR1bml0CQACAQILTWF0Y2ggZXJyb3IBCWlzTWFuYWdlcgEBaQQHJG1hdGNoMAkBFm1hbmFnZXJQdWJsaWNLZXlPclVuaXQAAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAnBrBQckbWF0Y2gwCQAAAggFAWkPY2FsbGVyUHVibGljS2V5BQJwawMJAAECBQckbWF0Y2gwAgRVbml0CQAAAggFAWkGY2FsbGVyBQR0aGlzCQACAQILTWF0Y2ggZXJyb3IBC211c3RNYW5hZ2VyAQFpAwkBCWlzTWFuYWdlcgEFAWkGCQACAQIRcGVybWlzc2lvbiBkZW5pZWQBDWdldEFjY0JhbGFuY2UBB2Fzc2V0SWQDCQAAAgUHYXNzZXRJZAIFV0FWRVMICQDvBwEFBHRoaXMJYXZhaWxhYmxlCQDwBwIFBHRoaXMJANkEAQUHYXNzZXRJZAQBaQEVc3dhcENhbGN1bGF0ZVJFQURPTkxZAwhhbW91bnRJbgdhc3NldEluCGFzc2V0T3V0BAVwckZlZQkBBXZhbHVlAQkAnwgBCQELcHJvdG9jb2xGZWUABBFmZWVQcm90b2NvbEFtb3VudAkAvAIDCQC2AgEFCGFtb3VudEluCQC2AgEFBXByRmVlBQhmZWVTY2FsZQQSZmVlTGlxdWlkaXR5QW1vdW50CQC8AgMJALYCAQUIYW1vdW50SW4JALYCAQUFcHJGZWUFCGZlZVNjYWxlBA5hbW91bnRJblRvUG9vbAkAuAICCQC2AgEFCGFtb3VudEluBRFmZWVQcm90b2NvbEFtb3VudAQNY2xlYW5BbW91bnRJbgkAuAICBQ5hbW91bnRJblRvUG9vbAUSZmVlTGlxdWlkaXR5QW1vdW50BA1scE5vblJldmVyZXNlCQD8BwQFD2ZhY3RvcnlDb250cmFjdAIgZ2V0THBBc3NldEZyb21Qb29sQXNzZXRzUkVBRE9OTFkJAMwIAgUHYXNzZXRJbgkAzAgCBQhhc3NldE91dAUDbmlsBQNuaWwECWxwUmV2ZXJzZQkA/AcEBQ9mYWN0b3J5Q29udHJhY3QCIGdldExwQXNzZXRGcm9tUG9vbEFzc2V0c1JFQURPTkxZCQDMCAIFCGFzc2V0T3V0CQDMCAIFB2Fzc2V0SW4FA25pbAUDbmlsBAskdDAyNjQxMzExNAMJAQIhPQIFDWxwTm9uUmV2ZXJlc2UFBHVuaXQECWlzUmV2ZXJzZQcEBHBvb2wJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AiFnZXRQb29sQWRkcmVzc0Zyb21McEFzc2V0UkVBRE9OTFkJAMwIAgUNbHBOb25SZXZlcmVzZQUDbmlsBQNuaWwJAJQKAgUJaXNSZXZlcnNlBQRwb29sAwkBAiE9AgUJbHBSZXZlcnNlBQR1bml0BAlpc1JldmVyc2UGBARwb29sCQD8BwQFD2ZhY3RvcnlDb250cmFjdAIhZ2V0UG9vbEFkZHJlc3NGcm9tTHBBc3NldFJFQURPTkxZCQDMCAIFCWxwUmV2ZXJzZQUDbmlsBQNuaWwJAJQKAgUJaXNSZXZlcnNlBQRwb29sBQxwb29sTm90RXhpc3QECWlzUmV2ZXJzZQgFCyR0MDI2NDEzMTE0Al8xBARwb29sCAULJHQwMjY0MTMxMTQCXzIEIGlzUG9vbE9uZVRva2VuT3BlcmF0aW9uc0Rpc2FibGVkCgABQAkA/AcEBQ9mYWN0b3J5Q29udHJhY3QCKGlzUG9vbE9uZVRva2VuT3BlcmF0aW9uc0Rpc2FibGVkUkVBRE9OTFkJAMwIAgUEcG9vbAUDbmlsBQNuaWwDCQABAgUBQAIHQm9vbGVhbgUBQAkAAgEJAKwCAgkAAwEFAUACHCBjb3VsZG4ndCBiZSBjYXN0IHRvIEJvb2xlYW4EBWNoZWNrAwUgaXNQb29sT25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWQGBQxwb29sRGlzYWJsZWQDCQAAAgUFY2hlY2sFBWNoZWNrBAdwb29sQWRyCQERQGV4dHJOYXRpdmUoMTA2MikBCQELdmFsdWVPckVsc2UCBQRwb29sAgAEBmNoZWNrMgMHBgUMcG9vbERpc2FibGVkAwkAAAIFBmNoZWNrMgUGY2hlY2syBANyZXMKAAFACQD8BwQFB3Bvb2xBZHICIWNhbGN1bGF0ZUFtb3VudE91dEZvclN3YXBSRUFET05MWQkAzAgCBQ1jbGVhbkFtb3VudEluCQDMCAIFCWlzUmV2ZXJzZQUDbmlsBQNuaWwDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50CQCUCgIFA25pbAUDcmVzCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBBHN3YXADDGFtb3VudE91dE1pbghhc3NldE91dAlhZGRyZXNzVG8EA3BtdAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAABAdhc3NldEluAwkAAAIIBQNwbXQHYXNzZXRJZAUEdW5pdAkAmwMBAgVXQVZFUwkBBXZhbHVlAQgFA3BtdAdhc3NldElkBAhhbW91bnRJbgkBBXZhbHVlAQgFA3BtdAZhbW91bnQEBXByRmVlCQEFdmFsdWUBCQCfCAEJAQtwcm90b2NvbEZlZQAEEWZlZVByb3RvY29sQW1vdW50CQC8AgMJALYCAQUIYW1vdW50SW4JALYCAQUFcHJGZWUFCGZlZVNjYWxlBBJmZWVMaXF1aWRpdHlBbW91bnQJALwCAwkAtgIBBQhhbW91bnRJbgkAtgIBBQVwckZlZQUIZmVlU2NhbGUEDmFtb3VudEluVG9Qb29sCQC4AgIJALYCAQUIYW1vdW50SW4FEWZlZVByb3RvY29sQW1vdW50BA1jbGVhbkFtb3VudEluCQC4AgIFDmFtb3VudEluVG9Qb29sBRJmZWVMaXF1aWRpdHlBbW91bnQEBmNoZWNrcwkAzAgCAwkAAAIJAJADAQgFAWkIcGF5bWVudHMAAQYJAAIBAh5leGFjdGx5IDEgcGF5bWVudCBhcmUgZXhwZWN0ZWQFA25pbAMJAAACBQZjaGVja3MFBmNoZWNrcwQNbHBOb25SZXZlcmVzZQkA/AcEBQ9mYWN0b3J5Q29udHJhY3QCIGdldExwQXNzZXRGcm9tUG9vbEFzc2V0c1JFQURPTkxZCQDMCAIFB2Fzc2V0SW4JAMwIAgUIYXNzZXRPdXQFA25pbAUDbmlsBAlscFJldmVyc2UJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AiBnZXRMcEFzc2V0RnJvbVBvb2xBc3NldHNSRUFET05MWQkAzAgCBQhhc3NldE91dAkAzAgCBQdhc3NldEluBQNuaWwFA25pbAQLJHQwNDU3NTUwNjUDCQECIT0CBQ1scE5vblJldmVyZXNlBQR1bml0BAlpc1JldmVyc2UHBARwb29sCgABQAkA/AcEBQ9mYWN0b3J5Q29udHJhY3QCIWdldFBvb2xBZGRyZXNzRnJvbUxwQXNzZXRSRUFET05MWQkAzAgCBQ1scE5vblJldmVyZXNlBQNuaWwFA25pbAMJAAECBQFAAgdBZGRyZXNzBQFACQACAQkArAICCQADAQUBQAIcIGNvdWxkbid0IGJlIGNhc3QgdG8gQWRkcmVzcwkAlAoCBQlpc1JldmVyc2UFBHBvb2wDCQECIT0CBQlscFJldmVyc2UFBHVuaXQECWlzUmV2ZXJzZQYEBHBvb2wJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AiFnZXRQb29sQWRkcmVzc0Zyb21McEFzc2V0UkVBRE9OTFkJAMwIAgUJbHBSZXZlcnNlBQNuaWwFA25pbAkAlAoCBQlpc1JldmVyc2UFBHBvb2wFDHBvb2xOb3RFeGlzdAQJaXNSZXZlcnNlCAULJHQwNDU3NTUwNjUCXzEEBHBvb2wIBQskdDA0NTc1NTA2NQJfMgQgaXNQb29sT25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWQKAAFACQD8BwQFD2ZhY3RvcnlDb250cmFjdAIoaXNQb29sT25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWRSRUFET05MWQkAzAgCBQRwb29sBQNuaWwFA25pbAMJAAECBQFAAgdCb29sZWFuBQFACQACAQkArAICCQADAQUBQAIcIGNvdWxkbid0IGJlIGNhc3QgdG8gQm9vbGVhbgQFY2hlY2sDBSBpc1Bvb2xPbmVUb2tlbk9wZXJhdGlvbnNEaXNhYmxlZAYFDHBvb2xEaXNhYmxlZAMJAAACBQVjaGVjawUFY2hlY2sEB3Bvb2xBZHIJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQt2YWx1ZU9yRWxzZQIFBHBvb2wCAAQDcmVzCgABQAkA/AcEBQdwb29sQWRyAiZjYWxjdWxhdGVBbW91bnRPdXRGb3JTd2FwQW5kU2VuZFRva2VucwkAzAgCBQ1jbGVhbkFtb3VudEluCQDMCAIFCWlzUmV2ZXJzZQkAzAgCBQxhbW91bnRPdXRNaW4JAMwIAgUJYWRkcmVzc1RvBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFB2Fzc2V0SW4JAKADAQUOYW1vdW50SW5Ub1Bvb2wFA25pbAMJAAECBQFAAgdCb29sZWFuBQFACQACAQkArAICCQADAQUBQAIcIGNvdWxkbid0IGJlIGNhc3QgdG8gQm9vbGVhbgkAlAoCBQNuaWwFA3JlcwkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQpzZXRNYW5hZ2VyARdwZW5kaW5nTWFuYWdlclB1YmxpY0tleQQLY2hlY2tDYWxsZXIJAQttdXN0TWFuYWdlcgEFAWkDCQAAAgULY2hlY2tDYWxsZXIFC2NoZWNrQ2FsbGVyBBVjaGVja01hbmFnZXJQdWJsaWNLZXkJANkEAQUXcGVuZGluZ01hbmFnZXJQdWJsaWNLZXkDCQAAAgUVY2hlY2tNYW5hZ2VyUHVibGljS2V5BRVjaGVja01hbmFnZXJQdWJsaWNLZXkJAMwIAgkBC1N0cmluZ0VudHJ5AgkBGmtleVBlbmRpbmdNYW5hZ2VyUHVibGljS2V5AAUXcGVuZGluZ01hbmFnZXJQdWJsaWNLZXkFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQ5jb25maXJtTWFuYWdlcgAEAnBtCQEdcGVuZGluZ01hbmFnZXJQdWJsaWNLZXlPclVuaXQABAVoYXNQTQMJAQlpc0RlZmluZWQBBQJwbQYJAAIBAhJubyBwZW5kaW5nIG1hbmFnZXIDCQAAAgUFaGFzUE0FBWhhc1BNBAdjaGVja1BNAwkAAAIIBQFpD2NhbGxlclB1YmxpY0tleQkBBXZhbHVlAQUCcG0GCQACAQIbeW91IGFyZSBub3QgcGVuZGluZyBtYW5hZ2VyAwkAAAIFB2NoZWNrUE0FB2NoZWNrUE0JAMwIAgkBC1N0cmluZ0VudHJ5AgkBE2tleU1hbmFnZXJQdWJsaWNLZXkACQDYBAEJAQV2YWx1ZQEFAnBtCQDMCAIJAQtEZWxldGVFbnRyeQEJARprZXlQZW5kaW5nTWFuYWdlclB1YmxpY0tleQAFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgECdHgBBnZlcmlmeQAED3RhcmdldFB1YmxpY0tleQQHJG1hdGNoMAkBFm1hbmFnZXJQdWJsaWNLZXlPclVuaXQAAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAnBrBQckbWF0Y2gwBQJwawMJAAECBQckbWF0Y2gwAgRVbml0CAUCdHgPc2VuZGVyUHVibGljS2V5CQACAQILTWF0Y2ggZXJyb3IJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAFD3RhcmdldFB1YmxpY0tleQOdf8w=", "chainId": 84, "height": 2433347, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 3g5NcMPY9HAShJa14jcya7jbSGYd2nEV69qgeRrpajxG Next: DT2aCS1mTAmfrKMhapDJndivF5LgvTWKe8bajCt89yFm Diff:
OldNewDifferences
121121 if ((check == check))
122122 then {
123123 let poolAdr = addressFromStringValue(valueOrElse(pool, ""))
124- let res = {
125- let @ = invoke(poolAdr, "calculateAmountOutForSwapREADONLY", [cleanAmountIn, isReverse], nil)
126- if ($isInstanceOf(@, "Int"))
127- then @
128- else throw(($getType(@) + " couldn't be cast to Int"))
129- }
130- $Tuple2(nil, res)
124+ let check2 = if (false)
125+ then true
126+ else poolDisabled
127+ if ((check2 == check2))
128+ then {
129+ let res = {
130+ let @ = invoke(poolAdr, "calculateAmountOutForSwapREADONLY", [cleanAmountIn, isReverse], nil)
131+ if ($isInstanceOf(@, "Int"))
132+ then @
133+ else throw(($getType(@) + " couldn't be cast to Int"))
134+ }
135+ $Tuple2(nil, res)
136+ }
137+ else throw("Strict value is not equal to itself.")
131138 }
132139 else throw("Strict value is not equal to itself.")
133140 }
153160 then {
154161 let lpNonReverese = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetIn, assetOut], nil)
155162 let lpReverse = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetOut, assetIn], nil)
156- let $t045345024 = if ((lpNonReverese != unit))
163+ let $t045755065 = if ((lpNonReverese != unit))
157164 then {
158165 let isReverse = false
159166 let pool = {
171178 $Tuple2(isReverse, pool)
172179 }
173180 else poolNotExist
174- let isReverse = $t045345024._1
175- let pool = $t045345024._2
181+ let isReverse = $t045755065._1
182+ let pool = $t045755065._2
176183 let isPoolOneTokenOperationsDisabled = {
177184 let @ = invoke(factoryContract, "isPoolOneTokenOperationsDisabledREADONLY", [pool], nil)
178185 if ($isInstanceOf(@, "Boolean"))
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 feeLiquidityContractAddress () = makeString(["%s", "feeLiquidityContractAddress"], SEP)
2929
3030
3131 func feeLiquidity () = makeString(["%s", "feeLiquidity"], SEP)
3232
3333
3434 func protocolFee () = makeString(["%s", "protocolFee"], SEP)
3535
3636
3737 func asInt (val) = match val {
3838 case valInt: Int =>
3939 valInt
4040 case _ =>
4141 throw("fail to cast into Int")
4242 }
4343
4444
4545 func dataMappingPoolAssets (internalAmountAssetStr,internalPriceAssetStr) = makeString(["%d%d", toString(internalAmountAssetStr), toString(internalPriceAssetStr)], SEP)
4646
4747
4848 func managerPublicKeyOrUnit () = match getString(keyManagerPublicKey()) {
4949 case s: String =>
5050 fromBase58String(s)
5151 case _: Unit =>
5252 unit
5353 case _ =>
5454 throw("Match error")
5555 }
5656
5757
5858 func pendingManagerPublicKeyOrUnit () = match getString(keyPendingManagerPublicKey()) {
5959 case s: String =>
6060 fromBase58String(s)
6161 case _: Unit =>
6262 unit
6363 case _ =>
6464 throw("Match error")
6565 }
6666
6767
6868 func isManager (i) = match managerPublicKeyOrUnit() {
6969 case pk: ByteVector =>
7070 (i.callerPublicKey == pk)
7171 case _: Unit =>
7272 (i.caller == this)
7373 case _ =>
7474 throw("Match error")
7575 }
7676
7777
7878 func mustManager (i) = if (isManager(i))
7979 then true
8080 else throw("permission denied")
8181
8282
8383 func getAccBalance (assetId) = if ((assetId == "WAVES"))
8484 then wavesBalance(this).available
8585 else assetBalance(this, fromBase58String(assetId))
8686
8787
8888 @Callable(i)
8989 func swapCalculateREADONLY (amountIn,assetIn,assetOut) = {
9090 let prFee = value(getInteger(protocolFee()))
9191 let feeProtocolAmount = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
9292 let feeLiquidityAmount = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
9393 let amountInToPool = (toBigInt(amountIn) - feeProtocolAmount)
9494 let cleanAmountIn = (amountInToPool - feeLiquidityAmount)
9595 let lpNonReverese = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetIn, assetOut], nil)
9696 let lpReverse = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetOut, assetIn], nil)
9797 let $t026413114 = if ((lpNonReverese != unit))
9898 then {
9999 let isReverse = false
100100 let pool = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [lpNonReverese], nil)
101101 $Tuple2(isReverse, pool)
102102 }
103103 else if ((lpReverse != unit))
104104 then {
105105 let isReverse = true
106106 let pool = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [lpReverse], nil)
107107 $Tuple2(isReverse, pool)
108108 }
109109 else poolNotExist
110110 let isReverse = $t026413114._1
111111 let pool = $t026413114._2
112112 let isPoolOneTokenOperationsDisabled = {
113113 let @ = invoke(factoryContract, "isPoolOneTokenOperationsDisabledREADONLY", [pool], nil)
114114 if ($isInstanceOf(@, "Boolean"))
115115 then @
116116 else throw(($getType(@) + " couldn't be cast to Boolean"))
117117 }
118118 let check = if (isPoolOneTokenOperationsDisabled)
119119 then true
120120 else poolDisabled
121121 if ((check == check))
122122 then {
123123 let poolAdr = addressFromStringValue(valueOrElse(pool, ""))
124- let res = {
125- let @ = invoke(poolAdr, "calculateAmountOutForSwapREADONLY", [cleanAmountIn, isReverse], nil)
126- if ($isInstanceOf(@, "Int"))
127- then @
128- else throw(($getType(@) + " couldn't be cast to Int"))
129- }
130- $Tuple2(nil, res)
124+ let check2 = if (false)
125+ then true
126+ else poolDisabled
127+ if ((check2 == check2))
128+ then {
129+ let res = {
130+ let @ = invoke(poolAdr, "calculateAmountOutForSwapREADONLY", [cleanAmountIn, isReverse], nil)
131+ if ($isInstanceOf(@, "Int"))
132+ then @
133+ else throw(($getType(@) + " couldn't be cast to Int"))
134+ }
135+ $Tuple2(nil, res)
136+ }
137+ else throw("Strict value is not equal to itself.")
131138 }
132139 else throw("Strict value is not equal to itself.")
133140 }
134141
135142
136143
137144 @Callable(i)
138145 func swap (amountOutMin,assetOut,addressTo) = {
139146 let pmt = value(i.payments[0])
140147 let assetIn = if ((pmt.assetId == unit))
141148 then toBytes("WAVES")
142149 else value(pmt.assetId)
143150 let amountIn = value(pmt.amount)
144151 let prFee = value(getInteger(protocolFee()))
145152 let feeProtocolAmount = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
146153 let feeLiquidityAmount = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
147154 let amountInToPool = (toBigInt(amountIn) - feeProtocolAmount)
148155 let cleanAmountIn = (amountInToPool - feeLiquidityAmount)
149156 let checks = [if ((size(i.payments) == 1))
150157 then true
151158 else throw("exactly 1 payment are expected")]
152159 if ((checks == checks))
153160 then {
154161 let lpNonReverese = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetIn, assetOut], nil)
155162 let lpReverse = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetOut, assetIn], nil)
156- let $t045345024 = if ((lpNonReverese != unit))
163+ let $t045755065 = if ((lpNonReverese != unit))
157164 then {
158165 let isReverse = false
159166 let pool = {
160167 let @ = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [lpNonReverese], nil)
161168 if ($isInstanceOf(@, "Address"))
162169 then @
163170 else throw(($getType(@) + " couldn't be cast to Address"))
164171 }
165172 $Tuple2(isReverse, pool)
166173 }
167174 else if ((lpReverse != unit))
168175 then {
169176 let isReverse = true
170177 let pool = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [lpReverse], nil)
171178 $Tuple2(isReverse, pool)
172179 }
173180 else poolNotExist
174- let isReverse = $t045345024._1
175- let pool = $t045345024._2
181+ let isReverse = $t045755065._1
182+ let pool = $t045755065._2
176183 let isPoolOneTokenOperationsDisabled = {
177184 let @ = invoke(factoryContract, "isPoolOneTokenOperationsDisabledREADONLY", [pool], nil)
178185 if ($isInstanceOf(@, "Boolean"))
179186 then @
180187 else throw(($getType(@) + " couldn't be cast to Boolean"))
181188 }
182189 let check = if (isPoolOneTokenOperationsDisabled)
183190 then true
184191 else poolDisabled
185192 if ((check == check))
186193 then {
187194 let poolAdr = addressFromStringValue(valueOrElse(pool, ""))
188195 let res = {
189196 let @ = invoke(poolAdr, "calculateAmountOutForSwapAndSendTokens", [cleanAmountIn, isReverse, amountOutMin, addressTo], [AttachedPayment(assetIn, toInt(amountInToPool))])
190197 if ($isInstanceOf(@, "Boolean"))
191198 then @
192199 else throw(($getType(@) + " couldn't be cast to Boolean"))
193200 }
194201 $Tuple2(nil, res)
195202 }
196203 else throw("Strict value is not equal to itself.")
197204 }
198205 else throw("Strict value is not equal to itself.")
199206 }
200207
201208
202209
203210 @Callable(i)
204211 func setManager (pendingManagerPublicKey) = {
205212 let checkCaller = mustManager(i)
206213 if ((checkCaller == checkCaller))
207214 then {
208215 let checkManagerPublicKey = fromBase58String(pendingManagerPublicKey)
209216 if ((checkManagerPublicKey == checkManagerPublicKey))
210217 then [StringEntry(keyPendingManagerPublicKey(), pendingManagerPublicKey)]
211218 else throw("Strict value is not equal to itself.")
212219 }
213220 else throw("Strict value is not equal to itself.")
214221 }
215222
216223
217224
218225 @Callable(i)
219226 func confirmManager () = {
220227 let pm = pendingManagerPublicKeyOrUnit()
221228 let hasPM = if (isDefined(pm))
222229 then true
223230 else throw("no pending manager")
224231 if ((hasPM == hasPM))
225232 then {
226233 let checkPM = if ((i.callerPublicKey == value(pm)))
227234 then true
228235 else throw("you are not pending manager")
229236 if ((checkPM == checkPM))
230237 then [StringEntry(keyManagerPublicKey(), toBase58String(value(pm))), DeleteEntry(keyPendingManagerPublicKey())]
231238 else throw("Strict value is not equal to itself.")
232239 }
233240 else throw("Strict value is not equal to itself.")
234241 }
235242
236243
237244 @Verifier(tx)
238245 func verify () = {
239246 let targetPublicKey = match managerPublicKeyOrUnit() {
240247 case pk: ByteVector =>
241248 pk
242249 case _: Unit =>
243250 tx.senderPublicKey
244251 case _ =>
245252 throw("Match error")
246253 }
247254 sigVerify(tx.bodyBytes, tx.proofs[0], targetPublicKey)
248255 }
249256

github/deemru/w8io/3ef1775 
42.67 ms