tx · EUVo8k9EQrbzF22FqGngLPXDXhqEffZU92rX9pjgTR3Z

3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS:  -0.01100000 Waves

2023.03.24 21:05 [2504434] smart account 3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS > SELF 0.00000000 Waves

{ "type": 13, "id": "EUVo8k9EQrbzF22FqGngLPXDXhqEffZU92rX9pjgTR3Z", "fee": 1100000, "feeAssetId": null, "timestamp": 1679681158403, "version": 2, "chainId": 84, "sender": "3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS", "senderPublicKey": "HP8sssVq1866F7CaPQJwgFrt6fsqhQjKwM84cL1wjD2a", "proofs": [ "2Jrxutx5Djpy3WFacmwWVUBZpa2NctNpuz8Juu8D1NRzzamoVku3xmKkSfud1T7NyPebng1SjBjVcaAHET7kbh8B" ], "script": "base64:BgIeCAISBwoFCAEIAQESAwoBCBIDCgEIEgcKBQgIAQEBJgALU0ZfUE9TX1RZUEUCAlNGAAtXWF9QT1NfVFlQRQICV1gABlNDQUxFOACAwtcvAApGRUVfU0NBTEU2AMCEPQAUa1NGUG9vbEFBc3NldEJhbGFuY2UCD0FfYXNzZXRfYmFsYW5jZQAUa1NGUG9vbEJBc3NldEJhbGFuY2UCD0JfYXNzZXRfYmFsYW5jZQAPa1NGUG9vbEFBc3NldElkAgpBX2Fzc2V0X2lkAA9rU0ZQb29sQkFzc2V0SWQCCkJfYXNzZXRfaWQADmtTRlBvb2xTaGFyZUlkAg5zaGFyZV9hc3NldF9pZAAOa1NGUG9vbFZlcnNpb24CB3ZlcnNpb24AEGtTRkZhcm1pbmdTdGFrZWQCFF9zaGFyZV90b2tlbnNfbG9ja2VkAA1rVXNlclBvc2l0aW9uAg5fdXNlcl9wb3NpdGlvbgARa1VzZXJQb3NpdGlvblR5cGUCE191c2VyX3Bvc2l0aW9uX3R5cGUAEGtVc2VyUG9zaXRpb25OdW0CFV91c2VyX3Bvc2l0aW9uX251bWJlcgAOa1RvdGFsUG9zaXRpb24CD190b3RhbF9wb3NpdGlvbgAVa0F4bHlJbkZlZVdpdGhvdXRMb2FuAhZfYXhseV9mZWVfd2l0aG91dF9sb2FuABJrQXhseUluRmVlV2l0aExvYW4CE19heGx5X2ZlZV93aXRoX2xvYW4AC2tBeGx5Q2FwRmVlAg1fYXhseV9mZWVfY2FwAAprUmVxdWVzdElkAgtfcmVxdWVzdF9pZAAMa1JlcXVlc3RJdGVyAg1yZXF1ZXN0c19pdGVyAAVrUG9vbAIFcG9vbF8ACWtNb25leUJveAIOYXhseV9tb25leV9ib3gADmtTRkZhcm1pbmdBZGRyAhNzd29wZmlfZmFybWluZ19hZGRyAAxrTGVuZFNlcnZpY2UCEWxlbmRfc2VydmljZV9hZGRyAAhtb25leUJveAkBB0FkZHJlc3MBCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQlrTW9uZXlCb3gCGE5vIGF4bHkgbW9uZXlCb3ggYWRkcmVzcwEKaXNTZWxmQ2FsbAEBaQMJAAACCAUBaQZjYWxsZXIFBHRoaXMFBHVuaXQJAAIBAitPbmx5IGNvbnRyYWN0IGl0c2VsZiBjYW4gY2FsbCB0aGlzIGZ1bmN0aW9uAQ5hY2NvdW50QmFsYW5jZQEHYXNzZXRJZAQHJG1hdGNoMAUHYXNzZXRJZAMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAJpZAUHJG1hdGNoMAkA8AcCBQR0aGlzBQJpZAMJAAECBQckbWF0Y2gwAgRVbml0BAV3YXZlcwUHJG1hdGNoMAgJAO8HAQUEdGhpcwlhdmFpbGFibGUJAAIBAgtNYXRjaCBlcnJvcgENZ2V0U0ZQb29sRGF0YQEIcG9vbEFkZHIJAJcKBQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFCHBvb2xBZGRyBQ9rU0ZQb29sQUFzc2V0SWQCGUNhbid0IGdldCBwb29sIEEgYXNzZXQgaWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQhwb29sQWRkcgUPa1NGUG9vbEJBc3NldElkAhlDYW4ndCBnZXQgcG9vbCBCIGFzc2V0IGlkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUIcG9vbEFkZHIFFGtTRlBvb2xBQXNzZXRCYWxhbmNlAh5DYW4ndCBnZXQgcG9vbCBBIGFzc2V0IGJhbGFuY2UJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQhwb29sQWRkcgUUa1NGUG9vbEJBc3NldEJhbGFuY2UCHkNhbid0IGdldCBwb29sIEIgYXNzZXQgYmFsYW5jZQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFCHBvb2xBZGRyBQ5rU0ZQb29sU2hhcmVJZAIYQ2FuJ3QgZ2V0IHNoYXJlIGFzc2V0IGlkAQ1nZXRXWFBvb2xEYXRhAQhwb29sQWRkcgkAlwoFCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUIcG9vbEFkZHIFD2tTRlBvb2xBQXNzZXRJZAIZQ2FuJ3QgZ2V0IHBvb2wgQSBhc3NldCBpZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFCHBvb2xBZGRyBQ9rU0ZQb29sQkFzc2V0SWQCGUNhbid0IGdldCBwb29sIEIgYXNzZXQgaWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQhwb29sQWRkcgUUa1NGUG9vbEFBc3NldEJhbGFuY2UCHkNhbid0IGdldCBwb29sIEEgYXNzZXQgYmFsYW5jZQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFCHBvb2xBZGRyBRRrU0ZQb29sQkFzc2V0QmFsYW5jZQIeQ2FuJ3QgZ2V0IHBvb2wgQiBhc3NldCBiYWxhbmNlCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUIcG9vbEFkZHIFDmtTRlBvb2xTaGFyZUlkAhhDYW4ndCBnZXQgc2hhcmUgYXNzZXQgaWQBFGdldEF4bHlUb3RhbFBvc2l0aW9uAQRwb29sCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgUEcG9vbAUOa1RvdGFsUG9zaXRpb24AAAEYZ2V0TmV3VXNlclBvc2l0aW9uTnVtYmVyAgRwb29sBHVzZXIJAGQCCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXIFEGtVc2VyUG9zaXRpb25OdW0AAAABAQxnZXRBeGx5SW5GZWUCBHBvb2wId2l0aExvYW4DBQh3aXRoTG9hbgkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkArAICBQRwb29sBRJrQXhseUluRmVlV2l0aExvYW4JARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAUVa0F4bHlJbkZlZVdpdGhvdXRMb2FuARBnZXRTRkZhcm1pbmdBZGRyAAkBB0FkZHJlc3MBCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQ5rU0ZGYXJtaW5nQWRkcgIdQ2FuJ3QgZ2V0IHN3b3BmaSBmYXJtaW5nIGFkZHIBDmdldExlbmRTcnZBZGRyAAkBB0FkZHJlc3MBCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQxrTGVuZFNlcnZpY2UCG0Nhbid0IGdldCBsZW5kIHNlcnZpY2UgYWRkcgEMYXNzZXRJZFRvU3RyAQdhc3NldElkBAckbWF0Y2gwBQdhc3NldElkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAmlkBQckbWF0Y2gwCQDYBAEFAmlkAwkAAQIFByRtYXRjaDACBFVuaXQEBXdhdmVzBQckbWF0Y2gwAgVXQVZFUwkAAgECC01hdGNoIGVycm9yAQ5hc3NldElkRnJvbVN0cgEHYXNzZXRJZAMJAAACBQdhc3NldElkAgVXQVZFUwUEdW5pdAkA2QQBBQdhc3NldElkAQ9yZXBsYW5pc2hTd29wRmkMBHVzZXIEcG9vbAh3aXRoTG9hbgRwbXRBCXBtdEFzc2V0QQRwbXRCCXBtdEFzc2V0QgRiYWxBBGJhbEIHc2hhcmVJZBN2aXJ0dWFsU3dhcFRva2VuUGF5E3ZpcnR1YWxTd2FwVG9rZW5HZXQEEnNoYXJlQmFsYW5jZUJlZm9yZQkBDmFjY291bnRCYWxhbmNlAQkA2QQBBQdzaGFyZUlkBAhwb29sQWRkcgkBB0FkZHJlc3MBCQDZBAEFBHBvb2wEBnJhdGlvQQkAawMFBlNDQUxFOAUEcG10QQUEYmFsQQQGcmF0aW9CCQBrAwUGU0NBTEU4BQRwbXRCBQRiYWxCBAskdDA0NTQ0NDgzNwMJAGYCBQZyYXRpb0IFBnJhdGlvQQQDcG10CQBuBAUEYmFsQgUGcmF0aW9BBQZTQ0FMRTgFB0NFSUxJTkcJAJYKBAUEcG10QQUDcG10CQBlAgUEcG10QgUDcG10BQlwbXRBc3NldEIEA3BtdAkAbgQFBGJhbEEFBnJhdGlvQgUGU0NBTEU4BQdDRUlMSU5HCQCWCgQFA3BtdAUEcG10QgkAZQIFBHBtdEEFA3BtdAUJcG10QXNzZXRBBApwbXRBbW91bnRBCAULJHQwNDU0NDQ4MzcCXzEECnBtdEFtb3VudEIIBQskdDA0NTQ0NDgzNwJfMgQGY2hhbmdlCAULJHQwNDU0NDQ4MzcCXzMEDWNoYW5nZUFzc2V0SWQIBQskdDA0NTQ0NDgzNwJfNAQLcG9vbFZlcnNpb24JARFAZXh0ck5hdGl2ZSgxMDUzKQIFCHBvb2xBZGRyAgd2ZXJzaW9uBARpbnYxAwMJAGYCBQpwbXRBbW91bnRBAAAJAGYCBQpwbXRBbW91bnRCAAAHBAhwYXltZW50cwkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBDmFzc2V0SWRGcm9tU3RyAQUJcG10QXNzZXRBBQpwbXRBbW91bnRBCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQEOYXNzZXRJZEZyb21TdHIBBQlwbXRBc3NldEIFCnBtdEFtb3VudEIFA25pbAMJAAACBQtwb29sVmVyc2lvbgIFMS4wLjAJAPwHBAUIcG9vbEFkZHICDGNhbGxGdW5jdGlvbgkAzAgCAhZyZXBsZW5pc2hXaXRoVHdvVG9rZW5zCQDMCAIJAMwIAgIFZmFsc2UJAMwIAgIBMAUDbmlsBQNuaWwFCHBheW1lbnRzAwkAAAIFC3Bvb2xWZXJzaW9uAgUyLjAuMAkA/AcEBQhwb29sQWRkcgIYcmVwbGVuaXNoV2l0aFR3b1Rva2Vuc1YyCQDMCAIHCQDMCAIAAAUDbmlsBQhwYXltZW50cwkAAgECD1dyb25nIHBvb2wgdHlwZQAAAwkAAAIFBGludjEFBGludjEEBGludjIDCQBmAgUGY2hhbmdlAAAECHBheW1lbnRzCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQEOYXNzZXRJZEZyb21TdHIBBQ1jaGFuZ2VBc3NldElkBQZjaGFuZ2UFA25pbAMJAAACBQtwb29sVmVyc2lvbgIFMS4wLjAEBHZhcnMJAMwIAgkApAMBBRN2aXJ0dWFsU3dhcFRva2VuUGF5CQDMCAIJAKQDAQUTdmlydHVhbFN3YXBUb2tlbkdldAkAzAgCAgVmYWxzZQkAzAgCAgEwBQNuaWwJAPwHBAUIcG9vbEFkZHICDGNhbGxGdW5jdGlvbgkAzAgCAhVyZXBsZW5pc2hXaXRoT25lVG9rZW4JAMwIAgUEdmFycwUDbmlsBQhwYXltZW50cwMJAAACBQtwb29sVmVyc2lvbgIFMi4wLjAEBHZhcnMJAMwIAgUTdmlydHVhbFN3YXBUb2tlblBheQkAzAgCBRN2aXJ0dWFsU3dhcFRva2VuR2V0CQDMCAIHCQDMCAIAAAUDbmlsCQD8BwQFCHBvb2xBZGRyAhdyZXBsZW5pc2hXaXRoT25lVG9rZW5WMgkAzAgCBwkAzAgCAAAFA25pbAUIcGF5bWVudHMJAAIBAg9Xcm9uZyBwb29sIHR5cGUAAAMJAAACBQRpbnYyBQRpbnYyBBFzaGFyZUJhbGFuY2VBZnRlcgkBDmFjY291bnRCYWxhbmNlAQkA2QQBBQdzaGFyZUlkBAp0b3RhbFNoYXJlCQBlAgURc2hhcmVCYWxhbmNlQWZ0ZXIFEnNoYXJlQmFsYW5jZUJlZm9yZQQJYXhseUluRmVlCQBrAwUKdG90YWxTaGFyZQkAZQIFCkZFRV9TQ0FMRTYJAQxnZXRBeGx5SW5GZWUCBQRwb29sBQh3aXRoTG9hbgUKRkVFX1NDQUxFNgQRdXNlclNoYXJlRm9yU3Rha2UJAGUCBQp0b3RhbFNoYXJlBQlheGx5SW5GZWUDCQBnAgAABRF1c2VyU2hhcmVGb3JTdGFrZQkAAgECKGFtb3VudCBvZiBzdGFrZWQgc2hhcmV0b2tlbnMgbXVzdCBiZSA+IDAEBGludjMJAPwHBAkBEGdldFNGRmFybWluZ0FkZHIAAg9sb2NrU2hhcmVUb2tlbnMJAMwIAgUEcG9vbAkAzAgCAAAFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkA2QQBBQdzaGFyZUlkBRF1c2VyU2hhcmVGb3JTdGFrZQUDbmlsAwkAAAIFBGludjMFBGludjMEC3RvdGFsQW1vdW50CQEUZ2V0QXhseVRvdGFsUG9zaXRpb24BBQRwb29sBAluZXdQb3NOdW0JARhnZXROZXdVc2VyUG9zaXRpb25OdW1iZXICBQRwb29sBQR1c2VyCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHBvb2wFDmtUb3RhbFBvc2l0aW9uCQBkAgULdG90YWxBbW91bnQFEXVzZXJTaGFyZUZvclN0YWtlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwkApAMBBQluZXdQb3NOdW0FDWtVc2VyUG9zaXRpb24FEXVzZXJTaGFyZUZvclN0YWtlCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfCQCkAwEFCW5ld1Bvc051bQURa1VzZXJQb3NpdGlvblR5cGUFC1NGX1BPU19UWVBFCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyBRBrVXNlclBvc2l0aW9uTnVtBQluZXdQb3NOdW0JAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUIbW9uZXlCb3gFCWF4bHlJbkZlZQkA2QQBBQdzaGFyZUlkBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BC3JlcGxhbmlzaFdYDAR1c2VyBHBvb2wId2l0aExvYW4EcG10QQlwbXRBc3NldEEEcG10QglwbXRBc3NldEIEYmFsQQRiYWxCB3NoYXJlSWQTdmlydHVhbFN3YXBUb2tlblBheRN2aXJ0dWFsU3dhcFRva2VuR2V0BQNuaWwEAWkBCXJlcGxhbmlzaAUEcG9vbAxib3Jyb3dBbW91bnQNYm9ycm93QXNzZXRJZBN2aXJ0dWFsU3dhcFRva2VuUGF5E3ZpcnR1YWxTd2FwVG9rZW5HZXQEBHR5cGUJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzCQCsAgIFBWtQb29sBQRwb29sAhJQb29sIGlzIG5vdCBpbml0ZWQECyR0MDc2NTM3OTA0AwkAAAIFBHR5cGUFC1NGX1BPU19UWVBFCQENZ2V0U0ZQb29sRGF0YQEJAQdBZGRyZXNzAQkA2QQBBQRwb29sAwkAAAIFBHR5cGUFC1dYX1BPU19UWVBFCQENZ2V0V1hQb29sRGF0YQEJAQdBZGRyZXNzAQkA2QQBBQRwb29sCQACAQIPV3JvbmcgcG9vbCB0eXBlBANBSWQIBQskdDA3NjUzNzkwNAJfMQQDQklkCAULJHQwNzY1Mzc5MDQCXzIEBGJhbEEIBQskdDA3NjUzNzkwNAJfMwQEYmFsQggFCyR0MDc2NTM3OTA0Al80BAdzaGFyZUlkCAULJHQwNzY1Mzc5MDQCXzUECyR0MDc5MDg4NTQ1AwkAAAIJAJADAQgFAWkIcGF5bWVudHMAAgMJAQIhPQIJAQxhc3NldElkVG9TdHIBCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQFA0FJZAkAAgECFVdyb25nIHBheW1lbnQgYXNzZXQgQQMJAQIhPQIJAQxhc3NldElkVG9TdHIBCAkAkQMCCAUBaQhwYXltZW50cwABB2Fzc2V0SWQFA0JJZAkAAgECFVdyb25nIHBheW1lbnQgYXNzZXQgQgkAlgoECAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAUDQUlkCAkAkQMCCAUBaQhwYXltZW50cwABBmFtb3VudAUDQklkAwkAAAIJAJADAQgFAWkIcGF5bWVudHMAAQMJAAACCQEMYXNzZXRJZFRvU3RyAQgJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBQNBSWQJAJYKBAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQFA0FJZAAABQNCSWQDCQAAAgkBDGFzc2V0SWRUb1N0cgEICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAUDQklkCQCWCgQAAAUDQUlkCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAUDQklkCQACAQINV3JvbmcgcGF5bWVudAkAAgECHE9uZSBvciB0d28gcGF5bWVudHMgZXhwZWN0ZWQEBHBtdEEIBQskdDA3OTA4ODU0NQJfMQQJcG10QXNzZXRBCAULJHQwNzkwODg1NDUCXzIEBHBtdEIIBQskdDA3OTA4ODU0NQJfMwQJcG10QXNzZXRCCAULJHQwNzkwODg1NDUCXzQDCQBmAgUMYm9ycm93QW1vdW50AAAEB3JlcXVlc3QJALkJAgkAzAgCBQR0eXBlCQDMCAIJAKUIAQgFAWkGY2FsbGVyCQDMCAIFBHBvb2wJAMwIAgkApAMBBQRwbXRBCQDMCAIFCXBtdEFzc2V0QQkAzAgCCQCkAwEFBHBtdEIJAMwIAgUJcG10QXNzZXRCCQDMCAIJAKQDAQUEYmFsQQkAzAgCCQCkAwEFBGJhbEIJAMwIAgUHc2hhcmVJZAkAzAgCCQCkAwEFE3ZpcnR1YWxTd2FwVG9rZW5QYXkJAMwIAgkApAMBBRN2aXJ0dWFsU3dhcFRva2VuR2V0BQNuaWwCASwEDG5ld1JlcXVlc3RJZAoAAUAJAPwHBAUEdGhpcwIQY3JlYXRlTmV3UmVxdWVzdAkAzAgCBQdyZXF1ZXN0BQNuaWwFA25pbAMJAAECBQFAAgNJbnQFAUAFBHVuaXQDCQAAAgUMbmV3UmVxdWVzdElkBQxuZXdSZXF1ZXN0SWQEBGFyZ3MJAMwIAgkApQgBCAUBaQZjYWxsZXIJAMwIAgUHc2hhcmVJZAkAzAgCBQ1ib3Jyb3dBc3NldElkCQDMCAIFDGJvcnJvd0Ftb3VudAkAzAgCCQClCAEFBHRoaXMJAMwIAgIRcmVwbGFuaXNoRnJvbUxhbmQJAMwIAgkApAMBCQETdmFsdWVPckVycm9yTWVzc2FnZQIFDG5ld1JlcXVlc3RJZAIYQ2FuJ3QgY3JlYXRlIG5ldyByZXF1ZXN0BQNuaWwEA2ludgkA/QcECQEOZ2V0TGVuZFNydkFkZHIAAg1mbGFzaFBvc2l0aW9uBQRhcmdzBQNuaWwFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgMJAAACBQR0eXBlBQtTRl9QT1NfVFlQRQkBD3JlcGxhbmlzaFN3b3BGaQwJAKUIAQgFAWkGY2FsbGVyBQRwb29sBwUEcG10QQUJcG10QXNzZXRBBQRwbXRCBQlwbXRBc3NldEIFBGJhbEEFBGJhbEIFB3NoYXJlSWQFE3ZpcnR1YWxTd2FwVG9rZW5QYXkFE3ZpcnR1YWxTd2FwVG9rZW5HZXQJAAIBAgdDYW50IHd4AWkBEXJlcGxhbmlzaEZyb21MYW5kAQlyZXF1ZXN0SWQEB3JlcXVlc3QJALUJAgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMJAKwCAgUJcmVxdWVzdElkBQprUmVxdWVzdElkCQCsAgICE05vIHJlcXVlc3Qgd2l0aCBpZCAFCXJlcXVlc3RJZAIBLAMJAAACCQCRAwIFB3JlcXVlc3QAAAULU0ZfUE9TX1RZUEUJAQ9yZXBsYW5pc2hTd29wRmkMCQCRAwIFB3JlcXVlc3QAAQkAkQMCBQdyZXF1ZXN0AAIGCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHcmVxdWVzdAADCQCRAwIFB3JlcXVlc3QABAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB3JlcXVlc3QABQkAkQMCBQdyZXF1ZXN0AAYJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQdyZXF1ZXN0AAcJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQdyZXF1ZXN0AAgJAJEDAgUHcmVxdWVzdAAJCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHcmVxdWVzdAAKCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHcmVxdWVzdAALCQACAQIHQ2FudCB3eAFpARBjcmVhdGVOZXdSZXF1ZXN0AQZwYXJhbXMJAQt2YWx1ZU9yRWxzZQIJAQppc1NlbGZDYWxsAQUBaQQMbmV3UmVxdWVzdElkCQBkAgkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQxrUmVxdWVzdEl0ZXIAAAABCQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCkAwEFDG5ld1JlcXVlc3RJZAUKa1JlcXVlc3RJZAUGcGFyYW1zBQNuaWwFDG5ld1JlcXVlc3RJZAFpAQtpbml0TmV3UG9vbAUEdHlwZQhwb29sQWRkcgtpbkZlZU5vTG9hbglpbkZlZUxvYW4GY2FwRmVlAwMJAQIhPQIFBHR5cGUFC1NGX1BPU19UWVBFCQECIT0CBQR0eXBlBQtXWF9QT1NfVFlQRQcJAAIBAgpXcm9uZyB0eXBlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFCHBvb2xBZGRyBRVrQXhseUluRmVlV2l0aG91dExvYW4FC2luRmVlTm9Mb2FuCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFCHBvb2xBZGRyBRJrQXhseUluRmVlV2l0aExvYW4FCWluRmVlTG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQhwb29sQWRkcgULa0F4bHlDYXBGZWUFBmNhcEZlZQkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIFBWtQb29sBQhwb29sQWRkcgUEdHlwZQUDbmlsAQJ0eAEGdmVyaWZ5AAkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAgFAnR4D3NlbmRlclB1YmxpY0tleZNvLxE=", "height": 2504434, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: EtvXmhtURw3Ua5nPr3xFosjxS35FNwQQbEN3i7DgGk7k Next: JDJUwqzx3X8AZzceH5WkHVYC7py7GgEWMUHWASuwdeaa Diff:
OldNewDifferences
122122 let pmtAmountB = $t045444837._2
123123 let change = $t045444837._3
124124 let changeAssetId = $t045444837._4
125- let inv1 = if (if ((pmtAmountA > 0))
126- then (pmtAmountB > 0)
127- else false)
128- then {
129- let payments = [AttachedPayment(assetIdFromStr(pmtAssetA), pmtAmountA), AttachedPayment(assetIdFromStr(pmtAssetB), pmtAmountB)]
130- invoke(poolAddr, "replenishWithTwoTokensV2", [false, 0], payments)
131- }
132- else 0
133- if ((inv1 == inv1))
134- then {
135- let inv2 = if ((change > 0))
136- then {
137- let payments = [AttachedPayment(assetIdFromStr(changeAssetId), change)]
138- let vars = [virtualSwapTokenPay, virtualSwapTokenGet, false, 0]
139- invoke(poolAddr, "replenishWithOneTokenV2", vars, payments)
140- }
141- else 0
142- if ((inv2 == inv2))
143- then {
144- let shareBalanceAfter = accountBalance(fromBase58String(shareId))
145- let totalShare = (shareBalanceAfter - shareBalanceBefore)
146- let axlyInFee = fraction(totalShare, (FEE_SCALE6 - getAxlyInFee(pool, withLoan)), FEE_SCALE6)
147- let userShareForStake = (totalShare - axlyInFee)
148- if ((0 >= userShareForStake))
149- then throw("amount of staked sharetokens must be > 0")
150- else {
151- let inv3 = invoke(getSFFarmingAddr(), "lockShareTokens", [pool, 0], [AttachedPayment(fromBase58String(shareId), userShareForStake)])
152- if ((inv3 == inv3))
153- then {
154- let totalAmount = getAxlyTotalPosition(pool)
155- let newPosNum = getNewUserPositionNumber(pool, user)
156-[IntegerEntry((pool + kTotalPosition), (totalAmount + userShareForStake)), IntegerEntry((((((pool + "_") + user) + "_") + toString(newPosNum)) + kUserPosition), userShareForStake), StringEntry((((((pool + "_") + user) + "_") + toString(newPosNum)) + kUserPositionType), SF_POS_TYPE), IntegerEntry((((pool + "_") + user) + kUserPositionNum), newPosNum), ScriptTransfer(moneyBox, axlyInFee, fromBase58String(shareId))]
157- }
158- else throw("Strict value is not equal to itself.")
159- }
160- }
161- else throw("Strict value is not equal to itself.")
162- }
163- else throw("Strict value is not equal to itself.")
164- }
165-
166-
167-func replanishWX (user,pool,withLoan,pmtA,pmtAssetA,pmtB,pmtAssetB,balA,balB,shareId,virtualSwapTokenPay,virtualSwapTokenGet) = {
168- let shareBalanceBefore = accountBalance(fromBase58String(shareId))
169- let poolAddr = Address(fromBase58String(pool))
170- let ratioA = fraction(SCALE8, pmtA, balA)
171- let ratioB = fraction(SCALE8, pmtB, balB)
172- let $t070237316 = if ((ratioB > ratioA))
173- then {
174- let pmt = fraction(balB, ratioA, SCALE8, CEILING)
175- $Tuple4(pmtA, pmt, (pmtB - pmt), pmtAssetB)
176- }
177- else {
178- let pmt = fraction(balA, ratioB, SCALE8, CEILING)
179- $Tuple4(pmt, pmtB, (pmtA - pmt), pmtAssetA)
180- }
181- let pmtAmountA = $t070237316._1
182- let pmtAmountB = $t070237316._2
183- let change = $t070237316._3
184- let changeAssetId = $t070237316._4
185125 let poolVersion = getStringValue(poolAddr, "version")
186126 let inv1 = if (if ((pmtAmountA > 0))
187127 then (pmtAmountB > 0)
238178 }
239179
240180
181+func replanishWX (user,pool,withLoan,pmtA,pmtAssetA,pmtB,pmtAssetB,balA,balB,shareId,virtualSwapTokenPay,virtualSwapTokenGet) = nil
182+
183+
241184 @Callable(i)
242185 func replanish (pool,borrowAmount,borrowAssetId,virtualSwapTokenPay,virtualSwapTokenGet) = {
243186 let type = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
244- let $t0984310094 = if ((type == SF_POS_TYPE))
187+ let $t076537904 = if ((type == SF_POS_TYPE))
245188 then getSFPoolData(Address(fromBase58String(pool)))
246189 else if ((type == WX_POS_TYPE))
247190 then getWXPoolData(Address(fromBase58String(pool)))
248191 else throw("Wrong pool type")
249- let AId = $t0984310094._1
250- let BId = $t0984310094._2
251- let balA = $t0984310094._3
252- let balB = $t0984310094._4
253- let shareId = $t0984310094._5
254- let $t01009810735 = if ((size(i.payments) == 2))
192+ let AId = $t076537904._1
193+ let BId = $t076537904._2
194+ let balA = $t076537904._3
195+ let balB = $t076537904._4
196+ let shareId = $t076537904._5
197+ let $t079088545 = if ((size(i.payments) == 2))
255198 then if ((assetIdToStr(i.payments[0].assetId) != AId))
256199 then throw("Wrong payment asset A")
257200 else if ((assetIdToStr(i.payments[1].assetId) != BId))
264207 then $Tuple4(0, AId, i.payments[0].amount, BId)
265208 else throw("Wrong payment")
266209 else throw("One or two payments expected")
267- let pmtA = $t01009810735._1
268- let pmtAssetA = $t01009810735._2
269- let pmtB = $t01009810735._3
270- let pmtAssetB = $t01009810735._4
210+ let pmtA = $t079088545._1
211+ let pmtAssetA = $t079088545._2
212+ let pmtB = $t079088545._3
213+ let pmtAssetB = $t079088545._4
271214 if ((borrowAmount > 0))
272215 then {
273216 let request = makeString([type, toString(i.caller), pool, toString(pmtA), pmtAssetA, toString(pmtB), pmtAssetB, toString(balA), toString(balB), shareId, toString(virtualSwapTokenPay), toString(virtualSwapTokenGet)], ",")
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let SF_POS_TYPE = "SF"
55
66 let WX_POS_TYPE = "WX"
77
88 let SCALE8 = 100000000
99
1010 let FEE_SCALE6 = 1000000
1111
1212 let kSFPoolAAssetBalance = "A_asset_balance"
1313
1414 let kSFPoolBAssetBalance = "B_asset_balance"
1515
1616 let kSFPoolAAssetId = "A_asset_id"
1717
1818 let kSFPoolBAssetId = "B_asset_id"
1919
2020 let kSFPoolShareId = "share_asset_id"
2121
2222 let kSFPoolVersion = "version"
2323
2424 let kSFFarmingStaked = "_share_tokens_locked"
2525
2626 let kUserPosition = "_user_position"
2727
2828 let kUserPositionType = "_user_position_type"
2929
3030 let kUserPositionNum = "_user_position_number"
3131
3232 let kTotalPosition = "_total_position"
3333
3434 let kAxlyInFeeWithoutLoan = "_axly_fee_without_loan"
3535
3636 let kAxlyInFeeWithLoan = "_axly_fee_with_loan"
3737
3838 let kAxlyCapFee = "_axly_fee_cap"
3939
4040 let kRequestId = "_request_id"
4141
4242 let kRequestIter = "requests_iter"
4343
4444 let kPool = "pool_"
4545
4646 let kMoneyBox = "axly_money_box"
4747
4848 let kSFFarmingAddr = "swopfi_farming_addr"
4949
5050 let kLendService = "lend_service_addr"
5151
5252 let moneyBox = Address(fromBase58String(valueOrErrorMessage(getString(this, kMoneyBox), "No axly moneyBox address")))
5353
5454 func isSelfCall (i) = if ((i.caller == this))
5555 then unit
5656 else throw("Only contract itself can call this function")
5757
5858
5959 func accountBalance (assetId) = match assetId {
6060 case id: ByteVector =>
6161 assetBalance(this, id)
6262 case waves: Unit =>
6363 wavesBalance(this).available
6464 case _ =>
6565 throw("Match error")
6666 }
6767
6868
6969 func getSFPoolData (poolAddr) = $Tuple5(valueOrErrorMessage(getString(poolAddr, kSFPoolAAssetId), "Can't get pool A asset id"), valueOrErrorMessage(getString(poolAddr, kSFPoolBAssetId), "Can't get pool B asset id"), valueOrErrorMessage(getInteger(poolAddr, kSFPoolAAssetBalance), "Can't get pool A asset balance"), valueOrErrorMessage(getInteger(poolAddr, kSFPoolBAssetBalance), "Can't get pool B asset balance"), valueOrErrorMessage(getString(poolAddr, kSFPoolShareId), "Can't get share asset id"))
7070
7171
7272 func getWXPoolData (poolAddr) = $Tuple5(valueOrErrorMessage(getString(poolAddr, kSFPoolAAssetId), "Can't get pool A asset id"), valueOrErrorMessage(getString(poolAddr, kSFPoolBAssetId), "Can't get pool B asset id"), valueOrErrorMessage(getInteger(poolAddr, kSFPoolAAssetBalance), "Can't get pool A asset balance"), valueOrErrorMessage(getInteger(poolAddr, kSFPoolBAssetBalance), "Can't get pool B asset balance"), valueOrErrorMessage(getString(poolAddr, kSFPoolShareId), "Can't get share asset id"))
7373
7474
7575 func getAxlyTotalPosition (pool) = valueOrElse(getInteger(this, (pool + kTotalPosition)), 0)
7676
7777
7878 func getNewUserPositionNumber (pool,user) = (valueOrElse(getInteger(this, (((pool + "_") + user) + kUserPositionNum)), 0) + 1)
7979
8080
8181 func getAxlyInFee (pool,withLoan) = if (withLoan)
8282 then getIntegerValue(this, (pool + kAxlyInFeeWithLoan))
8383 else getIntegerValue(this, (pool + kAxlyInFeeWithoutLoan))
8484
8585
8686 func getSFFarmingAddr () = Address(fromBase58String(valueOrErrorMessage(getString(this, kSFFarmingAddr), "Can't get swopfi farming addr")))
8787
8888
8989 func getLendSrvAddr () = Address(fromBase58String(valueOrErrorMessage(getString(this, kLendService), "Can't get lend service addr")))
9090
9191
9292 func assetIdToStr (assetId) = match assetId {
9393 case id: ByteVector =>
9494 toBase58String(id)
9595 case waves: Unit =>
9696 "WAVES"
9797 case _ =>
9898 throw("Match error")
9999 }
100100
101101
102102 func assetIdFromStr (assetId) = if ((assetId == "WAVES"))
103103 then unit
104104 else fromBase58String(assetId)
105105
106106
107107 func replanishSwopFi (user,pool,withLoan,pmtA,pmtAssetA,pmtB,pmtAssetB,balA,balB,shareId,virtualSwapTokenPay,virtualSwapTokenGet) = {
108108 let shareBalanceBefore = accountBalance(fromBase58String(shareId))
109109 let poolAddr = Address(fromBase58String(pool))
110110 let ratioA = fraction(SCALE8, pmtA, balA)
111111 let ratioB = fraction(SCALE8, pmtB, balB)
112112 let $t045444837 = if ((ratioB > ratioA))
113113 then {
114114 let pmt = fraction(balB, ratioA, SCALE8, CEILING)
115115 $Tuple4(pmtA, pmt, (pmtB - pmt), pmtAssetB)
116116 }
117117 else {
118118 let pmt = fraction(balA, ratioB, SCALE8, CEILING)
119119 $Tuple4(pmt, pmtB, (pmtA - pmt), pmtAssetA)
120120 }
121121 let pmtAmountA = $t045444837._1
122122 let pmtAmountB = $t045444837._2
123123 let change = $t045444837._3
124124 let changeAssetId = $t045444837._4
125- let inv1 = if (if ((pmtAmountA > 0))
126- then (pmtAmountB > 0)
127- else false)
128- then {
129- let payments = [AttachedPayment(assetIdFromStr(pmtAssetA), pmtAmountA), AttachedPayment(assetIdFromStr(pmtAssetB), pmtAmountB)]
130- invoke(poolAddr, "replenishWithTwoTokensV2", [false, 0], payments)
131- }
132- else 0
133- if ((inv1 == inv1))
134- then {
135- let inv2 = if ((change > 0))
136- then {
137- let payments = [AttachedPayment(assetIdFromStr(changeAssetId), change)]
138- let vars = [virtualSwapTokenPay, virtualSwapTokenGet, false, 0]
139- invoke(poolAddr, "replenishWithOneTokenV2", vars, payments)
140- }
141- else 0
142- if ((inv2 == inv2))
143- then {
144- let shareBalanceAfter = accountBalance(fromBase58String(shareId))
145- let totalShare = (shareBalanceAfter - shareBalanceBefore)
146- let axlyInFee = fraction(totalShare, (FEE_SCALE6 - getAxlyInFee(pool, withLoan)), FEE_SCALE6)
147- let userShareForStake = (totalShare - axlyInFee)
148- if ((0 >= userShareForStake))
149- then throw("amount of staked sharetokens must be > 0")
150- else {
151- let inv3 = invoke(getSFFarmingAddr(), "lockShareTokens", [pool, 0], [AttachedPayment(fromBase58String(shareId), userShareForStake)])
152- if ((inv3 == inv3))
153- then {
154- let totalAmount = getAxlyTotalPosition(pool)
155- let newPosNum = getNewUserPositionNumber(pool, user)
156-[IntegerEntry((pool + kTotalPosition), (totalAmount + userShareForStake)), IntegerEntry((((((pool + "_") + user) + "_") + toString(newPosNum)) + kUserPosition), userShareForStake), StringEntry((((((pool + "_") + user) + "_") + toString(newPosNum)) + kUserPositionType), SF_POS_TYPE), IntegerEntry((((pool + "_") + user) + kUserPositionNum), newPosNum), ScriptTransfer(moneyBox, axlyInFee, fromBase58String(shareId))]
157- }
158- else throw("Strict value is not equal to itself.")
159- }
160- }
161- else throw("Strict value is not equal to itself.")
162- }
163- else throw("Strict value is not equal to itself.")
164- }
165-
166-
167-func replanishWX (user,pool,withLoan,pmtA,pmtAssetA,pmtB,pmtAssetB,balA,balB,shareId,virtualSwapTokenPay,virtualSwapTokenGet) = {
168- let shareBalanceBefore = accountBalance(fromBase58String(shareId))
169- let poolAddr = Address(fromBase58String(pool))
170- let ratioA = fraction(SCALE8, pmtA, balA)
171- let ratioB = fraction(SCALE8, pmtB, balB)
172- let $t070237316 = if ((ratioB > ratioA))
173- then {
174- let pmt = fraction(balB, ratioA, SCALE8, CEILING)
175- $Tuple4(pmtA, pmt, (pmtB - pmt), pmtAssetB)
176- }
177- else {
178- let pmt = fraction(balA, ratioB, SCALE8, CEILING)
179- $Tuple4(pmt, pmtB, (pmtA - pmt), pmtAssetA)
180- }
181- let pmtAmountA = $t070237316._1
182- let pmtAmountB = $t070237316._2
183- let change = $t070237316._3
184- let changeAssetId = $t070237316._4
185125 let poolVersion = getStringValue(poolAddr, "version")
186126 let inv1 = if (if ((pmtAmountA > 0))
187127 then (pmtAmountB > 0)
188128 else false)
189129 then {
190130 let payments = [AttachedPayment(assetIdFromStr(pmtAssetA), pmtAmountA), AttachedPayment(assetIdFromStr(pmtAssetB), pmtAmountB)]
191131 if ((poolVersion == "1.0.0"))
192132 then invoke(poolAddr, "callFunction", ["replenishWithTwoTokens", ["false", "0"]], payments)
193133 else if ((poolVersion == "2.0.0"))
194134 then invoke(poolAddr, "replenishWithTwoTokensV2", [false, 0], payments)
195135 else throw("Wrong pool type")
196136 }
197137 else 0
198138 if ((inv1 == inv1))
199139 then {
200140 let inv2 = if ((change > 0))
201141 then {
202142 let payments = [AttachedPayment(assetIdFromStr(changeAssetId), change)]
203143 if ((poolVersion == "1.0.0"))
204144 then {
205145 let vars = [toString(virtualSwapTokenPay), toString(virtualSwapTokenGet), "false", "0"]
206146 invoke(poolAddr, "callFunction", ["replenishWithOneToken", vars], payments)
207147 }
208148 else if ((poolVersion == "2.0.0"))
209149 then {
210150 let vars = [virtualSwapTokenPay, virtualSwapTokenGet, false, 0]
211151 invoke(poolAddr, "replenishWithOneTokenV2", [false, 0], payments)
212152 }
213153 else throw("Wrong pool type")
214154 }
215155 else 0
216156 if ((inv2 == inv2))
217157 then {
218158 let shareBalanceAfter = accountBalance(fromBase58String(shareId))
219159 let totalShare = (shareBalanceAfter - shareBalanceBefore)
220160 let axlyInFee = fraction(totalShare, (FEE_SCALE6 - getAxlyInFee(pool, withLoan)), FEE_SCALE6)
221161 let userShareForStake = (totalShare - axlyInFee)
222162 if ((0 >= userShareForStake))
223163 then throw("amount of staked sharetokens must be > 0")
224164 else {
225165 let inv3 = invoke(getSFFarmingAddr(), "lockShareTokens", [pool, 0], [AttachedPayment(fromBase58String(shareId), userShareForStake)])
226166 if ((inv3 == inv3))
227167 then {
228168 let totalAmount = getAxlyTotalPosition(pool)
229169 let newPosNum = getNewUserPositionNumber(pool, user)
230170 [IntegerEntry((pool + kTotalPosition), (totalAmount + userShareForStake)), IntegerEntry((((((pool + "_") + user) + "_") + toString(newPosNum)) + kUserPosition), userShareForStake), StringEntry((((((pool + "_") + user) + "_") + toString(newPosNum)) + kUserPositionType), SF_POS_TYPE), IntegerEntry((((pool + "_") + user) + kUserPositionNum), newPosNum), ScriptTransfer(moneyBox, axlyInFee, fromBase58String(shareId))]
231171 }
232172 else throw("Strict value is not equal to itself.")
233173 }
234174 }
235175 else throw("Strict value is not equal to itself.")
236176 }
237177 else throw("Strict value is not equal to itself.")
238178 }
239179
240180
181+func replanishWX (user,pool,withLoan,pmtA,pmtAssetA,pmtB,pmtAssetB,balA,balB,shareId,virtualSwapTokenPay,virtualSwapTokenGet) = nil
182+
183+
241184 @Callable(i)
242185 func replanish (pool,borrowAmount,borrowAssetId,virtualSwapTokenPay,virtualSwapTokenGet) = {
243186 let type = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
244- let $t0984310094 = if ((type == SF_POS_TYPE))
187+ let $t076537904 = if ((type == SF_POS_TYPE))
245188 then getSFPoolData(Address(fromBase58String(pool)))
246189 else if ((type == WX_POS_TYPE))
247190 then getWXPoolData(Address(fromBase58String(pool)))
248191 else throw("Wrong pool type")
249- let AId = $t0984310094._1
250- let BId = $t0984310094._2
251- let balA = $t0984310094._3
252- let balB = $t0984310094._4
253- let shareId = $t0984310094._5
254- let $t01009810735 = if ((size(i.payments) == 2))
192+ let AId = $t076537904._1
193+ let BId = $t076537904._2
194+ let balA = $t076537904._3
195+ let balB = $t076537904._4
196+ let shareId = $t076537904._5
197+ let $t079088545 = if ((size(i.payments) == 2))
255198 then if ((assetIdToStr(i.payments[0].assetId) != AId))
256199 then throw("Wrong payment asset A")
257200 else if ((assetIdToStr(i.payments[1].assetId) != BId))
258201 then throw("Wrong payment asset B")
259202 else $Tuple4(i.payments[0].amount, AId, i.payments[1].amount, BId)
260203 else if ((size(i.payments) == 1))
261204 then if ((assetIdToStr(i.payments[0].assetId) == AId))
262205 then $Tuple4(i.payments[0].amount, AId, 0, BId)
263206 else if ((assetIdToStr(i.payments[0].assetId) == BId))
264207 then $Tuple4(0, AId, i.payments[0].amount, BId)
265208 else throw("Wrong payment")
266209 else throw("One or two payments expected")
267- let pmtA = $t01009810735._1
268- let pmtAssetA = $t01009810735._2
269- let pmtB = $t01009810735._3
270- let pmtAssetB = $t01009810735._4
210+ let pmtA = $t079088545._1
211+ let pmtAssetA = $t079088545._2
212+ let pmtB = $t079088545._3
213+ let pmtAssetB = $t079088545._4
271214 if ((borrowAmount > 0))
272215 then {
273216 let request = makeString([type, toString(i.caller), pool, toString(pmtA), pmtAssetA, toString(pmtB), pmtAssetB, toString(balA), toString(balB), shareId, toString(virtualSwapTokenPay), toString(virtualSwapTokenGet)], ",")
274217 let newRequestId = {
275218 let @ = invoke(this, "createNewRequest", [request], nil)
276219 if ($isInstanceOf(@, "Int"))
277220 then @
278221 else unit
279222 }
280223 if ((newRequestId == newRequestId))
281224 then {
282225 let args = [toString(i.caller), shareId, borrowAssetId, borrowAmount, toString(this), "replanishFromLand", toString(valueOrErrorMessage(newRequestId, "Can't create new request"))]
283226 let inv = reentrantInvoke(getLendSrvAddr(), "flashPosition", args, nil)
284227 nil
285228 }
286229 else throw("Strict value is not equal to itself.")
287230 }
288231 else if ((type == SF_POS_TYPE))
289232 then replanishSwopFi(toString(i.caller), pool, false, pmtA, pmtAssetA, pmtB, pmtAssetB, balA, balB, shareId, virtualSwapTokenPay, virtualSwapTokenGet)
290233 else throw("Cant wx")
291234 }
292235
293236
294237
295238 @Callable(i)
296239 func replanishFromLand (requestId) = {
297240 let request = split(valueOrErrorMessage(getString(this, (requestId + kRequestId)), ("No request with id " + requestId)), ",")
298241 if ((request[0] == SF_POS_TYPE))
299242 then replanishSwopFi(request[1], request[2], true, parseIntValue(request[3]), request[4], parseIntValue(request[5]), request[6], parseIntValue(request[7]), parseIntValue(request[8]), request[9], parseIntValue(request[10]), parseIntValue(request[11]))
300243 else throw("Cant wx")
301244 }
302245
303246
304247
305248 @Callable(i)
306249 func createNewRequest (params) = valueOrElse(isSelfCall(i), {
307250 let newRequestId = (valueOrElse(getInteger(this, kRequestIter), 0) + 1)
308251 $Tuple2([StringEntry((toString(newRequestId) + kRequestId), params)], newRequestId)
309252 })
310253
311254
312255
313256 @Callable(i)
314257 func initNewPool (type,poolAddr,inFeeNoLoan,inFeeLoan,capFee) = if (if ((type != SF_POS_TYPE))
315258 then (type != WX_POS_TYPE)
316259 else false)
317260 then throw("Wrong type")
318261 else [IntegerEntry((poolAddr + kAxlyInFeeWithoutLoan), inFeeNoLoan), IntegerEntry((poolAddr + kAxlyInFeeWithLoan), inFeeLoan), IntegerEntry((poolAddr + kAxlyCapFee), capFee), StringEntry((kPool + poolAddr), type)]
319262
320263
321264 @Verifier(tx)
322265 func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
323266

github/deemru/w8io/169f3d6 
54.23 ms