tx · D2biWyQf9VrsL32KB9iTKx9sCPWYcA114RHun7hZkfzv 3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS: -0.01000000 Waves 2023.03.24 21:16 [2504445] smart account 3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS > SELF 0.00000000 Waves
{ "type": 13, "id": "D2biWyQf9VrsL32KB9iTKx9sCPWYcA114RHun7hZkfzv", "fee": 1000000, "feeAssetId": null, "timestamp": 1679681830563, "version": 2, "chainId": 84, "sender": "3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS", "senderPublicKey": "HP8sssVq1866F7CaPQJwgFrt6fsqhQjKwM84cL1wjD2a", "proofs": [ "2xyr1HW72UH6VcCrdwEQxuZdoi8u7iUfRyY2KdAtG6XRPDrj12JKPSaPN8Hxt1w87rx46b3ju9qkwTm4wXQdrobD" ], "script": "base64:BgIeCAISBwoFCAEIAQESAwoBCBIDCgEIEgcKBQgIAQEBJgALU0ZfUE9TX1RZUEUCAlNGAAtXWF9QT1NfVFlQRQICV1gABlNDQUxFOACAwtcvAApGRUVfU0NBTEU2AMCEPQAUa1NGUG9vbEFBc3NldEJhbGFuY2UCD0FfYXNzZXRfYmFsYW5jZQAUa1NGUG9vbEJBc3NldEJhbGFuY2UCD0JfYXNzZXRfYmFsYW5jZQAPa1NGUG9vbEFBc3NldElkAgpBX2Fzc2V0X2lkAA9rU0ZQb29sQkFzc2V0SWQCCkJfYXNzZXRfaWQADmtTRlBvb2xTaGFyZUlkAg5zaGFyZV9hc3NldF9pZAAOa1NGUG9vbFZlcnNpb24CB3ZlcnNpb24AEGtTRkZhcm1pbmdTdGFrZWQCFF9zaGFyZV90b2tlbnNfbG9ja2VkAA1rVXNlclBvc2l0aW9uAg5fdXNlcl9wb3NpdGlvbgARa1VzZXJQb3NpdGlvblR5cGUCE191c2VyX3Bvc2l0aW9uX3R5cGUAEGtVc2VyUG9zaXRpb25OdW0CFV91c2VyX3Bvc2l0aW9uX251bWJlcgAOa1RvdGFsUG9zaXRpb24CD190b3RhbF9wb3NpdGlvbgAVa0F4bHlJbkZlZVdpdGhvdXRMb2FuAhZfYXhseV9mZWVfd2l0aG91dF9sb2FuABJrQXhseUluRmVlV2l0aExvYW4CE19heGx5X2ZlZV93aXRoX2xvYW4AC2tBeGx5Q2FwRmVlAg1fYXhseV9mZWVfY2FwAAprUmVxdWVzdElkAgtfcmVxdWVzdF9pZAAMa1JlcXVlc3RJdGVyAg1yZXF1ZXN0c19pdGVyAAVrUG9vbAIFcG9vbF8ACWtNb25leUJveAIOYXhseV9tb25leV9ib3gADmtTRkZhcm1pbmdBZGRyAhNzd29wZmlfZmFybWluZ19hZGRyAAxrTGVuZFNlcnZpY2UCEWxlbmRfc2VydmljZV9hZGRyAAhtb25leUJveAkBB0FkZHJlc3MBCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQlrTW9uZXlCb3gCGE5vIGF4bHkgbW9uZXlCb3ggYWRkcmVzcwEKaXNTZWxmQ2FsbAEBaQMJAAACCAUBaQZjYWxsZXIFBHRoaXMFBHVuaXQJAAIBAitPbmx5IGNvbnRyYWN0IGl0c2VsZiBjYW4gY2FsbCB0aGlzIGZ1bmN0aW9uAQ5hY2NvdW50QmFsYW5jZQEHYXNzZXRJZAQHJG1hdGNoMAUHYXNzZXRJZAMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAJpZAUHJG1hdGNoMAkA8AcCBQR0aGlzBQJpZAMJAAECBQckbWF0Y2gwAgRVbml0BAV3YXZlcwUHJG1hdGNoMAgJAO8HAQUEdGhpcwlhdmFpbGFibGUJAAIBAgtNYXRjaCBlcnJvcgENZ2V0U0ZQb29sRGF0YQEIcG9vbEFkZHIJAJcKBQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFCHBvb2xBZGRyBQ9rU0ZQb29sQUFzc2V0SWQCGUNhbid0IGdldCBwb29sIEEgYXNzZXQgaWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQhwb29sQWRkcgUPa1NGUG9vbEJBc3NldElkAhlDYW4ndCBnZXQgcG9vbCBCIGFzc2V0IGlkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUIcG9vbEFkZHIFFGtTRlBvb2xBQXNzZXRCYWxhbmNlAh5DYW4ndCBnZXQgcG9vbCBBIGFzc2V0IGJhbGFuY2UJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQhwb29sQWRkcgUUa1NGUG9vbEJBc3NldEJhbGFuY2UCHkNhbid0IGdldCBwb29sIEIgYXNzZXQgYmFsYW5jZQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFCHBvb2xBZGRyBQ5rU0ZQb29sU2hhcmVJZAIYQ2FuJ3QgZ2V0IHNoYXJlIGFzc2V0IGlkAQ1nZXRXWFBvb2xEYXRhAQhwb29sQWRkcgkAlwoFCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUIcG9vbEFkZHIFD2tTRlBvb2xBQXNzZXRJZAIZQ2FuJ3QgZ2V0IHBvb2wgQSBhc3NldCBpZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFCHBvb2xBZGRyBQ9rU0ZQb29sQkFzc2V0SWQCGUNhbid0IGdldCBwb29sIEIgYXNzZXQgaWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQhwb29sQWRkcgUUa1NGUG9vbEFBc3NldEJhbGFuY2UCHkNhbid0IGdldCBwb29sIEEgYXNzZXQgYmFsYW5jZQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFCHBvb2xBZGRyBRRrU0ZQb29sQkFzc2V0QmFsYW5jZQIeQ2FuJ3QgZ2V0IHBvb2wgQiBhc3NldCBiYWxhbmNlCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUIcG9vbEFkZHIFDmtTRlBvb2xTaGFyZUlkAhhDYW4ndCBnZXQgc2hhcmUgYXNzZXQgaWQBFGdldEF4bHlUb3RhbFBvc2l0aW9uAQRwb29sCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgUEcG9vbAUOa1RvdGFsUG9zaXRpb24AAAEYZ2V0TmV3VXNlclBvc2l0aW9uTnVtYmVyAgRwb29sBHVzZXIJAGQCCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXIFEGtVc2VyUG9zaXRpb25OdW0AAAABAQxnZXRBeGx5SW5GZWUCBHBvb2wId2l0aExvYW4DBQh3aXRoTG9hbgkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkArAICBQRwb29sBRJrQXhseUluRmVlV2l0aExvYW4JARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAUVa0F4bHlJbkZlZVdpdGhvdXRMb2FuARBnZXRTRkZhcm1pbmdBZGRyAAkBB0FkZHJlc3MBCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQ5rU0ZGYXJtaW5nQWRkcgIdQ2FuJ3QgZ2V0IHN3b3BmaSBmYXJtaW5nIGFkZHIBDmdldExlbmRTcnZBZGRyAAkBB0FkZHJlc3MBCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQxrTGVuZFNlcnZpY2UCG0Nhbid0IGdldCBsZW5kIHNlcnZpY2UgYWRkcgEMYXNzZXRJZFRvU3RyAQdhc3NldElkBAckbWF0Y2gwBQdhc3NldElkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAmlkBQckbWF0Y2gwCQDYBAEFAmlkAwkAAQIFByRtYXRjaDACBFVuaXQEBXdhdmVzBQckbWF0Y2gwAgVXQVZFUwkAAgECC01hdGNoIGVycm9yAQ5hc3NldElkRnJvbVN0cgEHYXNzZXRJZAMJAAACBQdhc3NldElkAgVXQVZFUwUEdW5pdAkA2QQBBQdhc3NldElkAQ9yZXBsYW5pc2hTd29wRmkMBHVzZXIEcG9vbAh3aXRoTG9hbgRwbXRBCXBtdEFzc2V0QQRwbXRCCXBtdEFzc2V0QgRiYWxBBGJhbEIHc2hhcmVJZBN2aXJ0dWFsU3dhcFRva2VuUGF5E3ZpcnR1YWxTd2FwVG9rZW5HZXQEEnNoYXJlQmFsYW5jZUJlZm9yZQkBDmFjY291bnRCYWxhbmNlAQkA2QQBBQdzaGFyZUlkAwkAAAIAAQABCQACAQkArAICCQCsAgIFB3NoYXJlSWQCA3x8IAkApAMBBRJzaGFyZUJhbGFuY2VCZWZvcmUECHBvb2xBZGRyCQEHQWRkcmVzcwEJANkEAQUEcG9vbAQGcmF0aW9BCQBrAwUGU0NBTEU4BQRwbXRBBQRiYWxBBAZyYXRpb0IJAGsDBQZTQ0FMRTgFBHBtdEIFBGJhbEIECyR0MDQ2MTk0OTEyAwkAZgIFBnJhdGlvQgUGcmF0aW9BBANwbXQJAG4EBQRiYWxCBQZyYXRpb0EFBlNDQUxFOAUHQ0VJTElORwkAlgoEBQRwbXRBBQNwbXQJAGUCBQRwbXRCBQNwbXQFCXBtdEFzc2V0QgQDcG10CQBuBAUEYmFsQQUGcmF0aW9CBQZTQ0FMRTgFB0NFSUxJTkcJAJYKBAUDcG10BQRwbXRCCQBlAgUEcG10QQUDcG10BQlwbXRBc3NldEEECnBtdEFtb3VudEEIBQskdDA0NjE5NDkxMgJfMQQKcG10QW1vdW50QggFCyR0MDQ2MTk0OTEyAl8yBAZjaGFuZ2UIBQskdDA0NjE5NDkxMgJfMwQNY2hhbmdlQXNzZXRJZAgFCyR0MDQ2MTk0OTEyAl80BAtwb29sVmVyc2lvbgkBEUBleHRyTmF0aXZlKDEwNTMpAgUIcG9vbEFkZHICB3ZlcnNpb24EBGludjEDAwkAZgIFCnBtdEFtb3VudEEAAAkAZgIFCnBtdEFtb3VudEIAAAcECHBheW1lbnRzCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQEOYXNzZXRJZEZyb21TdHIBBQlwbXRBc3NldEEFCnBtdEFtb3VudEEJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJAQ5hc3NldElkRnJvbVN0cgEFCXBtdEFzc2V0QgUKcG10QW1vdW50QgUDbmlsAwkAAAIFC3Bvb2xWZXJzaW9uAgUxLjAuMAkA/AcEBQhwb29sQWRkcgIMY2FsbEZ1bmN0aW9uCQDMCAICFnJlcGxlbmlzaFdpdGhUd29Ub2tlbnMJAMwIAgkAzAgCAgVmYWxzZQkAzAgCAgEwBQNuaWwFA25pbAUIcGF5bWVudHMDCQAAAgULcG9vbFZlcnNpb24CBTIuMC4wCQD8BwQFCHBvb2xBZGRyAhhyZXBsZW5pc2hXaXRoVHdvVG9rZW5zVjIJAMwIAgcJAMwIAgAABQNuaWwFCHBheW1lbnRzCQACAQIPV3JvbmcgcG9vbCB0eXBlAAADCQAAAgUEaW52MQUEaW52MQQEaW52MgMJAGYCBQZjaGFuZ2UAAAQIcGF5bWVudHMJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJAQ5hc3NldElkRnJvbVN0cgEFDWNoYW5nZUFzc2V0SWQFBmNoYW5nZQUDbmlsAwkAAAIFC3Bvb2xWZXJzaW9uAgUxLjAuMAQEdmFycwkAzAgCAgEwCQDMCAICBWZhbHNlCQDMCAICATAFA25pbAkA/AcEBQhwb29sQWRkcgIMY2FsbEZ1bmN0aW9uCQDMCAICFXJlcGxlbmlzaFdpdGhPbmVUb2tlbgkAzAgCBQR2YXJzBQNuaWwFCHBheW1lbnRzAwkAAAIFC3Bvb2xWZXJzaW9uAgUyLjAuMAQEdmFycwkAzAgCBRN2aXJ0dWFsU3dhcFRva2VuUGF5CQDMCAIFE3ZpcnR1YWxTd2FwVG9rZW5HZXQJAMwIAgcJAMwIAgAABQNuaWwJAPwHBAUIcG9vbEFkZHICF3JlcGxlbmlzaFdpdGhPbmVUb2tlblYyCQDMCAIHCQDMCAIAAAUDbmlsBQhwYXltZW50cwkAAgECD1dyb25nIHBvb2wgdHlwZQAAAwkAAAIFBGludjIFBGludjIEEXNoYXJlQmFsYW5jZUFmdGVyCQEOYWNjb3VudEJhbGFuY2UBCQDZBAEFB3NoYXJlSWQECnRvdGFsU2hhcmUJAGUCBRFzaGFyZUJhbGFuY2VBZnRlcgUSc2hhcmVCYWxhbmNlQmVmb3JlBAlheGx5SW5GZWUJAGsDBQp0b3RhbFNoYXJlCQBlAgUKRkVFX1NDQUxFNgkBDGdldEF4bHlJbkZlZQIFBHBvb2wFCHdpdGhMb2FuBQpGRUVfU0NBTEU2BBF1c2VyU2hhcmVGb3JTdGFrZQkAZQIFCnRvdGFsU2hhcmUFCWF4bHlJbkZlZQMJAGcCAAAFEXVzZXJTaGFyZUZvclN0YWtlCQACAQIoYW1vdW50IG9mIHN0YWtlZCBzaGFyZXRva2VucyBtdXN0IGJlID4gMAQEaW52MwkA/AcECQEQZ2V0U0ZGYXJtaW5nQWRkcgACD2xvY2tTaGFyZVRva2VucwkAzAgCBQRwb29sCQDMCAIAAAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQDZBAEFB3NoYXJlSWQFEXVzZXJTaGFyZUZvclN0YWtlBQNuaWwDCQAAAgUEaW52MwUEaW52MwQLdG90YWxBbW91bnQJARRnZXRBeGx5VG90YWxQb3NpdGlvbgEFBHBvb2wECW5ld1Bvc051bQkBGGdldE5ld1VzZXJQb3NpdGlvbk51bWJlcgIFBHBvb2wFBHVzZXIJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEcG9vbAUOa1RvdGFsUG9zaXRpb24JAGQCBQt0b3RhbEFtb3VudAURdXNlclNoYXJlRm9yU3Rha2UJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfCQCkAwEFCW5ld1Bvc051bQUNa1VzZXJQb3NpdGlvbgURdXNlclNoYXJlRm9yU3Rha2UJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8JAKQDAQUJbmV3UG9zTnVtBRFrVXNlclBvc2l0aW9uVHlwZQULU0ZfUE9TX1RZUEUJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXIFEGtVc2VyUG9zaXRpb25OdW0FCW5ld1Bvc051bQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQhtb25leUJveAUJYXhseUluRmVlCQDZBAEFB3NoYXJlSWQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgELcmVwbGFuaXNoV1gMBHVzZXIEcG9vbAh3aXRoTG9hbgRwbXRBCXBtdEFzc2V0QQRwbXRCCXBtdEFzc2V0QgRiYWxBBGJhbEIHc2hhcmVJZBN2aXJ0dWFsU3dhcFRva2VuUGF5E3ZpcnR1YWxTd2FwVG9rZW5HZXQFA25pbAQBaQEJcmVwbGFuaXNoBQRwb29sDGJvcnJvd0Ftb3VudA1ib3Jyb3dBc3NldElkE3ZpcnR1YWxTd2FwVG9rZW5QYXkTdmlydHVhbFN3YXBUb2tlbkdldAQEdHlwZQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMJAKwCAgUFa1Bvb2wFBHBvb2wCElBvb2wgaXMgbm90IGluaXRlZAQLJHQwNzY1ODc5MDkDCQAAAgUEdHlwZQULU0ZfUE9TX1RZUEUJAQ1nZXRTRlBvb2xEYXRhAQkBB0FkZHJlc3MBCQDZBAEFBHBvb2wDCQAAAgUEdHlwZQULV1hfUE9TX1RZUEUJAQ1nZXRXWFBvb2xEYXRhAQkBB0FkZHJlc3MBCQDZBAEFBHBvb2wJAAIBAg9Xcm9uZyBwb29sIHR5cGUEA0FJZAgFCyR0MDc2NTg3OTA5Al8xBANCSWQIBQskdDA3NjU4NzkwOQJfMgQEYmFsQQgFCyR0MDc2NTg3OTA5Al8zBARiYWxCCAULJHQwNzY1ODc5MDkCXzQEB3NoYXJlSWQIBQskdDA3NjU4NzkwOQJfNQQLJHQwNzkxMzg1NTADCQAAAgkAkAMBCAUBaQhwYXltZW50cwACAwkBAiE9AgkBDGFzc2V0SWRUb1N0cgEICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAUDQUlkCQACAQIVV3JvbmcgcGF5bWVudCBhc3NldCBBAwkBAiE9AgkBDGFzc2V0SWRUb1N0cgEICQCRAwIIBQFpCHBheW1lbnRzAAEHYXNzZXRJZAUDQklkCQACAQIVV3JvbmcgcGF5bWVudCBhc3NldCBCCQCWCgQICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BQNBSWQICQCRAwIIBQFpCHBheW1lbnRzAAEGYW1vdW50BQNCSWQDCQAAAgkAkAMBCAUBaQhwYXltZW50cwABAwkAAAIJAQxhc3NldElkVG9TdHIBCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQFA0FJZAkAlgoECAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAUDQUlkAAAFA0JJZAMJAAACCQEMYXNzZXRJZFRvU3RyAQgJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBQNCSWQJAJYKBAAABQNBSWQICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BQNCSWQJAAIBAg1Xcm9uZyBwYXltZW50CQACAQIcT25lIG9yIHR3byBwYXltZW50cyBleHBlY3RlZAQEcG10QQgFCyR0MDc5MTM4NTUwAl8xBAlwbXRBc3NldEEIBQskdDA3OTEzODU1MAJfMgQEcG10QggFCyR0MDc5MTM4NTUwAl8zBAlwbXRBc3NldEIIBQskdDA3OTEzODU1MAJfNAMJAGYCBQxib3Jyb3dBbW91bnQAAAQHcmVxdWVzdAkAuQkCCQDMCAIFBHR5cGUJAMwIAgkApQgBCAUBaQZjYWxsZXIJAMwIAgUEcG9vbAkAzAgCCQCkAwEFBHBtdEEJAMwIAgUJcG10QXNzZXRBCQDMCAIJAKQDAQUEcG10QgkAzAgCBQlwbXRBc3NldEIJAMwIAgkApAMBBQRiYWxBCQDMCAIJAKQDAQUEYmFsQgkAzAgCBQdzaGFyZUlkCQDMCAIJAKQDAQUTdmlydHVhbFN3YXBUb2tlblBheQkAzAgCCQCkAwEFE3ZpcnR1YWxTd2FwVG9rZW5HZXQFA25pbAIBLAQMbmV3UmVxdWVzdElkCgABQAkA/AcEBQR0aGlzAhBjcmVhdGVOZXdSZXF1ZXN0CQDMCAIFB3JlcXVlc3QFA25pbAUDbmlsAwkAAQIFAUACA0ludAUBQAUEdW5pdAMJAAACBQxuZXdSZXF1ZXN0SWQFDG5ld1JlcXVlc3RJZAQEYXJncwkAzAgCCQClCAEIBQFpBmNhbGxlcgkAzAgCBQdzaGFyZUlkCQDMCAIFDWJvcnJvd0Fzc2V0SWQJAMwIAgUMYm9ycm93QW1vdW50CQDMCAIJAKUIAQUEdGhpcwkAzAgCAhFyZXBsYW5pc2hGcm9tTGFuZAkAzAgCCQCkAwEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgUMbmV3UmVxdWVzdElkAhhDYW4ndCBjcmVhdGUgbmV3IHJlcXVlc3QFA25pbAQDaW52CQD9BwQJAQ5nZXRMZW5kU3J2QWRkcgACDWZsYXNoUG9zaXRpb24FBGFyZ3MFA25pbAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAwkAAAIFBHR5cGUFC1NGX1BPU19UWVBFCQEPcmVwbGFuaXNoU3dvcEZpDAkApQgBCAUBaQZjYWxsZXIFBHBvb2wHBQRwbXRBBQlwbXRBc3NldEEFBHBtdEIFCXBtdEFzc2V0QgUEYmFsQQUEYmFsQgUHc2hhcmVJZAUTdmlydHVhbFN3YXBUb2tlblBheQUTdmlydHVhbFN3YXBUb2tlbkdldAkAAgECB0NhbnQgd3gBaQERcmVwbGFuaXNoRnJvbUxhbmQBCXJlcXVlc3RJZAQHcmVxdWVzdAkAtQkCCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwkArAICBQlyZXF1ZXN0SWQFCmtSZXF1ZXN0SWQJAKwCAgITTm8gcmVxdWVzdCB3aXRoIGlkIAUJcmVxdWVzdElkAgEsAwkAAAIJAJEDAgUHcmVxdWVzdAAABQtTRl9QT1NfVFlQRQkBD3JlcGxhbmlzaFN3b3BGaQwJAJEDAgUHcmVxdWVzdAABCQCRAwIFB3JlcXVlc3QAAgYJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQdyZXF1ZXN0AAMJAJEDAgUHcmVxdWVzdAAECQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHcmVxdWVzdAAFCQCRAwIFB3JlcXVlc3QABgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB3JlcXVlc3QABwkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB3JlcXVlc3QACAkAkQMCBQdyZXF1ZXN0AAkJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQdyZXF1ZXN0AAoJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQdyZXF1ZXN0AAsJAAIBAgdDYW50IHd4AWkBEGNyZWF0ZU5ld1JlcXVlc3QBBnBhcmFtcwkBC3ZhbHVlT3JFbHNlAgkBCmlzU2VsZkNhbGwBBQFpBAxuZXdSZXF1ZXN0SWQJAGQCCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFDGtSZXF1ZXN0SXRlcgAAAAEJAJQKAgkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKQDAQUMbmV3UmVxdWVzdElkBQprUmVxdWVzdElkBQZwYXJhbXMFA25pbAUMbmV3UmVxdWVzdElkAWkBC2luaXROZXdQb29sBQR0eXBlCHBvb2xBZGRyC2luRmVlTm9Mb2FuCWluRmVlTG9hbgZjYXBGZWUDAwkBAiE9AgUEdHlwZQULU0ZfUE9TX1RZUEUJAQIhPQIFBHR5cGUFC1dYX1BPU19UWVBFBwkAAgECCldyb25nIHR5cGUJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUIcG9vbEFkZHIFFWtBeGx5SW5GZWVXaXRob3V0TG9hbgULaW5GZWVOb0xvYW4JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUIcG9vbEFkZHIFEmtBeGx5SW5GZWVXaXRoTG9hbgUJaW5GZWVMb2FuCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFCHBvb2xBZGRyBQtrQXhseUNhcEZlZQUGY2FwRmVlCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgUFa1Bvb2wFCHBvb2xBZGRyBQR0eXBlBQNuaWwBAnR4AQZ2ZXJpZnkACQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V53uEfpQ==", "height": 2504445, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: JDJUwqzx3X8AZzceH5WkHVYC7py7GgEWMUHWASuwdeaa Next: EYSe4yqpqsKyjx66dkvo7jievyXE2wKAyLtZp4B3AQwx Diff:
Old | New | Differences | |
---|---|---|---|
106 | 106 | ||
107 | 107 | func replanishSwopFi (user,pool,withLoan,pmtA,pmtAssetA,pmtB,pmtAssetB,balA,balB,shareId,virtualSwapTokenPay,virtualSwapTokenGet) = { | |
108 | 108 | let shareBalanceBefore = accountBalance(fromBase58String(shareId)) | |
109 | - | let poolAddr = Address(fromBase58String(pool)) | |
110 | - | let ratioA = fraction(SCALE8, pmtA, balA) | |
111 | - | let ratioB = fraction(SCALE8, pmtB, balB) | |
112 | - | let $t045444837 = if ((ratioB > ratioA)) | |
113 | - | then { | |
114 | - | let pmt = fraction(balB, ratioA, SCALE8, CEILING) | |
115 | - | $Tuple4(pmtA, pmt, (pmtB - pmt), pmtAssetB) | |
116 | - | } | |
109 | + | if ((1 == 1)) | |
110 | + | then throw(((shareId + "|| ") + toString(shareBalanceBefore))) | |
117 | 111 | else { | |
118 | - | let pmt = fraction(balA, ratioB, SCALE8, CEILING) | |
119 | - | $Tuple4(pmt, pmtB, (pmtA - pmt), pmtAssetA) | |
120 | - | } | |
121 | - | let pmtAmountA = $t045444837._1 | |
122 | - | let pmtAmountB = $t045444837._2 | |
123 | - | let change = $t045444837._3 | |
124 | - | let changeAssetId = $t045444837._4 | |
125 | - | let poolVersion = getStringValue(poolAddr, "version") | |
126 | - | let inv1 = if (if ((pmtAmountA > 0)) | |
127 | - | then (pmtAmountB > 0) | |
128 | - | else false) | |
129 | - | then { | |
130 | - | let payments = [AttachedPayment(assetIdFromStr(pmtAssetA), pmtAmountA), AttachedPayment(assetIdFromStr(pmtAssetB), pmtAmountB)] | |
131 | - | if ((poolVersion == "1.0.0")) | |
132 | - | then invoke(poolAddr, "callFunction", ["replenishWithTwoTokens", ["false", "0"]], payments) | |
133 | - | else if ((poolVersion == "2.0.0")) | |
134 | - | then invoke(poolAddr, "replenishWithTwoTokensV2", [false, 0], payments) | |
135 | - | else throw("Wrong pool type") | |
136 | - | } | |
137 | - | else 0 | |
138 | - | if ((inv1 == inv1)) | |
139 | - | then { | |
140 | - | let inv2 = if ((change > 0)) | |
112 | + | let poolAddr = Address(fromBase58String(pool)) | |
113 | + | let ratioA = fraction(SCALE8, pmtA, balA) | |
114 | + | let ratioB = fraction(SCALE8, pmtB, balB) | |
115 | + | let $t046194912 = if ((ratioB > ratioA)) | |
141 | 116 | then { | |
142 | - | let payments = [AttachedPayment(assetIdFromStr(changeAssetId), change)] | |
117 | + | let pmt = fraction(balB, ratioA, SCALE8, CEILING) | |
118 | + | $Tuple4(pmtA, pmt, (pmtB - pmt), pmtAssetB) | |
119 | + | } | |
120 | + | else { | |
121 | + | let pmt = fraction(balA, ratioB, SCALE8, CEILING) | |
122 | + | $Tuple4(pmt, pmtB, (pmtA - pmt), pmtAssetA) | |
123 | + | } | |
124 | + | let pmtAmountA = $t046194912._1 | |
125 | + | let pmtAmountB = $t046194912._2 | |
126 | + | let change = $t046194912._3 | |
127 | + | let changeAssetId = $t046194912._4 | |
128 | + | let poolVersion = getStringValue(poolAddr, "version") | |
129 | + | let inv1 = if (if ((pmtAmountA > 0)) | |
130 | + | then (pmtAmountB > 0) | |
131 | + | else false) | |
132 | + | then { | |
133 | + | let payments = [AttachedPayment(assetIdFromStr(pmtAssetA), pmtAmountA), AttachedPayment(assetIdFromStr(pmtAssetB), pmtAmountB)] | |
143 | 134 | if ((poolVersion == "1.0.0")) | |
144 | - | then { | |
145 | - | let vars = ["0", "false", "0"] | |
146 | - | invoke(poolAddr, "callFunction", ["replenishWithOneToken", vars], payments) | |
147 | - | } | |
135 | + | then invoke(poolAddr, "callFunction", ["replenishWithTwoTokens", ["false", "0"]], payments) | |
148 | 136 | else if ((poolVersion == "2.0.0")) | |
149 | - | then { | |
150 | - | let vars = [virtualSwapTokenPay, virtualSwapTokenGet, false, 0] | |
151 | - | invoke(poolAddr, "replenishWithOneTokenV2", [false, 0], payments) | |
152 | - | } | |
137 | + | then invoke(poolAddr, "replenishWithTwoTokensV2", [false, 0], payments) | |
153 | 138 | else throw("Wrong pool type") | |
154 | 139 | } | |
155 | 140 | else 0 | |
156 | - | if (( | |
141 | + | if ((inv1 == inv1)) | |
157 | 142 | then { | |
158 | - | let shareBalanceAfter = accountBalance(fromBase58String(shareId)) | |
159 | - | let totalShare = (shareBalanceAfter - shareBalanceBefore) | |
160 | - | let axlyInFee = fraction(totalShare, (FEE_SCALE6 - getAxlyInFee(pool, withLoan)), FEE_SCALE6) | |
161 | - | let userShareForStake = (totalShare - axlyInFee) | |
162 | - | if ((0 >= userShareForStake)) | |
163 | - | then throw("amount of staked sharetokens must be > 0") | |
164 | - | else { | |
165 | - | let inv3 = invoke(getSFFarmingAddr(), "lockShareTokens", [pool, 0], [AttachedPayment(fromBase58String(shareId), userShareForStake)]) | |
166 | - | if ((inv3 == inv3)) | |
143 | + | let inv2 = if ((change > 0)) | |
144 | + | then { | |
145 | + | let payments = [AttachedPayment(assetIdFromStr(changeAssetId), change)] | |
146 | + | if ((poolVersion == "1.0.0")) | |
167 | 147 | then { | |
168 | - | let totalAmount = getAxlyTotalPosition(pool) | |
169 | - | let newPosNum = getNewUserPositionNumber(pool, user) | |
148 | + | let vars = ["0", "false", "0"] | |
149 | + | invoke(poolAddr, "callFunction", ["replenishWithOneToken", vars], payments) | |
150 | + | } | |
151 | + | else if ((poolVersion == "2.0.0")) | |
152 | + | then { | |
153 | + | let vars = [virtualSwapTokenPay, virtualSwapTokenGet, false, 0] | |
154 | + | invoke(poolAddr, "replenishWithOneTokenV2", [false, 0], payments) | |
155 | + | } | |
156 | + | else throw("Wrong pool type") | |
157 | + | } | |
158 | + | else 0 | |
159 | + | if ((inv2 == inv2)) | |
160 | + | then { | |
161 | + | let shareBalanceAfter = accountBalance(fromBase58String(shareId)) | |
162 | + | let totalShare = (shareBalanceAfter - shareBalanceBefore) | |
163 | + | let axlyInFee = fraction(totalShare, (FEE_SCALE6 - getAxlyInFee(pool, withLoan)), FEE_SCALE6) | |
164 | + | let userShareForStake = (totalShare - axlyInFee) | |
165 | + | if ((0 >= userShareForStake)) | |
166 | + | then throw("amount of staked sharetokens must be > 0") | |
167 | + | else { | |
168 | + | let inv3 = invoke(getSFFarmingAddr(), "lockShareTokens", [pool, 0], [AttachedPayment(fromBase58String(shareId), userShareForStake)]) | |
169 | + | if ((inv3 == inv3)) | |
170 | + | then { | |
171 | + | let totalAmount = getAxlyTotalPosition(pool) | |
172 | + | let newPosNum = getNewUserPositionNumber(pool, user) | |
170 | 173 | [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))] | |
174 | + | } | |
175 | + | else throw("Strict value is not equal to itself.") | |
171 | 176 | } | |
172 | - | else throw("Strict value is not equal to itself.") | |
173 | 177 | } | |
178 | + | else throw("Strict value is not equal to itself.") | |
174 | 179 | } | |
175 | 180 | else throw("Strict value is not equal to itself.") | |
176 | 181 | } | |
177 | - | else throw("Strict value is not equal to itself.") | |
178 | 182 | } | |
179 | 183 | ||
180 | 184 | ||
184 | 188 | @Callable(i) | |
185 | 189 | func replanish (pool,borrowAmount,borrowAssetId,virtualSwapTokenPay,virtualSwapTokenGet) = { | |
186 | 190 | let type = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited") | |
187 | - | let $ | |
191 | + | let $t076587909 = if ((type == SF_POS_TYPE)) | |
188 | 192 | then getSFPoolData(Address(fromBase58String(pool))) | |
189 | 193 | else if ((type == WX_POS_TYPE)) | |
190 | 194 | then getWXPoolData(Address(fromBase58String(pool))) | |
191 | 195 | else throw("Wrong pool type") | |
192 | - | let AId = $ | |
193 | - | let BId = $ | |
194 | - | let balA = $ | |
195 | - | let balB = $ | |
196 | - | let shareId = $ | |
197 | - | let $ | |
196 | + | let AId = $t076587909._1 | |
197 | + | let BId = $t076587909._2 | |
198 | + | let balA = $t076587909._3 | |
199 | + | let balB = $t076587909._4 | |
200 | + | let shareId = $t076587909._5 | |
201 | + | let $t079138550 = if ((size(i.payments) == 2)) | |
198 | 202 | then if ((assetIdToStr(i.payments[0].assetId) != AId)) | |
199 | 203 | then throw("Wrong payment asset A") | |
200 | 204 | else if ((assetIdToStr(i.payments[1].assetId) != BId)) | |
207 | 211 | then $Tuple4(0, AId, i.payments[0].amount, BId) | |
208 | 212 | else throw("Wrong payment") | |
209 | 213 | else throw("One or two payments expected") | |
210 | - | let pmtA = $ | |
211 | - | let pmtAssetA = $ | |
212 | - | let pmtB = $ | |
213 | - | let pmtAssetB = $ | |
214 | + | let pmtA = $t079138550._1 | |
215 | + | let pmtAssetA = $t079138550._2 | |
216 | + | let pmtB = $t079138550._3 | |
217 | + | let pmtAssetB = $t079138550._4 | |
214 | 218 | if ((borrowAmount > 0)) | |
215 | 219 | then { | |
216 | 220 | let request = makeString([type, toString(i.caller), pool, toString(pmtA), pmtAssetA, toString(pmtB), pmtAssetB, toString(balA), toString(balB), shareId, toString(virtualSwapTokenPay), toString(virtualSwapTokenGet)], ",") |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let SF_POS_TYPE = "SF" | |
5 | 5 | ||
6 | 6 | let WX_POS_TYPE = "WX" | |
7 | 7 | ||
8 | 8 | let SCALE8 = 100000000 | |
9 | 9 | ||
10 | 10 | let FEE_SCALE6 = 1000000 | |
11 | 11 | ||
12 | 12 | let kSFPoolAAssetBalance = "A_asset_balance" | |
13 | 13 | ||
14 | 14 | let kSFPoolBAssetBalance = "B_asset_balance" | |
15 | 15 | ||
16 | 16 | let kSFPoolAAssetId = "A_asset_id" | |
17 | 17 | ||
18 | 18 | let kSFPoolBAssetId = "B_asset_id" | |
19 | 19 | ||
20 | 20 | let kSFPoolShareId = "share_asset_id" | |
21 | 21 | ||
22 | 22 | let kSFPoolVersion = "version" | |
23 | 23 | ||
24 | 24 | let kSFFarmingStaked = "_share_tokens_locked" | |
25 | 25 | ||
26 | 26 | let kUserPosition = "_user_position" | |
27 | 27 | ||
28 | 28 | let kUserPositionType = "_user_position_type" | |
29 | 29 | ||
30 | 30 | let kUserPositionNum = "_user_position_number" | |
31 | 31 | ||
32 | 32 | let kTotalPosition = "_total_position" | |
33 | 33 | ||
34 | 34 | let kAxlyInFeeWithoutLoan = "_axly_fee_without_loan" | |
35 | 35 | ||
36 | 36 | let kAxlyInFeeWithLoan = "_axly_fee_with_loan" | |
37 | 37 | ||
38 | 38 | let kAxlyCapFee = "_axly_fee_cap" | |
39 | 39 | ||
40 | 40 | let kRequestId = "_request_id" | |
41 | 41 | ||
42 | 42 | let kRequestIter = "requests_iter" | |
43 | 43 | ||
44 | 44 | let kPool = "pool_" | |
45 | 45 | ||
46 | 46 | let kMoneyBox = "axly_money_box" | |
47 | 47 | ||
48 | 48 | let kSFFarmingAddr = "swopfi_farming_addr" | |
49 | 49 | ||
50 | 50 | let kLendService = "lend_service_addr" | |
51 | 51 | ||
52 | 52 | let moneyBox = Address(fromBase58String(valueOrErrorMessage(getString(this, kMoneyBox), "No axly moneyBox address"))) | |
53 | 53 | ||
54 | 54 | func isSelfCall (i) = if ((i.caller == this)) | |
55 | 55 | then unit | |
56 | 56 | else throw("Only contract itself can call this function") | |
57 | 57 | ||
58 | 58 | ||
59 | 59 | func accountBalance (assetId) = match assetId { | |
60 | 60 | case id: ByteVector => | |
61 | 61 | assetBalance(this, id) | |
62 | 62 | case waves: Unit => | |
63 | 63 | wavesBalance(this).available | |
64 | 64 | case _ => | |
65 | 65 | throw("Match error") | |
66 | 66 | } | |
67 | 67 | ||
68 | 68 | ||
69 | 69 | 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")) | |
70 | 70 | ||
71 | 71 | ||
72 | 72 | 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")) | |
73 | 73 | ||
74 | 74 | ||
75 | 75 | func getAxlyTotalPosition (pool) = valueOrElse(getInteger(this, (pool + kTotalPosition)), 0) | |
76 | 76 | ||
77 | 77 | ||
78 | 78 | func getNewUserPositionNumber (pool,user) = (valueOrElse(getInteger(this, (((pool + "_") + user) + kUserPositionNum)), 0) + 1) | |
79 | 79 | ||
80 | 80 | ||
81 | 81 | func getAxlyInFee (pool,withLoan) = if (withLoan) | |
82 | 82 | then getIntegerValue(this, (pool + kAxlyInFeeWithLoan)) | |
83 | 83 | else getIntegerValue(this, (pool + kAxlyInFeeWithoutLoan)) | |
84 | 84 | ||
85 | 85 | ||
86 | 86 | func getSFFarmingAddr () = Address(fromBase58String(valueOrErrorMessage(getString(this, kSFFarmingAddr), "Can't get swopfi farming addr"))) | |
87 | 87 | ||
88 | 88 | ||
89 | 89 | func getLendSrvAddr () = Address(fromBase58String(valueOrErrorMessage(getString(this, kLendService), "Can't get lend service addr"))) | |
90 | 90 | ||
91 | 91 | ||
92 | 92 | func assetIdToStr (assetId) = match assetId { | |
93 | 93 | case id: ByteVector => | |
94 | 94 | toBase58String(id) | |
95 | 95 | case waves: Unit => | |
96 | 96 | "WAVES" | |
97 | 97 | case _ => | |
98 | 98 | throw("Match error") | |
99 | 99 | } | |
100 | 100 | ||
101 | 101 | ||
102 | 102 | func assetIdFromStr (assetId) = if ((assetId == "WAVES")) | |
103 | 103 | then unit | |
104 | 104 | else fromBase58String(assetId) | |
105 | 105 | ||
106 | 106 | ||
107 | 107 | func replanishSwopFi (user,pool,withLoan,pmtA,pmtAssetA,pmtB,pmtAssetB,balA,balB,shareId,virtualSwapTokenPay,virtualSwapTokenGet) = { | |
108 | 108 | let shareBalanceBefore = accountBalance(fromBase58String(shareId)) | |
109 | - | let poolAddr = Address(fromBase58String(pool)) | |
110 | - | let ratioA = fraction(SCALE8, pmtA, balA) | |
111 | - | let ratioB = fraction(SCALE8, pmtB, balB) | |
112 | - | let $t045444837 = if ((ratioB > ratioA)) | |
113 | - | then { | |
114 | - | let pmt = fraction(balB, ratioA, SCALE8, CEILING) | |
115 | - | $Tuple4(pmtA, pmt, (pmtB - pmt), pmtAssetB) | |
116 | - | } | |
109 | + | if ((1 == 1)) | |
110 | + | then throw(((shareId + "|| ") + toString(shareBalanceBefore))) | |
117 | 111 | else { | |
118 | - | let pmt = fraction(balA, ratioB, SCALE8, CEILING) | |
119 | - | $Tuple4(pmt, pmtB, (pmtA - pmt), pmtAssetA) | |
120 | - | } | |
121 | - | let pmtAmountA = $t045444837._1 | |
122 | - | let pmtAmountB = $t045444837._2 | |
123 | - | let change = $t045444837._3 | |
124 | - | let changeAssetId = $t045444837._4 | |
125 | - | let poolVersion = getStringValue(poolAddr, "version") | |
126 | - | let inv1 = if (if ((pmtAmountA > 0)) | |
127 | - | then (pmtAmountB > 0) | |
128 | - | else false) | |
129 | - | then { | |
130 | - | let payments = [AttachedPayment(assetIdFromStr(pmtAssetA), pmtAmountA), AttachedPayment(assetIdFromStr(pmtAssetB), pmtAmountB)] | |
131 | - | if ((poolVersion == "1.0.0")) | |
132 | - | then invoke(poolAddr, "callFunction", ["replenishWithTwoTokens", ["false", "0"]], payments) | |
133 | - | else if ((poolVersion == "2.0.0")) | |
134 | - | then invoke(poolAddr, "replenishWithTwoTokensV2", [false, 0], payments) | |
135 | - | else throw("Wrong pool type") | |
136 | - | } | |
137 | - | else 0 | |
138 | - | if ((inv1 == inv1)) | |
139 | - | then { | |
140 | - | let inv2 = if ((change > 0)) | |
112 | + | let poolAddr = Address(fromBase58String(pool)) | |
113 | + | let ratioA = fraction(SCALE8, pmtA, balA) | |
114 | + | let ratioB = fraction(SCALE8, pmtB, balB) | |
115 | + | let $t046194912 = if ((ratioB > ratioA)) | |
141 | 116 | then { | |
142 | - | let payments = [AttachedPayment(assetIdFromStr(changeAssetId), change)] | |
117 | + | let pmt = fraction(balB, ratioA, SCALE8, CEILING) | |
118 | + | $Tuple4(pmtA, pmt, (pmtB - pmt), pmtAssetB) | |
119 | + | } | |
120 | + | else { | |
121 | + | let pmt = fraction(balA, ratioB, SCALE8, CEILING) | |
122 | + | $Tuple4(pmt, pmtB, (pmtA - pmt), pmtAssetA) | |
123 | + | } | |
124 | + | let pmtAmountA = $t046194912._1 | |
125 | + | let pmtAmountB = $t046194912._2 | |
126 | + | let change = $t046194912._3 | |
127 | + | let changeAssetId = $t046194912._4 | |
128 | + | let poolVersion = getStringValue(poolAddr, "version") | |
129 | + | let inv1 = if (if ((pmtAmountA > 0)) | |
130 | + | then (pmtAmountB > 0) | |
131 | + | else false) | |
132 | + | then { | |
133 | + | let payments = [AttachedPayment(assetIdFromStr(pmtAssetA), pmtAmountA), AttachedPayment(assetIdFromStr(pmtAssetB), pmtAmountB)] | |
143 | 134 | if ((poolVersion == "1.0.0")) | |
144 | - | then { | |
145 | - | let vars = ["0", "false", "0"] | |
146 | - | invoke(poolAddr, "callFunction", ["replenishWithOneToken", vars], payments) | |
147 | - | } | |
135 | + | then invoke(poolAddr, "callFunction", ["replenishWithTwoTokens", ["false", "0"]], payments) | |
148 | 136 | else if ((poolVersion == "2.0.0")) | |
149 | - | then { | |
150 | - | let vars = [virtualSwapTokenPay, virtualSwapTokenGet, false, 0] | |
151 | - | invoke(poolAddr, "replenishWithOneTokenV2", [false, 0], payments) | |
152 | - | } | |
137 | + | then invoke(poolAddr, "replenishWithTwoTokensV2", [false, 0], payments) | |
153 | 138 | else throw("Wrong pool type") | |
154 | 139 | } | |
155 | 140 | else 0 | |
156 | - | if (( | |
141 | + | if ((inv1 == inv1)) | |
157 | 142 | then { | |
158 | - | let shareBalanceAfter = accountBalance(fromBase58String(shareId)) | |
159 | - | let totalShare = (shareBalanceAfter - shareBalanceBefore) | |
160 | - | let axlyInFee = fraction(totalShare, (FEE_SCALE6 - getAxlyInFee(pool, withLoan)), FEE_SCALE6) | |
161 | - | let userShareForStake = (totalShare - axlyInFee) | |
162 | - | if ((0 >= userShareForStake)) | |
163 | - | then throw("amount of staked sharetokens must be > 0") | |
164 | - | else { | |
165 | - | let inv3 = invoke(getSFFarmingAddr(), "lockShareTokens", [pool, 0], [AttachedPayment(fromBase58String(shareId), userShareForStake)]) | |
166 | - | if ((inv3 == inv3)) | |
143 | + | let inv2 = if ((change > 0)) | |
144 | + | then { | |
145 | + | let payments = [AttachedPayment(assetIdFromStr(changeAssetId), change)] | |
146 | + | if ((poolVersion == "1.0.0")) | |
167 | 147 | then { | |
168 | - | let totalAmount = getAxlyTotalPosition(pool) | |
169 | - | let newPosNum = getNewUserPositionNumber(pool, user) | |
148 | + | let vars = ["0", "false", "0"] | |
149 | + | invoke(poolAddr, "callFunction", ["replenishWithOneToken", vars], payments) | |
150 | + | } | |
151 | + | else if ((poolVersion == "2.0.0")) | |
152 | + | then { | |
153 | + | let vars = [virtualSwapTokenPay, virtualSwapTokenGet, false, 0] | |
154 | + | invoke(poolAddr, "replenishWithOneTokenV2", [false, 0], payments) | |
155 | + | } | |
156 | + | else throw("Wrong pool type") | |
157 | + | } | |
158 | + | else 0 | |
159 | + | if ((inv2 == inv2)) | |
160 | + | then { | |
161 | + | let shareBalanceAfter = accountBalance(fromBase58String(shareId)) | |
162 | + | let totalShare = (shareBalanceAfter - shareBalanceBefore) | |
163 | + | let axlyInFee = fraction(totalShare, (FEE_SCALE6 - getAxlyInFee(pool, withLoan)), FEE_SCALE6) | |
164 | + | let userShareForStake = (totalShare - axlyInFee) | |
165 | + | if ((0 >= userShareForStake)) | |
166 | + | then throw("amount of staked sharetokens must be > 0") | |
167 | + | else { | |
168 | + | let inv3 = invoke(getSFFarmingAddr(), "lockShareTokens", [pool, 0], [AttachedPayment(fromBase58String(shareId), userShareForStake)]) | |
169 | + | if ((inv3 == inv3)) | |
170 | + | then { | |
171 | + | let totalAmount = getAxlyTotalPosition(pool) | |
172 | + | let newPosNum = getNewUserPositionNumber(pool, user) | |
170 | 173 | [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))] | |
174 | + | } | |
175 | + | else throw("Strict value is not equal to itself.") | |
171 | 176 | } | |
172 | - | else throw("Strict value is not equal to itself.") | |
173 | 177 | } | |
178 | + | else throw("Strict value is not equal to itself.") | |
174 | 179 | } | |
175 | 180 | else throw("Strict value is not equal to itself.") | |
176 | 181 | } | |
177 | - | else throw("Strict value is not equal to itself.") | |
178 | 182 | } | |
179 | 183 | ||
180 | 184 | ||
181 | 185 | func replanishWX (user,pool,withLoan,pmtA,pmtAssetA,pmtB,pmtAssetB,balA,balB,shareId,virtualSwapTokenPay,virtualSwapTokenGet) = nil | |
182 | 186 | ||
183 | 187 | ||
184 | 188 | @Callable(i) | |
185 | 189 | func replanish (pool,borrowAmount,borrowAssetId,virtualSwapTokenPay,virtualSwapTokenGet) = { | |
186 | 190 | let type = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited") | |
187 | - | let $ | |
191 | + | let $t076587909 = if ((type == SF_POS_TYPE)) | |
188 | 192 | then getSFPoolData(Address(fromBase58String(pool))) | |
189 | 193 | else if ((type == WX_POS_TYPE)) | |
190 | 194 | then getWXPoolData(Address(fromBase58String(pool))) | |
191 | 195 | else throw("Wrong pool type") | |
192 | - | let AId = $ | |
193 | - | let BId = $ | |
194 | - | let balA = $ | |
195 | - | let balB = $ | |
196 | - | let shareId = $ | |
197 | - | let $ | |
196 | + | let AId = $t076587909._1 | |
197 | + | let BId = $t076587909._2 | |
198 | + | let balA = $t076587909._3 | |
199 | + | let balB = $t076587909._4 | |
200 | + | let shareId = $t076587909._5 | |
201 | + | let $t079138550 = if ((size(i.payments) == 2)) | |
198 | 202 | then if ((assetIdToStr(i.payments[0].assetId) != AId)) | |
199 | 203 | then throw("Wrong payment asset A") | |
200 | 204 | else if ((assetIdToStr(i.payments[1].assetId) != BId)) | |
201 | 205 | then throw("Wrong payment asset B") | |
202 | 206 | else $Tuple4(i.payments[0].amount, AId, i.payments[1].amount, BId) | |
203 | 207 | else if ((size(i.payments) == 1)) | |
204 | 208 | then if ((assetIdToStr(i.payments[0].assetId) == AId)) | |
205 | 209 | then $Tuple4(i.payments[0].amount, AId, 0, BId) | |
206 | 210 | else if ((assetIdToStr(i.payments[0].assetId) == BId)) | |
207 | 211 | then $Tuple4(0, AId, i.payments[0].amount, BId) | |
208 | 212 | else throw("Wrong payment") | |
209 | 213 | else throw("One or two payments expected") | |
210 | - | let pmtA = $ | |
211 | - | let pmtAssetA = $ | |
212 | - | let pmtB = $ | |
213 | - | let pmtAssetB = $ | |
214 | + | let pmtA = $t079138550._1 | |
215 | + | let pmtAssetA = $t079138550._2 | |
216 | + | let pmtB = $t079138550._3 | |
217 | + | let pmtAssetB = $t079138550._4 | |
214 | 218 | if ((borrowAmount > 0)) | |
215 | 219 | then { | |
216 | 220 | let request = makeString([type, toString(i.caller), pool, toString(pmtA), pmtAssetA, toString(pmtB), pmtAssetB, toString(balA), toString(balB), shareId, toString(virtualSwapTokenPay), toString(virtualSwapTokenGet)], ",") | |
217 | 221 | let newRequestId = { | |
218 | 222 | let @ = invoke(this, "createNewRequest", [request], nil) | |
219 | 223 | if ($isInstanceOf(@, "Int")) | |
220 | 224 | then @ | |
221 | 225 | else unit | |
222 | 226 | } | |
223 | 227 | if ((newRequestId == newRequestId)) | |
224 | 228 | then { | |
225 | 229 | let args = [toString(i.caller), shareId, borrowAssetId, borrowAmount, toString(this), "replanishFromLand", toString(valueOrErrorMessage(newRequestId, "Can't create new request"))] | |
226 | 230 | let inv = reentrantInvoke(getLendSrvAddr(), "flashPosition", args, nil) | |
227 | 231 | nil | |
228 | 232 | } | |
229 | 233 | else throw("Strict value is not equal to itself.") | |
230 | 234 | } | |
231 | 235 | else if ((type == SF_POS_TYPE)) | |
232 | 236 | then replanishSwopFi(toString(i.caller), pool, false, pmtA, pmtAssetA, pmtB, pmtAssetB, balA, balB, shareId, virtualSwapTokenPay, virtualSwapTokenGet) | |
233 | 237 | else throw("Cant wx") | |
234 | 238 | } | |
235 | 239 | ||
236 | 240 | ||
237 | 241 | ||
238 | 242 | @Callable(i) | |
239 | 243 | func replanishFromLand (requestId) = { | |
240 | 244 | let request = split(valueOrErrorMessage(getString(this, (requestId + kRequestId)), ("No request with id " + requestId)), ",") | |
241 | 245 | if ((request[0] == SF_POS_TYPE)) | |
242 | 246 | 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])) | |
243 | 247 | else throw("Cant wx") | |
244 | 248 | } | |
245 | 249 | ||
246 | 250 | ||
247 | 251 | ||
248 | 252 | @Callable(i) | |
249 | 253 | func createNewRequest (params) = valueOrElse(isSelfCall(i), { | |
250 | 254 | let newRequestId = (valueOrElse(getInteger(this, kRequestIter), 0) + 1) | |
251 | 255 | $Tuple2([StringEntry((toString(newRequestId) + kRequestId), params)], newRequestId) | |
252 | 256 | }) | |
253 | 257 | ||
254 | 258 | ||
255 | 259 | ||
256 | 260 | @Callable(i) | |
257 | 261 | func initNewPool (type,poolAddr,inFeeNoLoan,inFeeLoan,capFee) = if (if ((type != SF_POS_TYPE)) | |
258 | 262 | then (type != WX_POS_TYPE) | |
259 | 263 | else false) | |
260 | 264 | then throw("Wrong type") | |
261 | 265 | else [IntegerEntry((poolAddr + kAxlyInFeeWithoutLoan), inFeeNoLoan), IntegerEntry((poolAddr + kAxlyInFeeWithLoan), inFeeLoan), IntegerEntry((poolAddr + kAxlyCapFee), capFee), StringEntry((kPool + poolAddr), type)] | |
262 | 266 | ||
263 | 267 | ||
264 | 268 | @Verifier(tx) | |
265 | 269 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
266 | 270 |
github/deemru/w8io/026f985 61.43 ms ◑