tx · B93DcNShwWkxiNkKoHtqXpezfyEHzC8rECREnTTLjy65

3PKkojKdd6BBzTf1RXbQVfUDraNFXXHKzQF:  -0.01600000 Waves

2023.04.14 13:10 [3599700] smart account 3PKkojKdd6BBzTf1RXbQVfUDraNFXXHKzQF > SELF 0.00000000 Waves

{ "type": 13, "id": "B93DcNShwWkxiNkKoHtqXpezfyEHzC8rECREnTTLjy65", "fee": 1600000, "feeAssetId": null, "timestamp": 1681467062558, "version": 1, "sender": "3PKkojKdd6BBzTf1RXbQVfUDraNFXXHKzQF", "senderPublicKey": "EFvHiEdrRDt5rY98zz2qr96FtqeDuPim2jiQt4kktAEH", "proofs": [ "3msdXG27PwDRnxyyS4z8GBTNc8TQidGZ8rtuah2n2Hm82xkFd5M5V7tDGUD9AYebwTtAY2JR6DudCo7F2frVDj9M" ], "script": "base64:BgIRCAISCAoGCAgCAgICEgMKAQEuAAtQcm90b2NvbFNFUAIBOgADU0VQAgJfXwAScGVyY2VudFByaWNlT2Zmc2V0AF8BCGtleVByaWNlAQZzeW1ib2wJAKwCAgINJXMlc19fcHJpY2VfXwUGc3ltYm9sAQprZXlPcmFjbGVzAAIVJXMlc19fY29uZmlnX19vcmFjbGVzAQxrZXlHcm91cERhdGEBCGdyb3VwTnVtCQCsAgICDSVzJWRfX2dyb3VwX18FCGdyb3VwTnVtAQ9rZXlNaW5Db25zZW5zdXMAAholcyVzX19jb25maWdfX21pbkNvbnNlbnN1cwEPa2V5UHJpY2VGYWlsdXJlAQZzeW1ib2wJALkJAgkAzAgCAhslcyVzJWRfX2ZpbmFsaXphdGlvbkZhaWx1cmUJAMwIAgUGc3ltYm9sCQDMCAIJAKQDAQUGaGVpZ2h0BQNuaWwFA1NFUAENa2V5TGFzdEhlaWdodAEGc3ltYm9sCQCsAgICEiVzJXNfX2xhc3RIZWlnaHRfXwUGc3ltYm9sARBrZXlQcmljZUJ5SGVpZ2h0AgZzeW1ib2wBaAkAuQkCCQDMCAICFSVzJXMlZF9fcHJpY2VCeUhlaWdodAkAzAgCBQZzeW1ib2wJAMwIAgkApAMBBQFoBQNuaWwFA1NFUAEGa2V5SWR4AQZzeW1ib2wJAKwCAgISJXMlc19faWR4Q3VycmVudF9fBQZzeW1ib2wBDWtleUlkeDJIZWlnaHQCBnN5bWJvbANpZHgJALkJAgkAzAgCAhIlcyVzJWRfX2lkeDJIZWlnaHQJAMwIAgUGc3ltYm9sCQDMCAIJAKQDAQUDaWR4BQNuaWwFA1NFUAENa2V5SGVpZ2h0MklkeAIGc3ltYm9sAWgJALkJAgkAzAgCAhIlcyVzJWRfX2hlaWdodDJJZHgJAMwIAgUGc3ltYm9sCQDMCAIJAKQDAQUBaAUDbmlsBQNTRVABDmtleUdyb3VwU3RhdHVzAghncm91cE51bQxmaW5IZWlnaHRTdHIJALkJAgkAzAgCAhMlcyVkJWRfX2dyb3VwU3RhdHVzCQDMCAIFCGdyb3VwTnVtCQDMCAIFDGZpbkhlaWdodFN0cgUDbmlsBQNTRVABEWtleUlzTWFya2V0T3BlbmVkAQZzeW1ib2wJAKwCAgIWJXMlc19faXNNYXJrZXRPcGVuZWRfXwUGc3ltYm9sARBrZXlFbXB0eVByaWNlTXNnAQhwb3NpdGlvbgkAuQkCCQDMCAICFSVzJWQlZF9fZW1wdHlQcmljZU1zZwkAzAgCCQCkAwEFBmhlaWdodAkAzAgCCQCkAwEFCHBvc2l0aW9uBQNuaWwFA1NFUAEMa2V5SXNCbG9ja2VkAQZzeW1ib2wJAKwCAgIRJXMlc19faXNCbG9ja2VkX18FBnN5bWJvbAESa2V5SXNCbG9ja2VkU2VuZGVyAQZzeW1ib2wJALkJAgkAzAgCAhElcyVzJXNfX2lzQmxvY2tlZAkAzAgCBQZzeW1ib2wJAMwIAgIGc2VuZGVyBQNuaWwFA1NFUAESa2V5SXNCbG9ja2VkUmVhc29uAQZzeW1ib2wJALkJAgkAzAgCAhElcyVzJXNfX2lzQmxvY2tlZAkAzAgCBQZzeW1ib2wJAMwIAgIGcmVhc29uBQNuaWwFA1NFUAESa2V5QmxhY2tTd2FybVByaWNlAgFoBnN5bWJvbAkAuQkCCQDMCAICEyVzJXMlcyVkX19pc0Jsb2NrZWQJAMwIAgUGc3ltYm9sCQDMCAICD2JsYWNrU3dhcm1QcmljZQkAzAgCCQCkAwEFAWgFA25pbAUDU0VQAAlEQVlNSUxMSVMAgLiZKQAISDRNSUxMSVMAgPTuBgEIdG9QZXJpb2QCCXRpbWVzdGFtcAZwZXJpb2QJAGgCCQBpAgUJdGltZXN0YW1wBQZwZXJpb2QFBnBlcmlvZAERa2V5U3RhdHMxc3RQZXJpb2QBBnN5bWJvbAkAuQkCCQDMCAICBCVzJXMJAMwIAgIOc3RhdHMxc3RQZXJpb2QJAMwIAgUGc3ltYm9sBQNuaWwFA1NFUAEQa2V5U3RhdHNQcmljZVN1bQEGc3ltYm9sCQC5CQIJAMwIAgIEJXMlcwkAzAgCAg1zdGF0c1ByaWNlU3VtCQDMCAIFBnN5bWJvbAUDbmlsBQNTRVABEGtleVN0YXRzQ291bnRTdW0BBnN5bWJvbAkAuQkCCQDMCAICBCVzJXMJAMwIAgINc3RhdHNDb3VudFN1bQkAzAgCBQZzeW1ib2wFA25pbAUDU0VQARhrZXlTdGF0c0J5UGVyaW9kUHJpY2VTdW0CBnN5bWJvbAZwZXJpb2QJALkJAgkAzAgCAgYlcyVzJWQJAMwIAgINc3RhdHNQcmljZVN1bQkAzAgCBQZzeW1ib2wJAMwIAgUGcGVyaW9kBQNuaWwFA1NFUAEYa2V5U3RhdHNCeVBlcmlvZENvdW50U3VtAgZzeW1ib2wGcGVyaW9kCQC5CQIJAMwIAgIGJXMlcyVkCQDMCAICDXN0YXRzQ291bnRTdW0JAMwIAgUGc3ltYm9sCQDMCAIFBnBlcmlvZAUDbmlsBQNTRVABE2tleVN0YXRzQnlQZXJpb2RNaW4CBnN5bWJvbAZwZXJpb2QJALkJAgkAzAgCAgYlcyVzJWQJAMwIAgINc3RhdHNQcmljZU1pbgkAzAgCBQZzeW1ib2wJAMwIAgUGcGVyaW9kBQNuaWwFA1NFUAETa2V5U3RhdHNCeVBlcmlvZE1heAIGc3ltYm9sBnBlcmlvZAkAuQkCCQDMCAICBiVzJXMlZAkAzAgCAg1zdGF0c1ByaWNlTWF4CQDMCAIFBnN5bWJvbAkAzAgCBQZwZXJpb2QFA25pbAUDU0VQAQpTdGF0c0VudHJ5AgZzeW1ib2wFcHJpY2UEBnBlcmlvZAkBCHRvUGVyaW9kAggFCWxhc3RCbG9jawl0aW1lc3RhbXAFCEg0TUlMTElTBAlwZXJpb2RTdHIJAKQDAQUGcGVyaW9kBBFzdGF0czFzdFBlcmlvZEtFWQkBEWtleVN0YXRzMXN0UGVyaW9kAQUGc3ltYm9sBBBzdGF0c1ByaWNlU3VtS0VZCQEQa2V5U3RhdHNQcmljZVN1bQEFBnN5bWJvbAQQc3RhdHNDb3VudFN1bUtFWQkBEGtleVN0YXRzQ291bnRTdW0BBQZzeW1ib2wEGHN0YXRzQnlQZXJpb2RQcmljZVN1bUtFWQkBGGtleVN0YXRzQnlQZXJpb2RQcmljZVN1bQIFBnN5bWJvbAUJcGVyaW9kU3RyBBhzdGF0c0J5UGVyaW9kQ291bnRTdW1LRVkJARhrZXlTdGF0c0J5UGVyaW9kQ291bnRTdW0CBQZzeW1ib2wFCXBlcmlvZFN0cgQTc3RhdHNCeVBlcmlvZE1pbktFWQkBE2tleVN0YXRzQnlQZXJpb2RNaW4CBQZzeW1ib2wFCXBlcmlvZFN0cgQTc3RhdHNCeVBlcmlvZE1heEtFWQkBE2tleVN0YXRzQnlQZXJpb2RNYXgCBQZzeW1ib2wFCXBlcmlvZFN0cgQNc3RhdHNQcmljZVN1bQkApwMBCQELdmFsdWVPckVsc2UCCQCdCAIFBHRoaXMFEHN0YXRzUHJpY2VTdW1LRVkCATAEDXN0YXRzQ291bnRTdW0JAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUQc3RhdHNDb3VudFN1bUtFWQAABBBzdGF0c0J5UGVyaW9kTWluCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFE3N0YXRzQnlQZXJpb2RNaW5LRVkA96eNr7qTsRAEEHN0YXRzQnlQZXJpb2RNYXgJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUTc3RhdHNCeVBlcmlvZE1heEtFWQAABBBuZXdTdGF0c1ByaWNlU3VtCQC3AgIFDXN0YXRzUHJpY2VTdW0JALYCAQUFcHJpY2UEEG5ld1N0YXRzQ291bnRTdW0JAGQCBQ1zdGF0c0NvdW50U3VtAAEEGG5ld1N0YXRzQnlQZXJpb2RQcmljZVN1bQUQbmV3U3RhdHNQcmljZVN1bQQYbmV3U3RhdHNCeVBlcmlvZENvdW50U3VtBRBuZXdTdGF0c0NvdW50U3VtBBNuZXdTdGF0c0J5UGVyaW9kTWluCQCXAwEJAMwIAgUQc3RhdHNCeVBlcmlvZE1pbgkAzAgCBQVwcmljZQUDbmlsBBNuZXdTdGF0c0J5UGVyaW9kTWF4CQCWAwEJAMwIAgUQc3RhdHNCeVBlcmlvZE1heAkAzAgCBQVwcmljZQUDbmlsBA5zdGF0czFzdFBlcmlvZAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBRFzdGF0czFzdFBlcmlvZEtFWQD///////////8BCQDOCAIJAMwIAgkBC1N0cmluZ0VudHJ5AgUQc3RhdHNQcmljZVN1bUtFWQkApgMBBRBuZXdTdGF0c1ByaWNlU3VtCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRBzdGF0c0NvdW50U3VtS0VZBRBuZXdTdGF0c0NvdW50U3VtCQDMCAIJAQtTdHJpbmdFbnRyeQIFGHN0YXRzQnlQZXJpb2RQcmljZVN1bUtFWQkApgMBBRhuZXdTdGF0c0J5UGVyaW9kUHJpY2VTdW0JAMwIAgkBDEludGVnZXJFbnRyeQIFGHN0YXRzQnlQZXJpb2RDb3VudFN1bUtFWQUYbmV3U3RhdHNCeVBlcmlvZENvdW50U3VtCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRNzdGF0c0J5UGVyaW9kTWluS0VZBRNuZXdTdGF0c0J5UGVyaW9kTWluCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRNzdGF0c0J5UGVyaW9kTWF4S0VZBRNuZXdTdGF0c0J5UGVyaW9kTWF4BQNuaWwDCQBmAgAABQ5zdGF0czFzdFBlcmlvZAkAzAgCCQEMSW50ZWdlckVudHJ5AgURc3RhdHMxc3RQZXJpb2RLRVkFBnBlcmlvZAUDbmlsBQNuaWwBEWlzR3JvdXBGaW5hbGFpemVkAghncm91cE51bQxmaW5IZWlnaHRTdHIJAQlpc0RlZmluZWQBCQCbCAIFBHRoaXMJAQ5rZXlHcm91cFN0YXR1cwIFCGdyb3VwTnVtBQxmaW5IZWlnaHRTdHIBE3JlYWRHcm91cERhdGFPckZhaWwBCGdyb3VwTnVtBAFrCQEMa2V5R3JvdXBEYXRhAQUIZ3JvdXBOdW0EDGdyb3VwRGF0YU9wdAkAnQgCBQR0aGlzBQFrAwkBCWlzRGVmaW5lZAEFDGdyb3VwRGF0YU9wdAkBBXZhbHVlAQUMZ3JvdXBEYXRhT3B0CQACAQkArAICAhllbXB0eSBncm91cCBkYXRhIGZvciBrZXk9BQFrABFwdWJLZXlPcmFjbGVzTGlzdAkAtQkCCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzCQEKa2V5T3JhY2xlcwACASwAC29yYWNsZUNvdW50CQCQAwEFEXB1YktleU9yYWNsZXNMaXN0AAxtaW5Db25zZW5zdXMJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBD2tleU1pbkNvbnNlbnN1cwAAAwERUHJpY2VGYWlsZWRSZXN1bHQCBnN5bWJvbANtc2cJAMwIAgkBC1N0cmluZ0VudHJ5AgkBD2tleVByaWNlRmFpbHVyZQEFBnN5bWJvbAUDbXNnBQNuaWwBHnRocm93SW52YWxpZEZpbmFsaXphdGlvbkhlaWdodAEMZmluSGVpZ2h0U3RyCQACAQkArAICCQCsAgIJAKwCAgIkaW52YWxpZCBmaW5hbGl6YXRpb24gaGVpZ2h0OiBoZWlnaHQ9CQCkAwEFBmhlaWdodAIUIGZpbmFsaXphdGlvbkhlaWdodD0FDGZpbkhlaWdodFN0cgEadGhyb3dHcm91cEFscmVhZHlGaW5hbGl6ZWQCCGdyb3VwTnVtDGZpbkhlaWdodFN0cgkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgIUcHJpY2VzIGZvciBncm91cE51bT0FCGdyb3VwTnVtAgQgYXQgBQxmaW5IZWlnaHRTdHICIyBoZWlnaHQgaGF2ZSBiZWVuIGFscmVhZHkgZmluYWxpemVkARx0aHJvd0ludmFsaWRTaWduc1BhcmFtTGVuZ3RoAgNudW0FcGFyYW0JAAIBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgINaW52YWxpZCBzaWducwkApAMBBQNudW0CGCBwYXJhbWV0ZXI6IGFjdHVhbC5zaXplPQkApAMBCQDIAQEFBXBhcmFtAgsgYmFzZTU4VmFsPQkA2AQBBQVwYXJhbQEadGhyb3dPdXRPZlR1cm5GaW5hbGl6YXRpb24ACQACAQkArAICCQCsAgIJAKwCAgIaT3V0IG9mIHR1cm4gZmluYWxpemF0aW9uOiAJAKQDAQUGaGVpZ2h0Ah0gYmxvY2sgc2hvdWxkIGJlIGZpbmFsaXplIGJ5IAkAkQMCBRFwdWJLZXlPcmFjbGVzTGlzdAkAagIFBmhlaWdodAULb3JhY2xlQ291bnQBEXRocm93QmxvY2tlZEVycm9yAAkAAgECMGNvbnRyYWN0IGlzIGJsb2NrZWQgYnkgRU1FUkdFTkNZIFNIVVRET1dOIGFjdGlvbgEKUHJpY2VFbnRyeQMGc3ltYm9sCG5ld1ByaWNlDmlzTWFya2V0T3BlbmVkBANpZHgJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBBmtleUlkeAEFBnN5bWJvbAAABAZuZXdJZHgJAGQCBQNpZHgAAQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBCGtleVByaWNlAQUGc3ltYm9sBQhuZXdQcmljZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBDWtleUxhc3RIZWlnaHQBBQZzeW1ib2wFBmhlaWdodAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBEGtleVByaWNlQnlIZWlnaHQCBQZzeW1ib2wFBmhlaWdodAUIbmV3UHJpY2UJAMwIAgkBDEludGVnZXJFbnRyeQIJAQZrZXlJZHgBBQZzeW1ib2wFBm5ld0lkeAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBDWtleUlkeDJIZWlnaHQCBQZzeW1ib2wFBm5ld0lkeAUGaGVpZ2h0CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQENa2V5SGVpZ2h0MklkeAIFBnN5bWJvbAUGaGVpZ2h0BQZuZXdJZHgJAMwIAgkBDEJvb2xlYW5FbnRyeQIJARFrZXlJc01hcmtldE9wZW5lZAEFBnN5bWJvbAUOaXNNYXJrZXRPcGVuZWQFA25pbAEXZmluYWxpemVVc2RuVXNkdE9uY2hhaW4ABAZzeW1ib2wCCVVTRE4tVVNEVAQGdXNkbklkAixERzJ4RmtQZER3S1VvQmt6R0FoUXRMcFNHemZYTGlDWVBFemVLSDJBZDI0cAQGdXNkdElkAiwzNE45WWNFRVRMV245M3FZUTY0RXNQMXg4OXRTcnVKVTQ0UnJFTVNYWEVQSgQKdXNkbkFtb3VudACAlOvcAwQQd3hQb29sQWRkcmVzc1N0cgIjM1A4S015QUpDUFdOY3llZHFybXlteGFlV29udm1raEdhdXoEDXd4UG9vbEFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQEFEHd4UG9vbEFkZHJlc3NTdHIECyR0MDc1ODA3NzE5CgABQAkA/AcEBQ13eFBvb2xBZGRyZXNzAhxwdXRPbmVUa25WMldpdGhCb251c1JFQURPTkxZCQDMCAIFCnVzZG5BbW91bnQJAMwIAgUGdXNkbklkBQNuaWwFA25pbAMJAAECBQFAAg8oSW50LCBJbnQsIEludCkFAUAJAAIBCQCsAgIJAAMBBQFAAiQgY291bGRuJ3QgYmUgY2FzdCB0byAoSW50LCBJbnQsIEludCkECGxwQW1vdW50CAULJHQwNzU4MDc3MTkCXzEECmZlZUFtb3VudDEIBQskdDA3NTgwNzcxOQJfMgQFYm9udXMIBQskdDA3NTgwNzcxOQJfMwQLJHQwNzcyMjc4NDAKAAFACQD8BwQFDXd4UG9vbEFkZHJlc3MCE2dldE9uZVRrblYyUkVBRE9OTFkJAMwIAgUGdXNkdElkCQDMCAIFCGxwQW1vdW50BQNuaWwFA25pbAMJAAECBQFAAgooSW50LCBJbnQpBQFACQACAQkArAICCQADAQUBQAIfIGNvdWxkbid0IGJlIGNhc3QgdG8gKEludCwgSW50KQQKdXNkdEFtb3VudAgFCyR0MDc3MjI3ODQwAl8xBApmZWVBbW91bnQyCAULJHQwNzcyMjc4NDACXzIECG5ld1ByaWNlCQBrAwUKdXNkdEFtb3VudADAhD0FCnVzZG5BbW91bnQJAM4IAgkBClByaWNlRW50cnkDBQZzeW1ib2wFCG5ld1ByaWNlBgkBClN0YXRzRW50cnkCBQZzeW1ib2wFCG5ld1ByaWNlARlmaW5hbGl6ZVVzZG5Vc2R0T25jaGFpblYyAAQQd2F2ZXNVc2R0UHJpY2VYNgkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwIXJXMlc19fcHJpY2VfX1dBVkVTLVVTRFQEDmV0aFVzZHRQcmljZVg2CQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzAhUlcyVzX19wcmljZV9fRVRILVVTRFQEBnN5bWJvbAIJVVNETi1VU0RUBAh4dG5JZFN0cgIsREcyeEZrUGREd0tVb0JrekdBaFF0THBTR3pmWExpQ1lQRXplS0gyQWQyNHAEBXh0bklkCQDZBAEFCHh0bklkU3RyBAl1c2R0SWRTdHICLDM0TjlZY0VFVExXbjkzcVlRNjRFc1AxeDg5dFNydUpVNDRSckVNU1hYRVBKBAp1c2RuQW1vdW50AICU69wDBBB3eFVzZHRYdG5Qb29sU3RyAiMzUDhLTXlBSkNQV05jeWVkcXJteW14YWVXb252bWtoR2F1egQUd3hVc2R0WHRuUG9vbEFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQEFEHd4VXNkdFh0blBvb2xTdHIECnd4VXNkdFh0blcAQwQLJHQwODU1Mjg3MDAKAAFACQD8BwQFFHd4VXNkdFh0blBvb2xBZGRyZXNzAhxwdXRPbmVUa25WMldpdGhCb251c1JFQURPTkxZCQDMCAIFCnVzZG5BbW91bnQJAMwIAgUIeHRuSWRTdHIFA25pbAUDbmlsAwkAAQIFAUACDyhJbnQsIEludCwgSW50KQUBQAkAAgEJAKwCAgkAAwEFAUACJCBjb3VsZG4ndCBiZSBjYXN0IHRvIChJbnQsIEludCwgSW50KQQIbHBBbW91bnQIBQskdDA4NTUyODcwMAJfMQQKZmVlQW1vdW50MQgFCyR0MDg1NTI4NzAwAl8yBAVib251cwgFCyR0MDg1NTI4NzAwAl8zBAskdDA4NzAzODgzMQoAAUAJAPwHBAUUd3hVc2R0WHRuUG9vbEFkZHJlc3MCE2dldE9uZVRrblYyUkVBRE9OTFkJAMwIAgUJdXNkdElkU3RyCQDMCAIFCGxwQW1vdW50BQNuaWwFA25pbAMJAAECBQFAAgooSW50LCBJbnQpBQFACQACAQkArAICCQADAQUBQAIfIGNvdWxkbid0IGJlIGNhc3QgdG8gKEludCwgSW50KQQKdXNkdEFtb3VudAgFCyR0MDg3MDM4ODMxAl8xBApmZWVBbW91bnQyCAULJHQwODcwMzg4MzECXzIEDnd4VXNkdFh0blByaWNlCQBrAwUKdXNkdEFtb3VudADAhD0FCnVzZG5BbW91bnQEC3d4V2F2ZXNYdG5XAKYEBBF3eFdhdmVzWHRuUG9vbFN0cgIjM1BQWldnRk5SS0hMdk01MXB3UzkzNEM4Vlo3ZDJGNFo1OGcEFXd4V2F2ZXNYdG5Qb29sQWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQURd3hXYXZlc1h0blBvb2xTdHIED3dhdmVzV2F2ZXNYdG5YOAgJAO8HAQUVd3hXYXZlc1h0blBvb2xBZGRyZXNzB3JlZ3VsYXIEDXh0bldhdmVzWHRuWDYJAPAHAgUVd3hXYXZlc1h0blBvb2xBZGRyZXNzBQV4dG5JZAQPd2F2ZXNYdG5QcmljZVg2CQBrAwUNeHRuV2F2ZXNYdG5YNgCAwtcvBQ93YXZlc1dhdmVzWHRuWDgEE3d4V2F2ZXNVc2R0WHRuUHJpY2UJAGsDBRB3YXZlc1VzZHRQcmljZVg2AMCEPQUPd2F2ZXNYdG5QcmljZVg2BAl3eEV0aFh0blcABQQIZXRoSWRTdHICLDQ3NGpUZVl4MnIyVmEzNTc5NHRDU2NBWFdKRzloVTJIY2d4ek1vd2FaVW51BAVldGhJZAkA2QQBBQhldGhJZFN0cgQPd3hFdGhYdG5Qb29sU3RyAiMzUEVNcWV0c2FKRGJZTXcxWEdvdm1FMzdGQjhWVWhHblg5QQQTd3hFdGhYdG5Qb29sQWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQUPd3hFdGhYdG5Qb29sU3RyBAtldGhFdGhYdG5YOAkA8AcCBRN3eEV0aFh0blBvb2xBZGRyZXNzBQVldGhJZAQLeHRuRXRoWHRuWDYJAPAHAgUTd3hFdGhYdG5Qb29sQWRkcmVzcwUFeHRuSWQEDWV0aFh0blByaWNlWDYJAGsDBQt4dG5FdGhYdG5YNgCAwtcvBQtldGhFdGhYdG5YOAQRd3hFdGhVc2R0WHRuUHJpY2UJAGsDBQ5ldGhVc2R0UHJpY2VYNgDAhD0FDWV0aFh0blByaWNlWDYED3N3b3BmaVdhdmVzWHRuVwDCAwQKc3dvcGZpUmVzdAkBEUBleHRyTmF0aXZlKDEwNjIpAQIjM1A1NmpOUXpFQ1hucldwbmJiU0pLdzdFb29vNmZrVWFNUHAEFXN3b3BmaVdhdmVzWHRuUHJpY2VYNgoAAUAJAPwHBAUKc3dvcGZpUmVzdAIRY2FsY0dldEFtb3VudENQTU0JAMwIAgIjM1BIYU5nb21Ca3J2RUwyUW51SmFyUVZKYTcxd2p3OXFpcUcJAMwIAgIjM1BRSENUcWZ6RThlMUpvOG0xUVZhQ1hBVFNLeU1ta1lhc0YJAMwIAgIFV0FWRVMJAMwIAgCAwtcvBQNuaWwFA25pbAMJAAECBQFAAgNJbnQFAUAJAAIBCQCsAgIJAAMBBQFAAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQEF3N3b3BmaVdhdmVzVXNkdFh0blByaWNlCQBrAwUQd2F2ZXNVc2R0UHJpY2VYNgDAhD0FFXN3b3BmaVdhdmVzWHRuUHJpY2VYNgQIbmV3UHJpY2UJAGQCCQBrAwUTd3hXYXZlc1VzZHRYdG5QcmljZQULd3hXYXZlc1h0blcA6AcJAGsDBRdzd29wZmlXYXZlc1VzZHRYdG5QcmljZQUPc3dvcGZpV2F2ZXNYdG5XAOgHCQDOCAIJAQpQcmljZUVudHJ5AwUGc3ltYm9sBQhuZXdQcmljZQYJAQpTdGF0c0VudHJ5AgUGc3ltYm9sBQhuZXdQcmljZQEVZmluYWxpemVQcmljZVYyQ29tbW9uBQhwb3NpdGlvbghncm91cE51bQxncm91cERhdGFTdHIIbXNnQXJyYXkFc2lnbnMECW1zZ09mZnNldAkAaAIFCHBvc2l0aW9uAAMDCQBnAgUJbXNnT2Zmc2V0CQCQAwEFCG1zZ0FycmF5CQDMCAIJAQtTdHJpbmdFbnRyeQIJARBrZXlFbXB0eVByaWNlTXNnAQUIcG9zaXRpb24CE3ByaWNlIGRhdGEgaXMgZW1wdHkFA25pbAQGc3ltYm9sCQCRAwIFCG1zZ0FycmF5CQBkAgUJbXNnT2Zmc2V0AAAEC25ld1ByaWNlU3RyCQCRAwIFCG1zZ0FycmF5CQBkAgUJbXNnT2Zmc2V0AAEEEWlzTWFya2V0T3BlbmVkU3RyCQCRAwIFCG1zZ0FycmF5CQBkAgUJbXNnT2Zmc2V0AAIEC25ld1ByaWNlT3B0CQC2CQEFC25ld1ByaWNlU3RyBBFpc01hcmtldE9wZW5lZE9wdAkAtgkBBRFpc01hcmtldE9wZW5lZFN0cgQEc2lnMAkAyQECBQVzaWducwBABARzaWcxCQDJAQIJAMoBAgUFc2lnbnMAQABABARzaWcyCQDJAQIJAMoBAgUFc2lnbnMAgAEAQAQEc2lnMwkAyQECCQDKAQIFBXNpZ25zAMABAEAEBHNpZzQJAMwBAgUFc2lnbnMAQAQJaXNCbG9ja2VkCQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMJAQxrZXlJc0Jsb2NrZWQBBQZzeW1ib2wHAwkAAAIFBnN5bWJvbAIABQNuaWwDBQlpc0Jsb2NrZWQJARFQcmljZUZhaWxlZFJlc3VsdAIFBnN5bWJvbAkArAICBQZzeW1ib2wCCyBpcyBibG9ja2VkAwkBCGNvbnRhaW5zAgUMZ3JvdXBEYXRhU3RyBQZzeW1ib2wDAwkBCWlzRGVmaW5lZAEFC25ld1ByaWNlT3B0CQEJaXNEZWZpbmVkAQURaXNNYXJrZXRPcGVuZWRPcHQHBAhuZXdQcmljZQkBBXZhbHVlAQULbmV3UHJpY2VPcHQEDmlzTWFya2V0T3BlbmVkAwkAAAIJAQV2YWx1ZQEFEWlzTWFya2V0T3BlbmVkT3B0AAEGBwQLcHJpY2VNc2dTdHIJALkJAgkAzAgCAgtXQVZFUy1ET1JBMgkAzAgCBQhncm91cE51bQkAzAgCCQCkAwEFBmhlaWdodAkAzAgCBQZzeW1ib2wJAMwIAgULbmV3UHJpY2VTdHIJAMwIAgURaXNNYXJrZXRPcGVuZWRTdHIFA25pbAULUHJvdG9jb2xTRVAECHByaWNlTXNnCQCbAwEFC3ByaWNlTXNnU3RyBBJ2ZXJpZmljYXRpb25zQ291bnQJAGQCCQBkAgkAZAIJAGQCAwkAxBMDBQhwcmljZU1zZwUEc2lnMAkA2QQBCQCRAwIFEXB1YktleU9yYWNsZXNMaXN0AAAAAQAAAwkAxBMDBQhwcmljZU1zZwUEc2lnMQkA2QQBCQCRAwIFEXB1YktleU9yYWNsZXNMaXN0AAEAAQAAAwkAxBMDBQhwcmljZU1zZwUEc2lnMgkA2QQBCQCRAwIFEXB1YktleU9yYWNsZXNMaXN0AAIAAQAAAwkAxBMDBQhwcmljZU1zZwUEc2lnMwkA2QQBCQCRAwIFEXB1YktleU9yYWNsZXNMaXN0AAMAAQAAAwkAxBMDBQhwcmljZU1zZwUEc2lnNAkA2QQBCQCRAwIFEXB1YktleU9yYWNsZXNMaXN0AAQAAQAAAwkAZwIFEnZlcmlmaWNhdGlvbnNDb3VudAUMbWluQ29uc2Vuc3VzBAVwcmljZQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEIa2V5UHJpY2UBBQZzeW1ib2wAAAMDCQECIT0CBQVwcmljZQAAAwkAZwIFCG5ld1ByaWNlCQBkAgUFcHJpY2UJAGkCCQBoAgUFcHJpY2UFEnBlcmNlbnRQcmljZU9mZnNldABkBgkAZwIJAGUCBQVwcmljZQkAaQIJAGgCBQVwcmljZQUScGVyY2VudFByaWNlT2Zmc2V0AGQFCG5ld1ByaWNlBwQGcmVhc29uAj9hdXRvbWF0aWMgZW1lcmdlbmN5IHNodXRkb3duIGJlY2F1c2Ugb2YgbGFyZ2UgcHJpY2UgdmFyaWFiaWxpdHkJAMwIAgkBDEJvb2xlYW5FbnRyeQIJAQxrZXlJc0Jsb2NrZWQBBQZzeW1ib2wGCQDMCAIJAQtTdHJpbmdFbnRyeQIJARJrZXlJc0Jsb2NrZWRTZW5kZXIBBQZzeW1ib2wJAKUIAQUEdGhpcwkAzAgCCQELU3RyaW5nRW50cnkCCQESa2V5SXNCbG9ja2VkUmVhc29uAQUGc3ltYm9sBQZyZWFzb24JAMwIAgkBDEludGVnZXJFbnRyeQIJARJrZXlCbGFja1N3YXJtUHJpY2UCBQZoZWlnaHQFBnN5bWJvbAUIbmV3UHJpY2UFA25pbAkAzggCCQEKUHJpY2VFbnRyeQMFBnN5bWJvbAUIbmV3UHJpY2UFDmlzTWFya2V0T3BlbmVkCQEKU3RhdHNFbnRyeQIFBnN5bWJvbAUIbmV3UHJpY2UJARFQcmljZUZhaWxlZFJlc3VsdAIFBnN5bWJvbAkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIVdmVyaWZpY2F0aW9uc0NvdW50ID0gCQCkAwEFEnZlcmlmaWNhdGlvbnNDb3VudAIOc2lnbnMwLmxlbmd0aD0JAKQDAQkAyAEBBQVzaWducwIIIG1zZzAgPSAFC3ByaWNlTXNnU3RyAgggc2lnMCA9IAkA2AQBBQRzaWcwAggga2V5MCA9IAkAkQMCBRFwdWJLZXlPcmFjbGVzTGlzdAAACQERUHJpY2VGYWlsZWRSZXN1bHQCBQZzeW1ib2wJAKwCAgkArAICCQCsAgICHWRhdGEgcGFyc2luZyBlcnJvcjogbmV3UHJpY2U9BQtuZXdQcmljZVN0cgIQIGlzTWFya2V0T3BlbmVkPQURaXNNYXJrZXRPcGVuZWRTdHIJARFQcmljZUZhaWxlZFJlc3VsdAIFBnN5bWJvbAkArAICCQCsAgIFBnN5bWJvbAImIGRvZXNuJ3QgZXhpc3QgaW4gZ3JvdXA6IGdyb3VwRGF0YVN0cj0FDGdyb3VwRGF0YVN0cgIBaQENZmluYWxpemVET1JBMgYGaGVhZGVyA21zZwZzaWduczAGc2lnbnMxBnNpZ25zMgZzaWduczMEC2hlYWRlckFycmF5CQC1CQIFBmhlYWRlcgULUHJvdG9jb2xTRVAECGdyb3VwTnVtCQCRAwIFC2hlYWRlckFycmF5AAEEDGZpbkhlaWdodFN0cgkAkQMCBQtoZWFkZXJBcnJheQACBAlmaW5IZWlnaHQJAQ1wYXJzZUludFZhbHVlAQUMZmluSGVpZ2h0U3RyBAtzaWduc0xlbmd0aAkAaAIAQAULb3JhY2xlQ291bnQDCQECIT0CBQZoZWlnaHQFCWZpbkhlaWdodAkBHnRocm93SW52YWxpZEZpbmFsaXphdGlvbkhlaWdodAEFDGZpbkhlaWdodFN0cgMJARFpc0dyb3VwRmluYWxhaXplZAIFCGdyb3VwTnVtBQxmaW5IZWlnaHRTdHIJARp0aHJvd0dyb3VwQWxyZWFkeUZpbmFsaXplZAIFCGdyb3VwTnVtBQxmaW5IZWlnaHRTdHIDCQECIT0CCQCRAwIFEXB1YktleU9yYWNsZXNMaXN0CQBqAgUGaGVpZ2h0BQtvcmFjbGVDb3VudAkA2AQBCAUBaQ9jYWxsZXJQdWJsaWNLZXkJARp0aHJvd091dE9mVHVybkZpbmFsaXphdGlvbgADCQECIT0CCQDIAQEFBnNpZ25zMAULc2lnbnNMZW5ndGgJARx0aHJvd0ludmFsaWRTaWduc1BhcmFtTGVuZ3RoAgAABQZzaWduczADCQECIT0CCQDIAQEFBnNpZ25zMQULc2lnbnNMZW5ndGgJARx0aHJvd0ludmFsaWRTaWduc1BhcmFtTGVuZ3RoAgABBQZzaWduczEDCQECIT0CCQDIAQEFBnNpZ25zMgULc2lnbnNMZW5ndGgJARx0aHJvd0ludmFsaWRTaWduc1BhcmFtTGVuZ3RoAgACBQZzaWduczIDCQECIT0CCQDIAQEFBnNpZ25zMwULc2lnbnNMZW5ndGgJARx0aHJvd0ludmFsaWRTaWduc1BhcmFtTGVuZ3RoAgADBQZzaWduczMEDGdyb3VwRGF0YUtleQkBDGtleUdyb3VwRGF0YQEFCGdyb3VwTnVtBAxncm91cERhdGFTdHIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQxncm91cERhdGFLZXkJAKwCAgIZZW1wdHkgZ3JvdXAgZGF0YSBmb3Iga2V5PQUMZ3JvdXBEYXRhS2V5BAhtc2dBcnJheQkAtQkCBQNtc2cFC1Byb3RvY29sU0VQAwkBAiE9AgkAagIJAJADAQUIbXNnQXJyYXkAAwAACQACAQkArAICAjptc2cgcGFyYW1ldGVycyBjb3VudCBtdXN0IGJlIG11bHRpcGxlIG9mIDM6IG1zZ0FycmF5LnNpemU9CQCkAwEJALECAQUDbXNnCQDNCAIJAM4IAgkAzggCCQDOCAIJARVmaW5hbGl6ZVByaWNlVjJDb21tb24FAAAFCGdyb3VwTnVtBQxncm91cERhdGFTdHIFCG1zZ0FycmF5BQZzaWduczAJARVmaW5hbGl6ZVByaWNlVjJDb21tb24FAAEFCGdyb3VwTnVtBQxncm91cERhdGFTdHIFCG1zZ0FycmF5BQZzaWduczEJARVmaW5hbGl6ZVByaWNlVjJDb21tb24FAAIFCGdyb3VwTnVtBQxncm91cERhdGFTdHIFCG1zZ0FycmF5BQZzaWduczIDCQAAAgUIZ3JvdXBOdW0CATAJARlmaW5hbGl6ZVVzZG5Vc2R0T25jaGFpblYyAAkBFWZpbmFsaXplUHJpY2VWMkNvbW1vbgUAAwUIZ3JvdXBOdW0FDGdyb3VwRGF0YVN0cgUIbXNnQXJyYXkFBnNpZ25zMwkBDEJvb2xlYW5FbnRyeQIJAQ5rZXlHcm91cFN0YXR1cwIFCGdyb3VwTnVtBQxmaW5IZWlnaHRTdHIGAWkBBXByaWNlAQVob3VycwQGc3ltYm9sAglVU0ROLVVTRFQECnBlcmlvZFNURVAFCEg0TUlMTElTBAhtYXhIb3VycwBQBAVpdGVycwkAzAgCAAAJAMwIAgABCQDMCAIAAgkAzAgCAAMJAMwIAgAECQDMCAIABQkAzAgCAAYJAMwIAgAHCQDMCAIACAkAzAgCAAkJAMwIAgAKCQDMCAIACwkAzAgCAAwJAMwIAgANCQDMCAIADgkAzAgCAA8JAMwIAgAQCQDMCAIAEQkAzAgCABIJAMwIAgATCQDMCAIAFAUDbmlsAwkAZgIFBWhvdXJzBQhtYXhIb3VycwkAAgECHGhvdXJzIGlzIGdyZWF0ZXIgdGhlbiBtYXggODADCQBmAgAEBQVob3VycwkAAgECHmhvdXJzIGlzIGxlc3MgdGhlbiBtaW4gdmFsdWUgNAQIY3VyclRpbWUIBQlsYXN0QmxvY2sJdGltZXN0YW1wBAlzdGFydFRpbWUJAGUCCQBlAgUIY3VyclRpbWUJAGgCBQVob3VycwCA3dsBBQhINE1JTExJUwQGcGVyaW9kCQEIdG9QZXJpb2QCBQhjdXJyVGltZQUKcGVyaW9kU1RFUAQJcGVyaW9kU3RyCQCkAwEFBnBlcmlvZAQOc21hbGxlc3RQZXJpb2QJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJARFrZXlTdGF0czFzdFBlcmlvZAEFBnN5bWJvbAQOc3RhcnRQZXJpb2RUbXAJAQh0b1BlcmlvZAIFCXN0YXJ0VGltZQUKcGVyaW9kU1RFUAQMaXNFbm91Z2hEYXRhCQBnAgUOc3RhcnRQZXJpb2RUbXAFDnNtYWxsZXN0UGVyaW9kBAtzdGFydFBlcmlvZAMFDGlzRW5vdWdoRGF0YQUOc3RhcnRQZXJpb2RUbXAFDnNtYWxsZXN0UGVyaW9kBA5zdGFydFBlcmlvZFN0cgkApAMBBQtzdGFydFBlcmlvZAQOc3RhcnRQcmljZVN1bVgJAKcDAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwkBGGtleVN0YXRzQnlQZXJpb2RQcmljZVN1bQIFBnN5bWJvbAUOc3RhcnRQZXJpb2RTdHIEDXN0YXJ0Q291bnRTdW0JARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJARhrZXlTdGF0c0J5UGVyaW9kQ291bnRTdW0CBQZzeW1ib2wFDnN0YXJ0UGVyaW9kU3RyBAxlbmRQcmljZVN1bVgDBQxpc0Vub3VnaERhdGEJAKcDAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwkBGGtleVN0YXRzQnlQZXJpb2RQcmljZVN1bQIFBnN5bWJvbAUJcGVyaW9kU3RyCQC2AgEAAAQLZW5kQ291bnRTdW0DBQxpc0Vub3VnaERhdGEJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJARhrZXlTdGF0c0J5UGVyaW9kQ291bnRTdW0CBQZzeW1ib2wFCXBlcmlvZFN0cgAABAhwcmljZVN1bQkAoAMBCQC4AgIFDGVuZFByaWNlU3VtWAUOc3RhcnRQcmljZVN1bVgECnByaWNlQ291bnQJAGUCBQtlbmRDb3VudFN1bQUNc3RhcnRDb3VudFN1bQQIcHJpY2VBdmcJAGkCBQhwcmljZVN1bQUKcHJpY2VDb3VudAMJAGcCAAAFCHByaWNlQXZnCQACAQIRY2FsY3VsYXRpb24gZXJyb3IKAQpmaW5kTWluTWF4AgltaW5BbmRNYXgHbmV4dElkeAQNcGVyaW9kVG9DaGVjawkAZQIFBnBlcmlvZAkAaAIFB25leHRJZHgFCnBlcmlvZFNURVADCQBmAgULc3RhcnRQZXJpb2QFDXBlcmlvZFRvQ2hlY2sFCW1pbkFuZE1heAQQcGVyaW9kVG9DaGVja1N0cgkApAMBBQ1wZXJpb2RUb0NoZWNrBAZtaW5WYWwIBQltaW5BbmRNYXgCXzEEBm1heFZhbAgFCW1pbkFuZE1heAJfMgQJbmV3TWluVmFsCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQETa2V5U3RhdHNCeVBlcmlvZE1pbgIFBnN5bWJvbAUQcGVyaW9kVG9DaGVja1N0cgQJbmV3TWF4VmFsCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQETa2V5U3RhdHNCeVBlcmlvZE1heAIFBnN5bWJvbAUQcGVyaW9kVG9DaGVja1N0cgkAlAoCCQCXAwEJAMwIAgUGbWluVmFsCQDMCAIFCW5ld01pblZhbAUDbmlsCQCWAwEJAMwIAgUGbWF4VmFsCQDMCAIFCW5ld01heFZhbAUDbmlsBAVwcmljZQkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkBCGtleVByaWNlAQUGc3ltYm9sBAxtaW5NYXhTVFJVQ1QKAAIkbAUFaXRlcnMKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCUCgIA96eNr7qTsRAAAAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEKZmluZE1pbk1heAIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMjEJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwADQAOAA8AEAARABIAEwAUABUJAJQKAgUDbmlsCQCWCgQFBXByaWNlBQhwcmljZUF2ZwgFDG1pbk1heFNUUlVDVAJfMQgFDG1pbk1heFNUUlVDVAJfMgCs67Od", "chainId": 87, "height": 3599700, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 8dRMQSFDWtp9yE35Pb3y7CA7a75gDGWZXd3Tzxw877m3 Next: 2D2FurfXN8RioYkQR1BfC7WadTmbE9gqegfJL5mPK3cQ Diff:
OldNewDifferences
214214 let aN = aZ._1
215215 let aO = aZ._2
216216 let ba = fraction(aN, 1000000, aE)
217- let bb = 487
217+ let bb = 550
218218 let bc = "3PPZWgFNRKHLvM51pwS934C8VZ7d2F4Z58g"
219219 let bd = addressFromStringValue(bc)
220220 let be = wavesBalance(bd).regular
230230 let bo = assetBalance(bm, aT)
231231 let bp = fraction(bo, 100000000, bn)
232232 let bq = fraction(aR, 1000000, bp)
233- let br = 433
233+ let br = 450
234234 let bs = addressFromStringValue("3P56jNQzECXnrWpnbbSJKw7Eooo6fkUaMPp")
235235 let bt = {
236236 let aI = invoke(bs, "calcGetAmountCPMM", ["3PHaNgomBkrvEL2QnuJarQVJa71wjw9qiqG", "3PQHCTqfzE8e1Jo8m1QVaCXATSKyMmkYasF", "WAVES", 100000000], nil)
239239 else throw(($getType(aI) + " couldn't be cast to Int"))
240240 }
241241 let bu = fraction(aQ, 1000000, bt)
242- let ay = (((fraction(ba, aX, 1000) + fraction(bh, bb, 1000)) + fraction(bq, bi, 1000)) + fraction(bu, br, 1000))
242+ let ay = (fraction(bh, bb, 1000) + fraction(bu, br, 1000))
243243 (ax(e, ay, true) ++ M(e, ay))
244244 }
245245
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let a = ":"
55
66 let b = "__"
77
88 let c = 95
99
1010 func d (e) = ("%s%s__price__" + e)
1111
1212
1313 func f () = "%s%s__config__oracles"
1414
1515
1616 func g (h) = ("%s%d__group__" + h)
1717
1818
1919 func i () = "%s%s__config__minConsensus"
2020
2121
2222 func j (e) = makeString(["%s%s%d__finalizationFailure", e, toString(height)], b)
2323
2424
2525 func k (e) = ("%s%s__lastHeight__" + e)
2626
2727
2828 func l (e,m) = makeString(["%s%s%d__priceByHeight", e, toString(m)], b)
2929
3030
3131 func n (e) = ("%s%s__idxCurrent__" + e)
3232
3333
3434 func o (e,p) = makeString(["%s%s%d__idx2Height", e, toString(p)], b)
3535
3636
3737 func q (e,m) = makeString(["%s%s%d__height2Idx", e, toString(m)], b)
3838
3939
4040 func r (h,s) = makeString(["%s%d%d__groupStatus", h, s], b)
4141
4242
4343 func t (e) = ("%s%s__isMarketOpened__" + e)
4444
4545
4646 func u (v) = makeString(["%s%d%d__emptyPriceMsg", toString(height), toString(v)], b)
4747
4848
4949 func w (e) = ("%s%s__isBlocked__" + e)
5050
5151
5252 func x (e) = makeString(["%s%s%s__isBlocked", e, "sender"], b)
5353
5454
5555 func y (e) = makeString(["%s%s%s__isBlocked", e, "reason"], b)
5656
5757
5858 func z (m,e) = makeString(["%s%s%s%d__isBlocked", e, "blackSwarmPrice", toString(m)], b)
5959
6060
6161 let A = 86400000
6262
6363 let B = 14400000
6464
6565 func C (D,E) = ((D / E) * E)
6666
6767
6868 func F (e) = makeString(["%s%s", "stats1stPeriod", e], b)
6969
7070
7171 func G (e) = makeString(["%s%s", "statsPriceSum", e], b)
7272
7373
7474 func H (e) = makeString(["%s%s", "statsCountSum", e], b)
7575
7676
7777 func I (e,E) = makeString(["%s%s%d", "statsPriceSum", e, E], b)
7878
7979
8080 func J (e,E) = makeString(["%s%s%d", "statsCountSum", e, E], b)
8181
8282
8383 func K (e,E) = makeString(["%s%s%d", "statsPriceMin", e, E], b)
8484
8585
8686 func L (e,E) = makeString(["%s%s%d", "statsPriceMax", e, E], b)
8787
8888
8989 func M (e,N) = {
9090 let E = C(lastBlock.timestamp, B)
9191 let O = toString(E)
9292 let P = F(e)
9393 let Q = G(e)
9494 let R = H(e)
9595 let S = I(e, O)
9696 let T = J(e, O)
9797 let U = K(e, O)
9898 let V = L(e, O)
9999 let W = parseBigIntValue(valueOrElse(getString(this, Q), "0"))
100100 let X = valueOrElse(getInteger(this, R), 0)
101101 let Y = valueOrElse(getInteger(this, U), 9223372036854775)
102102 let Z = valueOrElse(getInteger(this, V), 0)
103103 let aa = (W + toBigInt(N))
104104 let ab = (X + 1)
105105 let ac = aa
106106 let ad = ab
107107 let ae = min([Y, N])
108108 let af = max([Z, N])
109109 let ag = valueOrElse(getInteger(this, P), -1)
110110 ([StringEntry(Q, toString(aa)), IntegerEntry(R, ab), StringEntry(S, toString(ac)), IntegerEntry(T, ad), IntegerEntry(U, ae), IntegerEntry(V, af)] ++ (if ((0 > ag))
111111 then [IntegerEntry(P, E)]
112112 else nil))
113113 }
114114
115115
116116 func ah (h,s) = isDefined(getBoolean(this, r(h, s)))
117117
118118
119119 func ai (h) = {
120120 let aj = g(h)
121121 let ak = getString(this, aj)
122122 if (isDefined(ak))
123123 then value(ak)
124124 else throw(("empty group data for key=" + aj))
125125 }
126126
127127
128128 let al = split(getStringValue(this, f()), ",")
129129
130130 let am = size(al)
131131
132132 let an = valueOrElse(getInteger(this, i()), 3)
133133
134134 func ao (e,ap) = [StringEntry(j(e), ap)]
135135
136136
137137 func aq (s) = throw(((("invalid finalization height: height=" + toString(height)) + " finalizationHeight=") + s))
138138
139139
140140 func ar (h,s) = throw((((("prices for groupNum=" + h) + " at ") + s) + " height have been already finalized"))
141141
142142
143143 func as (at,au) = throw(((((("invalid signs" + toString(at)) + " parameter: actual.size=") + toString(size(au))) + " base58Val=") + toBase58String(au)))
144144
145145
146146 func av () = throw(((("Out of turn finalization: " + toString(height)) + " block should be finalize by ") + al[(height % am)]))
147147
148148
149149 func aw () = throw("contract is blocked by EMERGENCY SHUTDOWN action")
150150
151151
152152 func ax (e,ay,az) = {
153153 let p = valueOrElse(getInteger(this, n(e)), 0)
154154 let aA = (p + 1)
155155 [IntegerEntry(d(e), ay), IntegerEntry(k(e), height), IntegerEntry(l(e, height), ay), IntegerEntry(n(e), aA), IntegerEntry(o(e, aA), height), IntegerEntry(q(e, height), aA), BooleanEntry(t(e), az)]
156156 }
157157
158158
159159 func aB () = {
160160 let e = "USDN-USDT"
161161 let aC = "DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p"
162162 let aD = "34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ"
163163 let aE = 1000000000
164164 let aF = "3P8KMyAJCPWNcyedqrmymxaeWonvmkhGauz"
165165 let aG = addressFromStringValue(aF)
166166 let aH = {
167167 let aI = invoke(aG, "putOneTknV2WithBonusREADONLY", [aE, aC], nil)
168168 if ($isInstanceOf(aI, "(Int, Int, Int)"))
169169 then aI
170170 else throw(($getType(aI) + " couldn't be cast to (Int, Int, Int)"))
171171 }
172172 let aJ = aH._1
173173 let aK = aH._2
174174 let aL = aH._3
175175 let aM = {
176176 let aI = invoke(aG, "getOneTknV2READONLY", [aD, aJ], nil)
177177 if ($isInstanceOf(aI, "(Int, Int)"))
178178 then aI
179179 else throw(($getType(aI) + " couldn't be cast to (Int, Int)"))
180180 }
181181 let aN = aM._1
182182 let aO = aM._2
183183 let ay = fraction(aN, 1000000, aE)
184184 (ax(e, ay, true) ++ M(e, ay))
185185 }
186186
187187
188188 func aP () = {
189189 let aQ = getIntegerValue(this, "%s%s__price__WAVES-USDT")
190190 let aR = getIntegerValue(this, "%s%s__price__ETH-USDT")
191191 let e = "USDN-USDT"
192192 let aS = "DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p"
193193 let aT = fromBase58String(aS)
194194 let aU = "34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ"
195195 let aE = 1000000000
196196 let aV = "3P8KMyAJCPWNcyedqrmymxaeWonvmkhGauz"
197197 let aW = addressFromStringValue(aV)
198198 let aX = 67
199199 let aY = {
200200 let aI = invoke(aW, "putOneTknV2WithBonusREADONLY", [aE, aS], nil)
201201 if ($isInstanceOf(aI, "(Int, Int, Int)"))
202202 then aI
203203 else throw(($getType(aI) + " couldn't be cast to (Int, Int, Int)"))
204204 }
205205 let aJ = aY._1
206206 let aK = aY._2
207207 let aL = aY._3
208208 let aZ = {
209209 let aI = invoke(aW, "getOneTknV2READONLY", [aU, aJ], nil)
210210 if ($isInstanceOf(aI, "(Int, Int)"))
211211 then aI
212212 else throw(($getType(aI) + " couldn't be cast to (Int, Int)"))
213213 }
214214 let aN = aZ._1
215215 let aO = aZ._2
216216 let ba = fraction(aN, 1000000, aE)
217- let bb = 487
217+ let bb = 550
218218 let bc = "3PPZWgFNRKHLvM51pwS934C8VZ7d2F4Z58g"
219219 let bd = addressFromStringValue(bc)
220220 let be = wavesBalance(bd).regular
221221 let bf = assetBalance(bd, aT)
222222 let bg = fraction(bf, 100000000, be)
223223 let bh = fraction(aQ, 1000000, bg)
224224 let bi = 5
225225 let bj = "474jTeYx2r2Va35794tCScAXWJG9hU2HcgxzMowaZUnu"
226226 let bk = fromBase58String(bj)
227227 let bl = "3PEMqetsaJDbYMw1XGovmE37FB8VUhGnX9A"
228228 let bm = addressFromStringValue(bl)
229229 let bn = assetBalance(bm, bk)
230230 let bo = assetBalance(bm, aT)
231231 let bp = fraction(bo, 100000000, bn)
232232 let bq = fraction(aR, 1000000, bp)
233- let br = 433
233+ let br = 450
234234 let bs = addressFromStringValue("3P56jNQzECXnrWpnbbSJKw7Eooo6fkUaMPp")
235235 let bt = {
236236 let aI = invoke(bs, "calcGetAmountCPMM", ["3PHaNgomBkrvEL2QnuJarQVJa71wjw9qiqG", "3PQHCTqfzE8e1Jo8m1QVaCXATSKyMmkYasF", "WAVES", 100000000], nil)
237237 if ($isInstanceOf(aI, "Int"))
238238 then aI
239239 else throw(($getType(aI) + " couldn't be cast to Int"))
240240 }
241241 let bu = fraction(aQ, 1000000, bt)
242- let ay = (((fraction(ba, aX, 1000) + fraction(bh, bb, 1000)) + fraction(bq, bi, 1000)) + fraction(bu, br, 1000))
242+ let ay = (fraction(bh, bb, 1000) + fraction(bu, br, 1000))
243243 (ax(e, ay, true) ++ M(e, ay))
244244 }
245245
246246
247247 func bv (v,h,bw,bx,by) = {
248248 let bz = (v * 3)
249249 if ((bz >= size(bx)))
250250 then [StringEntry(u(v), "price data is empty")]
251251 else {
252252 let e = bx[(bz + 0)]
253253 let bA = bx[(bz + 1)]
254254 let bB = bx[(bz + 2)]
255255 let bC = parseInt(bA)
256256 let bD = parseInt(bB)
257257 let bE = take(by, 64)
258258 let bF = take(drop(by, 64), 64)
259259 let bG = take(drop(by, 128), 64)
260260 let bH = take(drop(by, 192), 64)
261261 let bI = takeRight(by, 64)
262262 let bJ = valueOrElse(getBoolean(this, w(e)), false)
263263 if ((e == ""))
264264 then nil
265265 else if (bJ)
266266 then ao(e, (e + " is blocked"))
267267 else if (contains(bw, e))
268268 then if (if (isDefined(bC))
269269 then isDefined(bD)
270270 else false)
271271 then {
272272 let ay = value(bC)
273273 let az = if ((value(bD) == 1))
274274 then true
275275 else false
276276 let bK = makeString(["WAVES-DORA2", h, toString(height), e, bA, bB], a)
277277 let bL = toBytes(bK)
278278 let bM = (((((if (sigVerify_8Kb(bL, bE, fromBase58String(al[0])))
279279 then 1
280280 else 0) + (if (sigVerify_8Kb(bL, bF, fromBase58String(al[1])))
281281 then 1
282282 else 0)) + (if (sigVerify_8Kb(bL, bG, fromBase58String(al[2])))
283283 then 1
284284 else 0)) + (if (sigVerify_8Kb(bL, bH, fromBase58String(al[3])))
285285 then 1
286286 else 0)) + (if (sigVerify_8Kb(bL, bI, fromBase58String(al[4])))
287287 then 1
288288 else 0))
289289 if ((bM >= an))
290290 then {
291291 let N = valueOrElse(getInteger(this, d(e)), 0)
292292 if (if ((N != 0))
293293 then if ((ay >= (N + ((N * c) / 100))))
294294 then true
295295 else ((N - ((N * c) / 100)) >= ay)
296296 else false)
297297 then {
298298 let bN = "automatic emergency shutdown because of large price variability"
299299 [BooleanEntry(w(e), true), StringEntry(x(e), toString(this)), StringEntry(y(e), bN), IntegerEntry(z(height, e), ay)]
300300 }
301301 else (ax(e, ay, az) ++ M(e, ay))
302302 }
303303 else ao(e, ((((((((("verificationsCount = " + toString(bM)) + "signs0.length=") + toString(size(by))) + " msg0 = ") + bK) + " sig0 = ") + toBase58String(bE)) + " key0 = ") + al[0]))
304304 }
305305 else ao(e, ((("data parsing error: newPrice=" + bA) + " isMarketOpened=") + bB))
306306 else ao(e, ((e + " doesn't exist in group: groupDataStr=") + bw))
307307 }
308308 }
309309
310310
311311 @Callable(bO)
312312 func finalizeDORA2 (bP,ap,bQ,bR,bS,bT) = {
313313 let bU = split(bP, a)
314314 let h = bU[1]
315315 let s = bU[2]
316316 let bV = parseIntValue(s)
317317 let bW = (64 * am)
318318 if ((height != bV))
319319 then aq(s)
320320 else if (ah(h, s))
321321 then ar(h, s)
322322 else if ((al[(height % am)] != toBase58String(bO.callerPublicKey)))
323323 then av()
324324 else if ((size(bQ) != bW))
325325 then as(0, bQ)
326326 else if ((size(bR) != bW))
327327 then as(1, bR)
328328 else if ((size(bS) != bW))
329329 then as(2, bS)
330330 else if ((size(bT) != bW))
331331 then as(3, bT)
332332 else {
333333 let bX = g(h)
334334 let bw = valueOrErrorMessage(getString(this, bX), ("empty group data for key=" + bX))
335335 let bx = split(ap, a)
336336 if (((size(bx) % 3) != 0))
337337 then throw(("msg parameters count must be multiple of 3: msgArray.size=" + toString(size(ap))))
338338 else ((((bv(0, h, bw, bx, bQ) ++ bv(1, h, bw, bx, bR)) ++ bv(2, h, bw, bx, bS)) ++ (if ((h == "0"))
339339 then aP()
340340 else bv(3, h, bw, bx, bT))) :+ BooleanEntry(r(h, s), true))
341341 }
342342 }
343343
344344
345345
346346 @Callable(bO)
347347 func price (bY) = {
348348 let e = "USDN-USDT"
349349 let bZ = B
350350 let ca = 80
351351 let cb = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20]
352352 if ((bY > ca))
353353 then throw("hours is greater then max 80")
354354 else if ((4 > bY))
355355 then throw("hours is less then min value 4")
356356 else {
357357 let cc = lastBlock.timestamp
358358 let cd = ((cc - (bY * 3600000)) - B)
359359 let E = C(cc, bZ)
360360 let O = toString(E)
361361 let ce = getIntegerValue(this, F(e))
362362 let cf = C(cd, bZ)
363363 let cg = (cf >= ce)
364364 let ch = if (cg)
365365 then cf
366366 else ce
367367 let ci = toString(ch)
368368 let cj = parseBigIntValue(getStringValue(this, I(e, ci)))
369369 let ck = getIntegerValue(this, J(e, ci))
370370 let cl = if (cg)
371371 then parseBigIntValue(getStringValue(this, I(e, O)))
372372 else toBigInt(0)
373373 let cm = if (cg)
374374 then getIntegerValue(this, J(e, O))
375375 else 0
376376 let cn = toInt((cl - cj))
377377 let co = (cm - ck)
378378 let cp = (cn / co)
379379 if ((0 >= cp))
380380 then throw("calculation error")
381381 else {
382382 func cq (cr,cs) = {
383383 let ct = (E - (cs * bZ))
384384 if ((ch > ct))
385385 then cr
386386 else {
387387 let cu = toString(ct)
388388 let cv = cr._1
389389 let cw = cr._2
390390 let cx = getIntegerValue(this, K(e, cu))
391391 let cy = getIntegerValue(this, L(e, cu))
392392 $Tuple2(min([cv, cx]), max([cw, cy]))
393393 }
394394 }
395395
396396 let N = getIntegerValue(this, d(e))
397397 let cz = {
398398 let cA = cb
399399 let cB = size(cA)
400400 let cC = $Tuple2(9223372036854775, 0)
401401 func cD (cE,cF) = if ((cF >= cB))
402402 then cE
403403 else cq(cE, cA[cF])
404404
405405 func cG (cE,cF) = if ((cF >= cB))
406406 then cE
407407 else throw("List size exceeds 21")
408408
409409 cG(cD(cD(cD(cD(cD(cD(cD(cD(cD(cD(cD(cD(cD(cD(cD(cD(cD(cD(cD(cD(cD(cC, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21)
410410 }
411411 $Tuple2(nil, $Tuple4(N, cp, cz._1, cz._2))
412412 }
413413 }
414414 }
415415
416416

github/deemru/w8io/873ac7e 
61.87 ms