tx · A7H6RqSs3FWyF4erSDHv8qyoE2kLqHs7ZLpxhZFrapMQ

3N6LHjfGb6Fgcy7YsVcNxGyPTj49XbQAijq:  -0.01300000 Waves

2023.01.31 17:33 [2429246] smart account 3N6LHjfGb6Fgcy7YsVcNxGyPTj49XbQAijq > SELF 0.00000000 Waves

{ "type": 13, "id": "A7H6RqSs3FWyF4erSDHv8qyoE2kLqHs7ZLpxhZFrapMQ", "fee": 1300000, "feeAssetId": null, "timestamp": 1675175669971, "version": 1, "sender": "3N6LHjfGb6Fgcy7YsVcNxGyPTj49XbQAijq", "senderPublicKey": "2u2wYYcVBQv43Cc71zkhHPPitkqgg6dqTZ3nUMvYJ1uq", "proofs": [ "28daFo7Yk7RHpCjxbdBk38yXGEa1c6X1oaPYv2TD7MGWtf9wuD7iGQ1RrbTAeapYfWUXtKaEd5RfiDmNMcA6AmWf" ], "script": "base64:BgIXCAISBQoDAQgIEgUKAwEICBIDCgEIEgAVAANTRVACAl9fAAhmZWVTY2FsZQkAtgIBAKCNBgEPZ2V0U3RyaW5nT3JGYWlsAQNrZXkJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQNrZXkJAKwCAgIVTm8gZGF0YSBmb3IgdGhpcy5rZXk9BQNrZXkADHBvb2xEaXNhYmxlZAkAAgECDVBvb2wgZGlzYWJsZWQADHBvb2xOb3RFeGlzdAkAAgECEVBvb2wgaXMgbm90IGV4aXN0AA5zbGlwcGFnZVRvb0JpZwkAAgECE1NsaXBwYWdlIGlzIHRvbyBiaWcACXRlc3RFcnJvcgkAAgECD1Rlc3QgZXJyb3IgaGVyZQETa2V5TWFuYWdlclB1YmxpY0tleQACFCVzX19tYW5hZ2VyUHVibGljS2V5ARprZXlQZW5kaW5nTWFuYWdlclB1YmxpY0tleQACGyVzX19wZW5kaW5nTWFuYWdlclB1YmxpY0tleQECZmMAAhMlc19fZmFjdG9yeUNvbnRyYWN0AA9mYWN0b3J5Q29udHJhY3QJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQ9nZXRTdHJpbmdPckZhaWwBCQECZmMAARtmZWVMaXF1aWRpdHlDb250cmFjdEFkZHJlc3MACQC5CQIJAMwIAgICJXMJAMwIAgIbZmVlTGlxdWlkaXR5Q29udHJhY3RBZGRyZXNzBQNuaWwFA1NFUAEMZmVlTGlxdWlkaXR5AAkAuQkCCQDMCAICAiVzCQDMCAICDGZlZUxpcXVpZGl0eQUDbmlsBQNTRVABC3Byb3RvY29sRmVlAAkAuQkCCQDMCAICAiVzCQDMCAICC3Byb3RvY29sRmVlBQNuaWwFA1NFUAEFYXNJbnQBA3ZhbAQHJG1hdGNoMAUDdmFsAwkAAQIFByRtYXRjaDACA0ludAQGdmFsSW50BQckbWF0Y2gwBQZ2YWxJbnQJAAIBAhVmYWlsIHRvIGNhc3QgaW50byBJbnQBFWRhdGFNYXBwaW5nUG9vbEFzc2V0cwIWaW50ZXJuYWxBbW91bnRBc3NldFN0chVpbnRlcm5hbFByaWNlQXNzZXRTdHIJALkJAgkAzAgCAgQlZCVkCQDMCAIJAKQDAQUWaW50ZXJuYWxBbW91bnRBc3NldFN0cgkAzAgCCQCkAwEFFWludGVybmFsUHJpY2VBc3NldFN0cgUDbmlsBQNTRVABFm1hbmFnZXJQdWJsaWNLZXlPclVuaXQABAckbWF0Y2gwCQCiCAEJARNrZXlNYW5hZ2VyUHVibGljS2V5AAMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXMFByRtYXRjaDAJANkEAQUBcwMJAAECBQckbWF0Y2gwAgRVbml0BQR1bml0CQACAQILTWF0Y2ggZXJyb3IBHXBlbmRpbmdNYW5hZ2VyUHVibGljS2V5T3JVbml0AAQHJG1hdGNoMAkAoggBCQEaa2V5UGVuZGluZ01hbmFnZXJQdWJsaWNLZXkAAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAkA2QQBBQFzAwkAAQIFByRtYXRjaDACBFVuaXQFBHVuaXQJAAIBAgtNYXRjaCBlcnJvcgEJaXNNYW5hZ2VyAQFpBAckbWF0Y2gwCQEWbWFuYWdlclB1YmxpY0tleU9yVW5pdAADCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQCcGsFByRtYXRjaDAJAAACCAUBaQ9jYWxsZXJQdWJsaWNLZXkFAnBrAwkAAQIFByRtYXRjaDACBFVuaXQJAAACCAUBaQZjYWxsZXIFBHRoaXMJAAIBAgtNYXRjaCBlcnJvcgELbXVzdE1hbmFnZXIBAWkDCQEJaXNNYW5hZ2VyAQUBaQYJAAIBAhFwZXJtaXNzaW9uIGRlbmllZAENZ2V0QWNjQmFsYW5jZQEHYXNzZXRJZAMJAAACBQdhc3NldElkAgVXQVZFUwgJAO8HAQUEdGhpcwlhdmFpbGFibGUJAPAHAgUEdGhpcwkA2QQBBQdhc3NldElkBAFpARVzd2FwQ2FsY3VsYXRlUkVBRE9OTFkDCGFtb3VudEluB2Fzc2V0SW4IYXNzZXRPdXQEBXByRmVlCQEFdmFsdWUBCQCfCAEJAQtwcm90b2NvbEZlZQAEEWZlZVByb3RvY29sQW1vdW50CQC8AgMJALYCAQUIYW1vdW50SW4JALYCAQUFcHJGZWUFCGZlZVNjYWxlBBJmZWVMaXF1aWRpdHlBbW91bnQJALwCAwkAtgIBBQhhbW91bnRJbgkAtgIBBQVwckZlZQUIZmVlU2NhbGUEDmFtb3VudEluVG9Qb29sCQC4AgIJALYCAQUIYW1vdW50SW4FEWZlZVByb3RvY29sQW1vdW50BA1jbGVhbkFtb3VudEluCQC4AgIFDmFtb3VudEluVG9Qb29sBRJmZWVMaXF1aWRpdHlBbW91bnQEDWxwTm9uUmV2ZXJlc2UJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AiBnZXRMcEFzc2V0RnJvbVBvb2xBc3NldHNSRUFET05MWQkAzAgCBQdhc3NldEluCQDMCAIFCGFzc2V0T3V0BQNuaWwFA25pbAQJbHBSZXZlcnNlCQD8BwQFD2ZhY3RvcnlDb250cmFjdAIgZ2V0THBBc3NldEZyb21Qb29sQXNzZXRzUkVBRE9OTFkJAMwIAgUIYXNzZXRPdXQJAMwIAgUHYXNzZXRJbgUDbmlsBQNuaWwEAmVlAwkAAAIAAAAABQl0ZXN0RXJyb3IFCXRlc3RFcnJvcgQLJHQwMjc1ODMyNDgDCQECIT0CBQ1scE5vblJldmVyZXNlBQR1bml0BAlpc1JldmVyc2UHBARwb29sCgABQAkA/AcEBQ9mYWN0b3J5Q29udHJhY3QCIWdldFBvb2xBZGRyZXNzRnJvbUxwQXNzZXRSRUFET05MWQkAzAgCBQ1scE5vblJldmVyZXNlBQNuaWwFA25pbAMJAAECBQFAAgdBZGRyZXNzBQFACQACAQkArAICCQADAQUBQAIcIGNvdWxkbid0IGJlIGNhc3QgdG8gQWRkcmVzcwkAlAoCBQlpc1JldmVyc2UFBHBvb2wDCQECIT0CBQlscFJldmVyc2UFBHVuaXQECWlzUmV2ZXJzZQYEBHBvb2wJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AiFnZXRQb29sQWRkcmVzc0Zyb21McEFzc2V0UkVBRE9OTFkJAMwIAgUJbHBSZXZlcnNlBQNuaWwFA25pbAkAlAoCBQlpc1JldmVyc2UFBHBvb2wFDHBvb2xOb3RFeGlzdAQJaXNSZXZlcnNlCAULJHQwMjc1ODMyNDgCXzEEBHBvb2wIBQskdDAyNzU4MzI0OAJfMgQgaXNQb29sT25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWQKAAFACQD8BwQFD2ZhY3RvcnlDb250cmFjdAIoaXNQb29sT25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWRSRUFET05MWQkAzAgCBQRwb29sBQNuaWwFA25pbAMJAAECBQFAAgdCb29sZWFuBQFACQACAQkArAICCQADAQUBQAIcIGNvdWxkbid0IGJlIGNhc3QgdG8gQm9vbGVhbgQFY2hlY2sDBSBpc1Bvb2xPbmVUb2tlbk9wZXJhdGlvbnNEaXNhYmxlZAYFDHBvb2xEaXNhYmxlZAMJAAACBQVjaGVjawUFY2hlY2sEB3Bvb2xBZHIJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQt2YWx1ZU9yRWxzZQIFBHBvb2wCAAQDcmVzCgABQAkA/AcEBQdwb29sQWRyAiFjYWxjdWxhdGVBbW91bnRPdXRGb3JTd2FwUkVBRE9OTFkJAMwIAgUNY2xlYW5BbW91bnRJbgkAzAgCBQlpc1JldmVyc2UFA25pbAUDbmlsAwkAAQIFAUACA0ludAUBQAkAAgEJAKwCAgkAAwEFAUACGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAkAlAoCBQNuaWwFA3JlcwkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQRzd2FwAwxhbW91bnRPdXRNaW4IYXNzZXRPdXQJYWRkcmVzc1RvBANwbXQJAQV2YWx1ZQEJAJEDAggFAWkIcGF5bWVudHMAAAQHYXNzZXRJbgMJAAACCAUDcG10B2Fzc2V0SWQFBHVuaXQJAJsDAQIFV0FWRVMJAQV2YWx1ZQEIBQNwbXQHYXNzZXRJZAQIYW1vdW50SW4JAQV2YWx1ZQEIBQNwbXQGYW1vdW50BAVwckZlZQkBBXZhbHVlAQkAnwgBCQELcHJvdG9jb2xGZWUABBFmZWVQcm90b2NvbEFtb3VudAkAvAIDCQC2AgEFCGFtb3VudEluCQC2AgEFBXByRmVlBQhmZWVTY2FsZQQSZmVlTGlxdWlkaXR5QW1vdW50CQC8AgMJALYCAQUIYW1vdW50SW4JALYCAQUFcHJGZWUFCGZlZVNjYWxlBA5hbW91bnRJblRvUG9vbAkAuAICCQC2AgEFCGFtb3VudEluBRFmZWVQcm90b2NvbEFtb3VudAQNY2xlYW5BbW91bnRJbgkAuAICBQ5hbW91bnRJblRvUG9vbAUSZmVlTGlxdWlkaXR5QW1vdW50BAZjaGVja3MJAMwIAgMJAAACCQCQAwEIBQFpCHBheW1lbnRzAAEGCQACAQIeZXhhY3RseSAxIHBheW1lbnQgYXJlIGV4cGVjdGVkBQNuaWwDCQAAAgUGY2hlY2tzBQZjaGVja3MEDWxwTm9uUmV2ZXJlc2UJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AiBnZXRMcEFzc2V0RnJvbVBvb2xBc3NldHNSRUFET05MWQkAzAgCBQdhc3NldEluCQDMCAIFCGFzc2V0T3V0BQNuaWwFA25pbAQJbHBSZXZlcnNlCQD8BwQFD2ZhY3RvcnlDb250cmFjdAIgZ2V0THBBc3NldEZyb21Qb29sQXNzZXRzUkVBRE9OTFkJAMwIAgUIYXNzZXRPdXQJAMwIAgUHYXNzZXRJbgUDbmlsBQNuaWwECyR0MDQ2Njg1MTU4AwkBAiE9AgUNbHBOb25SZXZlcmVzZQUEdW5pdAQJaXNSZXZlcnNlBwQEcG9vbAoAAUAJAPwHBAUPZmFjdG9yeUNvbnRyYWN0AiFnZXRQb29sQWRkcmVzc0Zyb21McEFzc2V0UkVBRE9OTFkJAMwIAgUNbHBOb25SZXZlcmVzZQUDbmlsBQNuaWwDCQABAgUBQAIHQWRkcmVzcwUBQAkAAgEJAKwCAgkAAwEFAUACHCBjb3VsZG4ndCBiZSBjYXN0IHRvIEFkZHJlc3MJAJQKAgUJaXNSZXZlcnNlBQRwb29sAwkBAiE9AgUJbHBSZXZlcnNlBQR1bml0BAlpc1JldmVyc2UGBARwb29sCQD8BwQFD2ZhY3RvcnlDb250cmFjdAIhZ2V0UG9vbEFkZHJlc3NGcm9tTHBBc3NldFJFQURPTkxZCQDMCAIFCWxwUmV2ZXJzZQUDbmlsBQNuaWwJAJQKAgUJaXNSZXZlcnNlBQRwb29sBQxwb29sTm90RXhpc3QECWlzUmV2ZXJzZQgFCyR0MDQ2Njg1MTU4Al8xBARwb29sCAULJHQwNDY2ODUxNTgCXzIEIGlzUG9vbE9uZVRva2VuT3BlcmF0aW9uc0Rpc2FibGVkCgABQAkA/AcEBQ9mYWN0b3J5Q29udHJhY3QCKGlzUG9vbE9uZVRva2VuT3BlcmF0aW9uc0Rpc2FibGVkUkVBRE9OTFkJAMwIAgUEcG9vbAUDbmlsBQNuaWwDCQABAgUBQAIHQm9vbGVhbgUBQAkAAgEJAKwCAgkAAwEFAUACHCBjb3VsZG4ndCBiZSBjYXN0IHRvIEJvb2xlYW4EBWNoZWNrAwUgaXNQb29sT25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWQGBQxwb29sRGlzYWJsZWQDCQAAAgUFY2hlY2sFBWNoZWNrBAdwb29sQWRyCQERQGV4dHJOYXRpdmUoMTA2MikBCQELdmFsdWVPckVsc2UCBQRwb29sAgAEA3JlcwoAAUAJAPwHBAUHcG9vbEFkcgImY2FsY3VsYXRlQW1vdW50T3V0Rm9yU3dhcEFuZFNlbmRUb2tlbnMJAMwIAgUNY2xlYW5BbW91bnRJbgkAzAgCBQlpc1JldmVyc2UJAMwIAgUMYW1vdW50T3V0TWluCQDMCAIFCWFkZHJlc3NUbwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQdhc3NldEluCQCgAwEFDmFtb3VudEluVG9Qb29sBQNuaWwDCQABAgUBQAIHQm9vbGVhbgUBQAkAAgEJAKwCAgkAAwEFAUACHCBjb3VsZG4ndCBiZSBjYXN0IHRvIEJvb2xlYW4JAJQKAgUDbmlsBQNyZXMJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEKc2V0TWFuYWdlcgEXcGVuZGluZ01hbmFnZXJQdWJsaWNLZXkEC2NoZWNrQ2FsbGVyCQELbXVzdE1hbmFnZXIBBQFpAwkAAAIFC2NoZWNrQ2FsbGVyBQtjaGVja0NhbGxlcgQVY2hlY2tNYW5hZ2VyUHVibGljS2V5CQDZBAEFF3BlbmRpbmdNYW5hZ2VyUHVibGljS2V5AwkAAAIFFWNoZWNrTWFuYWdlclB1YmxpY0tleQUVY2hlY2tNYW5hZ2VyUHVibGljS2V5CQDMCAIJAQtTdHJpbmdFbnRyeQIJARprZXlQZW5kaW5nTWFuYWdlclB1YmxpY0tleQAFF3BlbmRpbmdNYW5hZ2VyUHVibGljS2V5BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEOY29uZmlybU1hbmFnZXIABAJwbQkBHXBlbmRpbmdNYW5hZ2VyUHVibGljS2V5T3JVbml0AAQFaGFzUE0DCQEJaXNEZWZpbmVkAQUCcG0GCQACAQISbm8gcGVuZGluZyBtYW5hZ2VyAwkAAAIFBWhhc1BNBQVoYXNQTQQHY2hlY2tQTQMJAAACCAUBaQ9jYWxsZXJQdWJsaWNLZXkJAQV2YWx1ZQEFAnBtBgkAAgECG3lvdSBhcmUgbm90IHBlbmRpbmcgbWFuYWdlcgMJAAACBQdjaGVja1BNBQdjaGVja1BNCQDMCAIJAQtTdHJpbmdFbnRyeQIJARNrZXlNYW5hZ2VyUHVibGljS2V5AAkA2AQBCQEFdmFsdWUBBQJwbQkAzAgCCQELRGVsZXRlRW50cnkBCQEaa2V5UGVuZGluZ01hbmFnZXJQdWJsaWNLZXkABQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAnR4AQZ2ZXJpZnkABA90YXJnZXRQdWJsaWNLZXkEByRtYXRjaDAJARZtYW5hZ2VyUHVibGljS2V5T3JVbml0AAMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAJwawUHJG1hdGNoMAUCcGsDCQABAgUHJG1hdGNoMAIEVW5pdAgFAnR4D3NlbmRlclB1YmxpY0tleQkAAgECC01hdGNoIGVycm9yCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQ90YXJnZXRQdWJsaWNLZXnQwURg", "chainId": 84, "height": 2429246, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 4LDgK1DQT1SAcPwQ1cis7UAysoZz2dFoN5vPHTU98Nek Next: 3AkwLU2kJEjw6Vu2cSbMikZqmHjAVdYKR9Kdh7PSHp4W Diff:
OldNewDifferences
1313 let poolNotExist = throw("Pool is not exist")
1414
1515 let slippageTooBig = throw("Slippage is too big")
16+
17+let testError = throw("Test error here")
1618
1719 func keyManagerPublicKey () = "%s__managerPublicKey"
1820
9496 let cleanAmountIn = (amountInToPool - feeLiquidityAmount)
9597 let lpNonReverese = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetIn, assetOut], nil)
9698 let lpReverse = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetOut, assetIn], nil)
97- let $t026393129 = if ((lpNonReverese != unit))
99+ let ee = if ((0 == 0))
100+ then testError
101+ else testError
102+ let $t027583248 = if ((lpNonReverese != unit))
98103 then {
99104 let isReverse = false
100105 let pool = {
112117 $Tuple2(isReverse, pool)
113118 }
114119 else poolNotExist
115- let isReverse = $t026393129._1
116- let pool = $t026393129._2
120+ let isReverse = $t027583248._1
121+ let pool = $t027583248._2
117122 let isPoolOneTokenOperationsDisabled = {
118123 let @ = invoke(factoryContract, "isPoolOneTokenOperationsDisabledREADONLY", [pool], nil)
119124 if ($isInstanceOf(@, "Boolean"))
158163 then {
159164 let lpNonReverese = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetIn, assetOut], nil)
160165 let lpReverse = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetOut, assetIn], nil)
161- let $t045495039 = if ((lpNonReverese != unit))
166+ let $t046685158 = if ((lpNonReverese != unit))
162167 then {
163168 let isReverse = false
164169 let pool = {
176181 $Tuple2(isReverse, pool)
177182 }
178183 else poolNotExist
179- let isReverse = $t045495039._1
180- let pool = $t045495039._2
184+ let isReverse = $t046685158._1
185+ let pool = $t046685158._2
181186 let isPoolOneTokenOperationsDisabled = {
182187 let @ = invoke(factoryContract, "isPoolOneTokenOperationsDisabledREADONLY", [pool], nil)
183188 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")
16+
17+let testError = throw("Test error here")
1618
1719 func keyManagerPublicKey () = "%s__managerPublicKey"
1820
1921
2022 func keyPendingManagerPublicKey () = "%s__pendingManagerPublicKey"
2123
2224
2325 func fc () = "%s__factoryContract"
2426
2527
2628 let factoryContract = addressFromStringValue(getStringOrFail(fc()))
2729
2830 func feeLiquidityContractAddress () = makeString(["%s", "feeLiquidityContractAddress"], SEP)
2931
3032
3133 func feeLiquidity () = makeString(["%s", "feeLiquidity"], SEP)
3234
3335
3436 func protocolFee () = makeString(["%s", "protocolFee"], SEP)
3537
3638
3739 func asInt (val) = match val {
3840 case valInt: Int =>
3941 valInt
4042 case _ =>
4143 throw("fail to cast into Int")
4244 }
4345
4446
4547 func dataMappingPoolAssets (internalAmountAssetStr,internalPriceAssetStr) = makeString(["%d%d", toString(internalAmountAssetStr), toString(internalPriceAssetStr)], SEP)
4648
4749
4850 func managerPublicKeyOrUnit () = match getString(keyManagerPublicKey()) {
4951 case s: String =>
5052 fromBase58String(s)
5153 case _: Unit =>
5254 unit
5355 case _ =>
5456 throw("Match error")
5557 }
5658
5759
5860 func pendingManagerPublicKeyOrUnit () = match getString(keyPendingManagerPublicKey()) {
5961 case s: String =>
6062 fromBase58String(s)
6163 case _: Unit =>
6264 unit
6365 case _ =>
6466 throw("Match error")
6567 }
6668
6769
6870 func isManager (i) = match managerPublicKeyOrUnit() {
6971 case pk: ByteVector =>
7072 (i.callerPublicKey == pk)
7173 case _: Unit =>
7274 (i.caller == this)
7375 case _ =>
7476 throw("Match error")
7577 }
7678
7779
7880 func mustManager (i) = if (isManager(i))
7981 then true
8082 else throw("permission denied")
8183
8284
8385 func getAccBalance (assetId) = if ((assetId == "WAVES"))
8486 then wavesBalance(this).available
8587 else assetBalance(this, fromBase58String(assetId))
8688
8789
8890 @Callable(i)
8991 func swapCalculateREADONLY (amountIn,assetIn,assetOut) = {
9092 let prFee = value(getInteger(protocolFee()))
9193 let feeProtocolAmount = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
9294 let feeLiquidityAmount = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
9395 let amountInToPool = (toBigInt(amountIn) - feeProtocolAmount)
9496 let cleanAmountIn = (amountInToPool - feeLiquidityAmount)
9597 let lpNonReverese = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetIn, assetOut], nil)
9698 let lpReverse = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetOut, assetIn], nil)
97- let $t026393129 = if ((lpNonReverese != unit))
99+ let ee = if ((0 == 0))
100+ then testError
101+ else testError
102+ let $t027583248 = if ((lpNonReverese != unit))
98103 then {
99104 let isReverse = false
100105 let pool = {
101106 let @ = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [lpNonReverese], nil)
102107 if ($isInstanceOf(@, "Address"))
103108 then @
104109 else throw(($getType(@) + " couldn't be cast to Address"))
105110 }
106111 $Tuple2(isReverse, pool)
107112 }
108113 else if ((lpReverse != unit))
109114 then {
110115 let isReverse = true
111116 let pool = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [lpReverse], nil)
112117 $Tuple2(isReverse, pool)
113118 }
114119 else poolNotExist
115- let isReverse = $t026393129._1
116- let pool = $t026393129._2
120+ let isReverse = $t027583248._1
121+ let pool = $t027583248._2
117122 let isPoolOneTokenOperationsDisabled = {
118123 let @ = invoke(factoryContract, "isPoolOneTokenOperationsDisabledREADONLY", [pool], nil)
119124 if ($isInstanceOf(@, "Boolean"))
120125 then @
121126 else throw(($getType(@) + " couldn't be cast to Boolean"))
122127 }
123128 let check = if (isPoolOneTokenOperationsDisabled)
124129 then true
125130 else poolDisabled
126131 if ((check == check))
127132 then {
128133 let poolAdr = addressFromStringValue(valueOrElse(pool, ""))
129134 let res = {
130135 let @ = invoke(poolAdr, "calculateAmountOutForSwapREADONLY", [cleanAmountIn, isReverse], nil)
131136 if ($isInstanceOf(@, "Int"))
132137 then @
133138 else throw(($getType(@) + " couldn't be cast to Int"))
134139 }
135140 $Tuple2(nil, res)
136141 }
137142 else throw("Strict value is not equal to itself.")
138143 }
139144
140145
141146
142147 @Callable(i)
143148 func swap (amountOutMin,assetOut,addressTo) = {
144149 let pmt = value(i.payments[0])
145150 let assetIn = if ((pmt.assetId == unit))
146151 then toBytes("WAVES")
147152 else value(pmt.assetId)
148153 let amountIn = value(pmt.amount)
149154 let prFee = value(getInteger(protocolFee()))
150155 let feeProtocolAmount = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
151156 let feeLiquidityAmount = fraction(toBigInt(amountIn), toBigInt(prFee), feeScale)
152157 let amountInToPool = (toBigInt(amountIn) - feeProtocolAmount)
153158 let cleanAmountIn = (amountInToPool - feeLiquidityAmount)
154159 let checks = [if ((size(i.payments) == 1))
155160 then true
156161 else throw("exactly 1 payment are expected")]
157162 if ((checks == checks))
158163 then {
159164 let lpNonReverese = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetIn, assetOut], nil)
160165 let lpReverse = invoke(factoryContract, "getLpAssetFromPoolAssetsREADONLY", [assetOut, assetIn], nil)
161- let $t045495039 = if ((lpNonReverese != unit))
166+ let $t046685158 = if ((lpNonReverese != unit))
162167 then {
163168 let isReverse = false
164169 let pool = {
165170 let @ = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [lpNonReverese], nil)
166171 if ($isInstanceOf(@, "Address"))
167172 then @
168173 else throw(($getType(@) + " couldn't be cast to Address"))
169174 }
170175 $Tuple2(isReverse, pool)
171176 }
172177 else if ((lpReverse != unit))
173178 then {
174179 let isReverse = true
175180 let pool = invoke(factoryContract, "getPoolAddressFromLpAssetREADONLY", [lpReverse], nil)
176181 $Tuple2(isReverse, pool)
177182 }
178183 else poolNotExist
179- let isReverse = $t045495039._1
180- let pool = $t045495039._2
184+ let isReverse = $t046685158._1
185+ let pool = $t046685158._2
181186 let isPoolOneTokenOperationsDisabled = {
182187 let @ = invoke(factoryContract, "isPoolOneTokenOperationsDisabledREADONLY", [pool], nil)
183188 if ($isInstanceOf(@, "Boolean"))
184189 then @
185190 else throw(($getType(@) + " couldn't be cast to Boolean"))
186191 }
187192 let check = if (isPoolOneTokenOperationsDisabled)
188193 then true
189194 else poolDisabled
190195 if ((check == check))
191196 then {
192197 let poolAdr = addressFromStringValue(valueOrElse(pool, ""))
193198 let res = {
194199 let @ = invoke(poolAdr, "calculateAmountOutForSwapAndSendTokens", [cleanAmountIn, isReverse, amountOutMin, addressTo], [AttachedPayment(assetIn, toInt(amountInToPool))])
195200 if ($isInstanceOf(@, "Boolean"))
196201 then @
197202 else throw(($getType(@) + " couldn't be cast to Boolean"))
198203 }
199204 $Tuple2(nil, res)
200205 }
201206 else throw("Strict value is not equal to itself.")
202207 }
203208 else throw("Strict value is not equal to itself.")
204209 }
205210
206211
207212
208213 @Callable(i)
209214 func setManager (pendingManagerPublicKey) = {
210215 let checkCaller = mustManager(i)
211216 if ((checkCaller == checkCaller))
212217 then {
213218 let checkManagerPublicKey = fromBase58String(pendingManagerPublicKey)
214219 if ((checkManagerPublicKey == checkManagerPublicKey))
215220 then [StringEntry(keyPendingManagerPublicKey(), pendingManagerPublicKey)]
216221 else throw("Strict value is not equal to itself.")
217222 }
218223 else throw("Strict value is not equal to itself.")
219224 }
220225
221226
222227
223228 @Callable(i)
224229 func confirmManager () = {
225230 let pm = pendingManagerPublicKeyOrUnit()
226231 let hasPM = if (isDefined(pm))
227232 then true
228233 else throw("no pending manager")
229234 if ((hasPM == hasPM))
230235 then {
231236 let checkPM = if ((i.callerPublicKey == value(pm)))
232237 then true
233238 else throw("you are not pending manager")
234239 if ((checkPM == checkPM))
235240 then [StringEntry(keyManagerPublicKey(), toBase58String(value(pm))), DeleteEntry(keyPendingManagerPublicKey())]
236241 else throw("Strict value is not equal to itself.")
237242 }
238243 else throw("Strict value is not equal to itself.")
239244 }
240245
241246
242247 @Verifier(tx)
243248 func verify () = {
244249 let targetPublicKey = match managerPublicKeyOrUnit() {
245250 case pk: ByteVector =>
246251 pk
247252 case _: Unit =>
248253 tx.senderPublicKey
249254 case _ =>
250255 throw("Match error")
251256 }
252257 sigVerify(tx.bodyBytes, tx.proofs[0], targetPublicKey)
253258 }
254259

github/deemru/w8io/3ef1775 
48.99 ms