tx · G45FACGHTbSxyk6BS568CVQoGS6sycWjbdy8eTuuhZwc 3PNEC4YKqZiMMytFrYRVtpW2ujvi3aGXRPm: -0.01200000 Waves 2022.11.26 01:08 [3398670] smart account 3PNEC4YKqZiMMytFrYRVtpW2ujvi3aGXRPm > SELF 0.00000000 Waves
{ "type": 13, "id": "G45FACGHTbSxyk6BS568CVQoGS6sycWjbdy8eTuuhZwc", "fee": 1200000, "feeAssetId": null, "timestamp": 1669413965633, "version": 2, "chainId": 87, "sender": "3PNEC4YKqZiMMytFrYRVtpW2ujvi3aGXRPm", "senderPublicKey": "6SbbanjpWtV7Z7jfnHEFWaU4WqFvJwbPVWc4KhTULTR2", "proofs": [ "", "3uR8D8qN7ri6pyNBqg57REUSn51RTwrQJ7j4Vw3sWSipGX7AopTzMd7gCWKCHUNZzt9fXUdSHVjTA9GMZXa4Jpud", "UW7HhhyZqa7BZMwjWNpnfHRa5duDGChWWZS6KkpWPDxQsnhqwGtsJz44uzd9WYKUKQfn5VygWNgUdn645Da8sNK" ], "script": "base64:BgIkCAISBAoCCBgSABIAEgUKAwQBCBIDCgEBEgMKAQESABIDCgEBKQAHa0FjdGl2ZQIGYWN0aXZlAAtrQWN0aXZlR2xvYgIUYWN0aXZlX2FsbF9jb250cmFjdHMABmtDYXVzZQIOc2h1dGRvd25fY2F1c2UADGtVU0ROQWRkcmVzcwIYc3Rha2luZ191c2RubnNidF9hZGRyZXNzAAxrRVVSTkFkZHJlc3MCFHN0YWtpbmdfZXVybl9hZGRyZXNzAAxrTGVhc2luZ1Bvb2wCD2xlYXNpbmdfYWRkcmVzcwAOa0xlYXNpbmdBbW91bnQCDmxlYXNpbmdfYW1vdW50AAprTGVhc2luZ0lkAgpsZWFzaW5nX2lkAA1rQWRtaW5QdWJLZXkxAgthZG1pbl9wdWJfMQANa0FkbWluUHViS2V5MgILYWRtaW5fcHViXzIADWtBZG1pblB1YktleTMCC2FkbWluX3B1Yl8zABJrQWRtaW5JbnZva2VQdWJLZXkCEGFkbWluX2ludm9rZV9wdWIADWtDcG1tQ29udHJhY3QCDWNwbW1fY29udHJhY3QADGtVU0ROQXNzZXRJZAINdXNkbl9hc3NldF9pZAAMa0VVUk5Bc3NldElkAg1ldXJuX2Fzc2V0X2lkAA5rU3Rha2luZ0Fzc2V0cwIOc3Rha2luZ19hc3NldHMADWtTaGFyZUFzc2V0SWQCDnNoYXJlX2Fzc2V0X2lkAAZvcmFjbGUJAQdBZGRyZXNzAQEaAVeK/whomjW6QM1hdPISN96mN/D6OM7oHjgBE2dldEJhc2U1OEZyb21PcmFjbGUBA2tleQQHJG1hdGNoMAkAnQgCBQZvcmFjbGUFA2tleQMJAAECBQckbWF0Y2gwAgZTdHJpbmcEBnN0cmluZwUHJG1hdGNoMAkA2QQBBQZzdHJpbmcEB25vdGhpbmcFByRtYXRjaDAJAAIBCQCsAgIFA2tleQIIaXMgZW1wdHkADGFkbWluUHViS2V5MQkBE2dldEJhc2U1OEZyb21PcmFjbGUBBQ1rQWRtaW5QdWJLZXkxAAxhZG1pblB1YktleTIJARNnZXRCYXNlNThGcm9tT3JhY2xlAQUNa0FkbWluUHViS2V5MgAMYWRtaW5QdWJLZXkzCQETZ2V0QmFzZTU4RnJvbU9yYWNsZQEFDWtBZG1pblB1YktleTMAEWFkbWluUHViS2V5SW52b2tlCQETZ2V0QmFzZTU4RnJvbU9yYWNsZQEFEmtBZG1pbkludm9rZVB1YktleQASc3Rha2luZ1VTRE5BZGRyZXNzCQEHQWRkcmVzcwEJARNnZXRCYXNlNThGcm9tT3JhY2xlAQUMa1VTRE5BZGRyZXNzABJzdGFraW5nRVVSTkFkZHJlc3MJAQdBZGRyZXNzAQkBE2dldEJhc2U1OEZyb21PcmFjbGUBBQxrRVVSTkFkZHJlc3MADGNwbW1Db250cmFjdAkBB0FkZHJlc3MBCQETZ2V0QmFzZTU4RnJvbU9yYWNsZQEFDWtDcG1tQ29udHJhY3QABFVTRE4JARNnZXRCYXNlNThGcm9tT3JhY2xlAQUMa1VTRE5Bc3NldElkAARFVVJOCQETZ2V0QmFzZTU4RnJvbU9yYWNsZQEFDGtFVVJOQXNzZXRJZAANc3Rha2luZ0Fzc2V0cwkBEUBleHRyTmF0aXZlKDEwNTMpAgUGb3JhY2xlBQ5rU3Rha2luZ0Fzc2V0cwAKYWN0aXZlR2xvYgkBC3ZhbHVlT3JFbHNlAgkAmwgCBQZvcmFjbGUFC2tBY3RpdmVHbG9iBgAGYWN0aXZlCQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFB2tBY3RpdmUGAQhpc0FjdGl2ZQADAwUGYWN0aXZlBQphY3RpdmVHbG9iBwUEdW5pdAkAAgECH0RBcHAgaXMgaW5hY3RpdmUgYXQgdGhpcyBtb21lbnQBDmlzR2xvYmFsQ2FsbGVyAQZjYWxsZXIDCQAAAgUGY2FsbGVyBQxjcG1tQ29udHJhY3QFBHVuaXQJAAIBAi1Pbmx5IGdsb2JhbCBDb250cmFjdCBjYW4gaW52b2tlIHRoaXMgZnVuY3Rpb24BC2lzQWRtaW5DYWxsAQxjYWxsZXJQdWJLZXkDCQEPY29udGFpbnNFbGVtZW50AgkAzAgCBQxhZG1pblB1YktleTEJAMwIAgUMYWRtaW5QdWJLZXkyCQDMCAIFDGFkbWluUHViS2V5MwUDbmlsBQxjYWxsZXJQdWJLZXkFBHVuaXQJAAIBAiFPbmx5IGFkbWluIGNhbiBjYWxsIHRoaXMgZnVuY3Rpb24BB3N1c3BlbmQBBWNhdXNlCQDMCAIJAQxCb29sZWFuRW50cnkCBQdrQWN0aXZlBwkAzAgCCQELU3RyaW5nRW50cnkCBQZrQ2F1c2UFBWNhdXNlBQNuaWwBGGNhbGNTdGFraW5nRnVuY0FuZEFkZHJlcwIFc3Rha2UHYXNzZXRJZAMFBXN0YWtlAwkAAAIFB2Fzc2V0SWQFBFVTRE4JAJQKAgIMbG9ja05ldXRyaW5vBRJzdGFraW5nVVNETkFkZHJlc3MJAJQKAgIMc3RhcnRTdGFraW5nBRJzdGFraW5nRVVSTkFkZHJlc3MDCQAAAgUHYXNzZXRJZAUEVVNETgkAlAoCAg51bmxvY2tOZXV0cmlubwUSc3Rha2luZ1VTRE5BZGRyZXNzCQCUCgICC3N0b3BTdGFraW5nBRJzdGFraW5nRVVSTkFkZHJlc3MBEWNhbGNTdGFraW5nUGFyYW1zAwVzdGFrZQZhbW91bnQHYXNzZXRJZAMFBXN0YWtlBAskdDAyNTkzMjY1OQkBGGNhbGNTdGFraW5nRnVuY0FuZEFkZHJlcwIFBXN0YWtlBQdhc3NldElkBARjYWxsCAULJHQwMjU5MzI2NTkCXzEEC3N0YWtpbmdBZGRyCAULJHQwMjU5MzI2NTkCXzIJAJYKBAUEY2FsbAULc3Rha2luZ0FkZHIFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUHYXNzZXRJZAUGYW1vdW50BQNuaWwECyR0MDI3NDUyODExCQEYY2FsY1N0YWtpbmdGdW5jQW5kQWRkcmVzAgUFc3Rha2UFB2Fzc2V0SWQEBGNhbGwIBQskdDAyNzQ1MjgxMQJfMQQLc3Rha2luZ0FkZHIIBQskdDAyNzQ1MjgxMQJfMgkAlgoEBQRjYWxsBQtzdGFraW5nQWRkcgkAzAgCBQZhbW91bnQJAMwIAgkA2AQBBQdhc3NldElkBQNuaWwFA25pbAEPY29sbGVjdFBheW1lbnRzAgNhY2MHcGF5bWVudAQLJHQwMjk3MzMwMTYFA2FjYwQOcGF5bWVudEFtb3VudHMIBQskdDAyOTczMzAxNgJfMQQPcGF5bWVudEFzc2V0SWRzCAULJHQwMjk3MzMwMTYCXzIJAJQKAgkAzQgCBQ5wYXltZW50QW1vdW50cwgFB3BheW1lbnQGYW1vdW50CQDNCAIFD3BheW1lbnRBc3NldElkcwMJAAACCAUHcGF5bWVudAdhc3NldElkBQR1bml0AQAIBQdwYXltZW50B2Fzc2V0SWQBDGNvbGxlY3RTdGF0ZQIGcmVzdWx0BnNvdXJjZQQHJG1hdGNoMAUGc291cmNlAwMJAAECBQckbWF0Y2gwAgVJc3N1ZQYDCQABAgUHJG1hdGNoMAIEQnVybgYDCQABAgUHJG1hdGNoMAIHUmVpc3N1ZQYDCQABAgUHJG1hdGNoMAIOU2NyaXB0VHJhbnNmZXIGAwkAAQIFByRtYXRjaDACC0JpbmFyeUVudHJ5BgMJAAECBQckbWF0Y2gwAgxCb29sZWFuRW50cnkGAwkAAQIFByRtYXRjaDACC1N0cmluZ0VudHJ5BgkAAQIFByRtYXRjaDACDEludGVnZXJFbnRyeQQBZQUHJG1hdGNoMAkAzQgCBQZyZXN1bHQFAWUFBnJlc3VsdAELY29sbGVjdERhdGECBnJlc3VsdAZzb3VyY2UEByRtYXRjaDAFBnNvdXJjZQMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXYFByRtYXRjaDAJAM0IAgUGcmVzdWx0BQF2AwkAAQIFByRtYXRjaDACA0ludAQBdgUHJG1hdGNoMAkAzQgCBQZyZXN1bHQFAXYDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBdgUHJG1hdGNoMAkAzQgCBQZyZXN1bHQFAXYDCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQBdgUHJG1hdGNoMAkAzQgCBQZyZXN1bHQFAXYDCQABAgUHJG1hdGNoMAIEVW5pdAQBdgUHJG1hdGNoMAkAzQgCBQZyZXN1bHQFAXYJAQV0aHJvdwABCmNhbGxDb21tb24ECGZ1bmNOYW1lBmNhbGxlcgRhcmdzCHBheW1lbnRzCQELdmFsdWVPckVsc2UCCQEIaXNBY3RpdmUABAskdDAzOTM2NDAyMAoAAiRsBQhwYXltZW50cwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAJAJQKAgUDbmlsBQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBD2NvbGxlY3RQYXltZW50cwIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgQOcGF5bWVudEFtb3VudHMIBQskdDAzOTM2NDAyMAJfMQQPcGF5bWVudEFzc2V0SWRzCAULJHQwMzkzNjQwMjACXzIEC2xvY2tQYXltZW50AwMJAAACBQhmdW5jTmFtZQIWcmVwbGVuaXNoV2l0aFR3b1Rva2VucwkAAAIJAJADAQUIcGF5bWVudHMAAwcJAMwIAgkAkQMCBQhwYXltZW50cwACBQNuaWwDAwkAAAIFCGZ1bmNOYW1lAhVyZXBsZW5pc2hXaXRoT25lVG9rZW4JAAACCQCQAwEFCHBheW1lbnRzAAIHCQDMCAIJAJEDAgUIcGF5bWVudHMAAQUDbmlsBQNuaWwECyR0MDQyNTA0NDA3CgABQAkA/QcEBQxjcG1tQ29udHJhY3QFCGZ1bmNOYW1lCQDMCAIFBmNhbGxlcgkAzAgCBQRhcmdzCQDMCAIFDnBheW1lbnRBbW91bnRzCQDMCAIFD3BheW1lbnRBc3NldElkcwUDbmlsBQtsb2NrUGF5bWVudAMJAAECBQFAAhYoTGlzdFtBbnldLCBMaXN0W0FueV0pBQFACQACAQkArAICCQADAQUBQAIrIGNvdWxkbid0IGJlIGNhc3QgdG8gKExpc3RbQW55XSwgTGlzdFtBbnldKQMJAAACBQskdDA0MjUwNDQwNwULJHQwNDI1MDQ0MDcEBGRhdGEIBQskdDA0MjUwNDQwNwJfMgQHYWN0aW9ucwgFCyR0MDQyNTA0NDA3Al8xBAptYXBwZWREYXRhCgACJGwFBGRhdGEKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjFfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBC2NvbGxlY3REYXRhAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYxXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMAkBBSRmMV8yAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKBA1tYXBwZWRBY3Rpb25zCgACJGwFB2FjdGlvbnMKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjJfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBDGNvbGxlY3RTdGF0ZQIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMl8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTUJAQUkZjJfMgIJAQUkZjJfMQIJAQUkZjJfMQIJAQUkZjJfMQIJAQUkZjJfMQIJAQUkZjJfMQIJAQUkZjJfMQIJAQUkZjJfMQIJAQUkZjJfMQIJAQUkZjJfMQIJAQUkZjJfMQIJAQUkZjJfMQIJAQUkZjJfMQIJAQUkZjJfMQIJAQUkZjJfMQIJAQUkZjJfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwADQAOAA8JAJQKAgUNbWFwcGVkQWN0aW9ucwUKbWFwcGVkRGF0YQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLggBaQEMY2FsbEZ1bmN0aW9uAghmdW5jTmFtZQRhcmdzCQEKY2FsbENvbW1vbgQFCGZ1bmNOYW1lCAgFAWkGY2FsbGVyBWJ5dGVzBQRhcmdzCAUBaQhwYXltZW50cwFpAQhzaHV0ZG93bgAJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEIBQFpD2NhbGxlclB1YmxpY0tleQMJAQEhAQUGYWN0aXZlCQACAQkArAICAiJEQXBwIGlzIGFscmVhZHkgc3VzcGVuZGVkLiBDYXVzZTogCQELdmFsdWVPckVsc2UCCQCdCAIFBHRoaXMFBmtDYXVzZQIadGhlIGNhdXNlIHdhc24ndCBzcGVjaWZpZWQJAQdzdXNwZW5kAQIPUGF1c2VkIGJ5IGFkbWluAWkBCGFjdGl2YXRlAAkBC3ZhbHVlT3JFbHNlAgkBC2lzQWRtaW5DYWxsAQgFAWkPY2FsbGVyUHVibGljS2V5AwUGYWN0aXZlCQACAQIWREFwcCBpcyBhbHJlYWR5IGFjdGl2ZQkAzAgCCQEMQm9vbGVhbkVudHJ5AgUHa0FjdGl2ZQYJAMwIAgkBC0RlbGV0ZUVudHJ5AQUGa0NhdXNlBQNuaWwBaQEMc3Rha2VVbnN0YWtlAwVzdGFrZQZhbW91bnQNYXNzZXRJZFN0cmluZwkBC3ZhbHVlT3JFbHNlAgkBCGlzQWN0aXZlAAMJAQIhPQIIBQFpBmNhbGxlcgUMY3BtbUNvbnRyYWN0CQACAQItT25seSBnbG9iYWwgQ29udHJhY3QgY2FuIGludm9rZSB0aGlzIGZ1bmN0aW9uAwkAAAIFDWFzc2V0SWRTdHJpbmcCBVdBVkVTBARwb29sCQERQGV4dHJOYXRpdmUoMTA2MikBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUGb3JhY2xlBQxrTGVhc2luZ1Bvb2wCGU5vIGxlYXNpbmcgcG9vbCBpbiBvcmFjbGUECWxlYXNpbmdJZAkAnAgCBQR0aGlzBQprTGVhc2luZ0lkBA1sZWFzaW5nQW1vdW50CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFDmtMZWFzaW5nQW1vdW50AAAEDm5ld0xlYXNlQW1vdW50AwUFc3Rha2UJAGQCBQ1sZWFzaW5nQW1vdW50BQZhbW91bnQJAGUCBQ1sZWFzaW5nQW1vdW50BQZhbW91bnQECG5ld0xlYXNlCQDECAIFBHBvb2wFDm5ld0xlYXNlQW1vdW50BApuZXdMZWFzZUlkCQC5CAEFCG5ld0xlYXNlBAhiYXNlRXRyeQkAzAgCBQhuZXdMZWFzZQkAzAgCCQELQmluYXJ5RW50cnkCBQprTGVhc2luZ0lkBQpuZXdMZWFzZUlkCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ5rTGVhc2luZ0Ftb3VudAUObmV3TGVhc2VBbW91bnQFA25pbAQHJG1hdGNoMAUJbGVhc2luZ0lkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEA2xJZAUHJG1hdGNoMAkAzggCCQDMCAIJAQtMZWFzZUNhbmNlbAEFA2xJZAUDbmlsBQhiYXNlRXRyeQUIYmFzZUV0cnkECyR0MDY0MDM2NTA2CQERY2FsY1N0YWtpbmdQYXJhbXMDBQVzdGFrZQUGYW1vdW50CQDZBAEFDWFzc2V0SWRTdHJpbmcEBGNhbGwIBQskdDA2NDAzNjUwNgJfMQQEYWRkcggFCyR0MDY0MDM2NTA2Al8yBAZwYXJhbXMIBQskdDA2NDAzNjUwNgJfMwQIcGF5bWVudHMIBQskdDA2NDAzNjUwNgJfNAQDaW52CQD8BwQFBGFkZHIFBGNhbGwFBnBhcmFtcwUIcGF5bWVudHMDCQAAAgUDaW52BQNpbnYFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARFyZWlzc3VlU2hhcmVUb2tlbgEGYW1vdW50CQELdmFsdWVPckVsc2UCCQEOaXNHbG9iYWxDYWxsZXIBCAUBaQZjYWxsZXIJAQt2YWx1ZU9yRWxzZQIJAQhpc0FjdGl2ZQAEDHNoYXJlQXNzZXRJZAkA2QQBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzBQ1rU2hhcmVBc3NldElkCQDMCAIJAQdSZWlzc3VlAwUMc2hhcmVBc3NldElkBQZhbW91bnQGCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgUGYW1vdW50BQxzaGFyZUFzc2V0SWQFA25pbAFpARZyZXBsZW5pc2hXaXRoVHdvVG9rZW5zARFzbGlwcGFnZVRvbGVyYW5jZQkBCmNhbGxDb21tb24EAhZyZXBsZW5pc2hXaXRoVHdvVG9rZW5zCAgFAWkGY2FsbGVyBWJ5dGVzCQDMCAICBWZhbHNlCQDMCAICATAFA25pbAgFAWkIcGF5bWVudHMBaQEId2l0aGRyYXcACQEKY2FsbENvbW1vbgQCCHdpdGhkcmF3CAgFAWkGY2FsbGVyBWJ5dGVzCQDMCAICATAFA25pbAgFAWkIcGF5bWVudHMBaQEIZXhjaGFuZ2UBEm1pbkFtb3VudFRvUmVjZWl2ZQkBCmNhbGxDb21tb24EAghleGNoYW5nZQgIBQFpBmNhbGxlcgVieXRlcwkAzAgCCQCkAwEFEm1pbkFtb3VudFRvUmVjZWl2ZQUDbmlsCAUBaQhwYXltZW50cwECdHgBBnZlcmlmeQAEE211bHRpU2lnbmVkQnlBZG1pbnMEEmFkbWluUHViS2V5MVNpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAFDGFkbWluUHViS2V5MQABAAAEEmFkbWluUHViS2V5MlNpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAEFDGFkbWluUHViS2V5MgABAAAEEmFkbWluUHViS2V5M1NpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAIFDGFkbWluUHViS2V5MwABAAAJAGcCCQBkAgkAZAIFEmFkbWluUHViS2V5MVNpZ25lZAUSYWRtaW5QdWJLZXkyU2lnbmVkBRJhZG1pblB1YktleTNTaWduZWQAAgUTbXVsdGlTaWduZWRCeUFkbWlucwdfBRo=", "height": 3398670, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 8qWsFUE8uzY9hXZWyvc9LzA5Wfizbz2f5MRFTwuzzXJA Next: 33c1zszyJKSPaqUMbV337mjr33o2nNXwrz57aC9M6G7s Diff:
Old | New | Differences | |
---|---|---|---|
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let kActive = "active" | |
5 | + | ||
6 | + | let kActiveGlob = "active_all_contracts" | |
5 | 7 | ||
6 | 8 | let kCause = "shutdown_cause" | |
7 | 9 | ||
63 | 65 | ||
64 | 66 | let stakingAssets = getStringValue(oracle, kStakingAssets) | |
65 | 67 | ||
68 | + | let activeGlob = valueOrElse(getBoolean(oracle, kActiveGlob), true) | |
69 | + | ||
66 | 70 | let active = valueOrElse(getBoolean(this, kActive), true) | |
67 | 71 | ||
68 | - | func isActive () = if (active) | |
72 | + | func isActive () = if (if (active) | |
73 | + | then activeGlob | |
74 | + | else false) | |
69 | 75 | then unit | |
70 | 76 | else throw("DApp is inactive at this moment") | |
71 | 77 | ||
94 | 100 | ||
95 | 101 | func calcStakingParams (stake,amount,assetId) = if (stake) | |
96 | 102 | then { | |
97 | - | let $ | |
98 | - | let call = $ | |
99 | - | let stakingAddr = $ | |
103 | + | let $t025932659 = calcStakingFuncAndAddres(stake, assetId) | |
104 | + | let call = $t025932659._1 | |
105 | + | let stakingAddr = $t025932659._2 | |
100 | 106 | $Tuple4(call, stakingAddr, nil, [AttachedPayment(assetId, amount)]) | |
101 | 107 | } | |
102 | 108 | else { | |
103 | - | let $ | |
104 | - | let call = $ | |
105 | - | let stakingAddr = $ | |
109 | + | let $t027452811 = calcStakingFuncAndAddres(stake, assetId) | |
110 | + | let call = $t027452811._1 | |
111 | + | let stakingAddr = $t027452811._2 | |
106 | 112 | $Tuple4(call, stakingAddr, [amount, toBase58String(assetId)], nil) | |
107 | 113 | } | |
108 | 114 | ||
109 | 115 | ||
110 | 116 | func collectPayments (acc,payment) = { | |
111 | - | let $ | |
112 | - | let paymentAmounts = $ | |
113 | - | let paymentAssetIds = $ | |
117 | + | let $t029733016 = acc | |
118 | + | let paymentAmounts = $t029733016._1 | |
119 | + | let paymentAssetIds = $t029733016._2 | |
114 | 120 | $Tuple2((paymentAmounts :+ payment.amount), (paymentAssetIds :+ (if ((payment.assetId == unit)) | |
115 | 121 | then base58'' | |
116 | 122 | else payment.assetId))) | |
142 | 148 | ||
143 | 149 | ||
144 | 150 | func callCommon (funcName,caller,args,payments) = valueOrElse(isActive(), { | |
145 | - | let $ | |
151 | + | let $t039364020 = { | |
146 | 152 | let $l = payments | |
147 | 153 | let $s = size($l) | |
148 | 154 | let $acc0 = $Tuple2(nil, nil) | |
156 | 162 | ||
157 | 163 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10) | |
158 | 164 | } | |
159 | - | let paymentAmounts = $t038163900._1 | |
160 | - | let paymentAssetIds = $t038163900._2 | |
161 | - | let $t039054053 = { | |
162 | - | let @ = reentrantInvoke(cpmmContract, funcName, [caller, args, paymentAmounts, paymentAssetIds], nil) | |
165 | + | let paymentAmounts = $t039364020._1 | |
166 | + | let paymentAssetIds = $t039364020._2 | |
167 | + | let lockPayment = if (if ((funcName == "replenishWithTwoTokens")) | |
168 | + | then (size(payments) == 3) | |
169 | + | else false) | |
170 | + | then [payments[2]] | |
171 | + | else if (if ((funcName == "replenishWithOneToken")) | |
172 | + | then (size(payments) == 2) | |
173 | + | else false) | |
174 | + | then [payments[1]] | |
175 | + | else nil | |
176 | + | let $t042504407 = { | |
177 | + | let @ = reentrantInvoke(cpmmContract, funcName, [caller, args, paymentAmounts, paymentAssetIds], lockPayment) | |
163 | 178 | if ($isInstanceOf(@, "(List[Any], List[Any])")) | |
164 | 179 | then @ | |
165 | 180 | else throw(($getType(@) + " couldn't be cast to (List[Any], List[Any])")) | |
166 | 181 | } | |
167 | - | if (($ | |
182 | + | if (($t042504407 == $t042504407)) | |
168 | 183 | then { | |
169 | - | let data = $ | |
170 | - | let actions = $ | |
184 | + | let data = $t042504407._2 | |
185 | + | let actions = $t042504407._1 | |
171 | 186 | let mappedData = { | |
172 | 187 | let $l = data | |
173 | 188 | let $s = size($l) | |
243 | 258 | } | |
244 | 259 | } | |
245 | 260 | else { | |
246 | - | let $ | |
247 | - | let call = $ | |
248 | - | let addr = $ | |
249 | - | let params = $ | |
250 | - | let payments = $ | |
261 | + | let $t064036506 = calcStakingParams(stake, amount, fromBase58String(assetIdString)) | |
262 | + | let call = $t064036506._1 | |
263 | + | let addr = $t064036506._2 | |
264 | + | let params = $t064036506._3 | |
265 | + | let payments = $t064036506._4 | |
251 | 266 | let inv = invoke(addr, call, params, payments) | |
252 | 267 | if ((inv == inv)) | |
253 | 268 | then nil |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let kActive = "active" | |
5 | + | ||
6 | + | let kActiveGlob = "active_all_contracts" | |
5 | 7 | ||
6 | 8 | let kCause = "shutdown_cause" | |
7 | 9 | ||
8 | 10 | let kUSDNAddress = "staking_usdnnsbt_address" | |
9 | 11 | ||
10 | 12 | let kEURNAddress = "staking_eurn_address" | |
11 | 13 | ||
12 | 14 | let kLeasingPool = "leasing_address" | |
13 | 15 | ||
14 | 16 | let kLeasingAmount = "leasing_amount" | |
15 | 17 | ||
16 | 18 | let kLeasingId = "leasing_id" | |
17 | 19 | ||
18 | 20 | let kAdminPubKey1 = "admin_pub_1" | |
19 | 21 | ||
20 | 22 | let kAdminPubKey2 = "admin_pub_2" | |
21 | 23 | ||
22 | 24 | let kAdminPubKey3 = "admin_pub_3" | |
23 | 25 | ||
24 | 26 | let kAdminInvokePubKey = "admin_invoke_pub" | |
25 | 27 | ||
26 | 28 | let kCpmmContract = "cpmm_contract" | |
27 | 29 | ||
28 | 30 | let kUSDNAssetId = "usdn_asset_id" | |
29 | 31 | ||
30 | 32 | let kEURNAssetId = "eurn_asset_id" | |
31 | 33 | ||
32 | 34 | let kStakingAssets = "staking_assets" | |
33 | 35 | ||
34 | 36 | let kShareAssetId = "share_asset_id" | |
35 | 37 | ||
36 | 38 | let oracle = Address(base58'3PEbqViERCoKnmcSULh6n2aiMvUdSQdCsom') | |
37 | 39 | ||
38 | 40 | func getBase58FromOracle (key) = match getString(oracle, key) { | |
39 | 41 | case string: String => | |
40 | 42 | fromBase58String(string) | |
41 | 43 | case nothing => | |
42 | 44 | throw((key + "is empty")) | |
43 | 45 | } | |
44 | 46 | ||
45 | 47 | ||
46 | 48 | let adminPubKey1 = getBase58FromOracle(kAdminPubKey1) | |
47 | 49 | ||
48 | 50 | let adminPubKey2 = getBase58FromOracle(kAdminPubKey2) | |
49 | 51 | ||
50 | 52 | let adminPubKey3 = getBase58FromOracle(kAdminPubKey3) | |
51 | 53 | ||
52 | 54 | let adminPubKeyInvoke = getBase58FromOracle(kAdminInvokePubKey) | |
53 | 55 | ||
54 | 56 | let stakingUSDNAddress = Address(getBase58FromOracle(kUSDNAddress)) | |
55 | 57 | ||
56 | 58 | let stakingEURNAddress = Address(getBase58FromOracle(kEURNAddress)) | |
57 | 59 | ||
58 | 60 | let cpmmContract = Address(getBase58FromOracle(kCpmmContract)) | |
59 | 61 | ||
60 | 62 | let USDN = getBase58FromOracle(kUSDNAssetId) | |
61 | 63 | ||
62 | 64 | let EURN = getBase58FromOracle(kEURNAssetId) | |
63 | 65 | ||
64 | 66 | let stakingAssets = getStringValue(oracle, kStakingAssets) | |
65 | 67 | ||
68 | + | let activeGlob = valueOrElse(getBoolean(oracle, kActiveGlob), true) | |
69 | + | ||
66 | 70 | let active = valueOrElse(getBoolean(this, kActive), true) | |
67 | 71 | ||
68 | - | func isActive () = if (active) | |
72 | + | func isActive () = if (if (active) | |
73 | + | then activeGlob | |
74 | + | else false) | |
69 | 75 | then unit | |
70 | 76 | else throw("DApp is inactive at this moment") | |
71 | 77 | ||
72 | 78 | ||
73 | 79 | func isGlobalCaller (caller) = if ((caller == cpmmContract)) | |
74 | 80 | then unit | |
75 | 81 | else throw("Only global Contract can invoke this function") | |
76 | 82 | ||
77 | 83 | ||
78 | 84 | func isAdminCall (callerPubKey) = if (containsElement([adminPubKey1, adminPubKey2, adminPubKey3], callerPubKey)) | |
79 | 85 | then unit | |
80 | 86 | else throw("Only admin can call this function") | |
81 | 87 | ||
82 | 88 | ||
83 | 89 | func suspend (cause) = [BooleanEntry(kActive, false), StringEntry(kCause, cause)] | |
84 | 90 | ||
85 | 91 | ||
86 | 92 | func calcStakingFuncAndAddres (stake,assetId) = if (stake) | |
87 | 93 | then if ((assetId == USDN)) | |
88 | 94 | then $Tuple2("lockNeutrino", stakingUSDNAddress) | |
89 | 95 | else $Tuple2("startStaking", stakingEURNAddress) | |
90 | 96 | else if ((assetId == USDN)) | |
91 | 97 | then $Tuple2("unlockNeutrino", stakingUSDNAddress) | |
92 | 98 | else $Tuple2("stopStaking", stakingEURNAddress) | |
93 | 99 | ||
94 | 100 | ||
95 | 101 | func calcStakingParams (stake,amount,assetId) = if (stake) | |
96 | 102 | then { | |
97 | - | let $ | |
98 | - | let call = $ | |
99 | - | let stakingAddr = $ | |
103 | + | let $t025932659 = calcStakingFuncAndAddres(stake, assetId) | |
104 | + | let call = $t025932659._1 | |
105 | + | let stakingAddr = $t025932659._2 | |
100 | 106 | $Tuple4(call, stakingAddr, nil, [AttachedPayment(assetId, amount)]) | |
101 | 107 | } | |
102 | 108 | else { | |
103 | - | let $ | |
104 | - | let call = $ | |
105 | - | let stakingAddr = $ | |
109 | + | let $t027452811 = calcStakingFuncAndAddres(stake, assetId) | |
110 | + | let call = $t027452811._1 | |
111 | + | let stakingAddr = $t027452811._2 | |
106 | 112 | $Tuple4(call, stakingAddr, [amount, toBase58String(assetId)], nil) | |
107 | 113 | } | |
108 | 114 | ||
109 | 115 | ||
110 | 116 | func collectPayments (acc,payment) = { | |
111 | - | let $ | |
112 | - | let paymentAmounts = $ | |
113 | - | let paymentAssetIds = $ | |
117 | + | let $t029733016 = acc | |
118 | + | let paymentAmounts = $t029733016._1 | |
119 | + | let paymentAssetIds = $t029733016._2 | |
114 | 120 | $Tuple2((paymentAmounts :+ payment.amount), (paymentAssetIds :+ (if ((payment.assetId == unit)) | |
115 | 121 | then base58'' | |
116 | 122 | else payment.assetId))) | |
117 | 123 | } | |
118 | 124 | ||
119 | 125 | ||
120 | 126 | func collectState (result,source) = match source { | |
121 | 127 | case e: Issue|Burn|Reissue|ScriptTransfer|BinaryEntry|BooleanEntry|StringEntry|IntegerEntry => | |
122 | 128 | (result :+ e) | |
123 | 129 | case _ => | |
124 | 130 | result | |
125 | 131 | } | |
126 | 132 | ||
127 | 133 | ||
128 | 134 | func collectData (result,source) = match source { | |
129 | 135 | case v: String => | |
130 | 136 | (result :+ v) | |
131 | 137 | case v: Int => | |
132 | 138 | (result :+ v) | |
133 | 139 | case v: Boolean => | |
134 | 140 | (result :+ v) | |
135 | 141 | case v: ByteVector => | |
136 | 142 | (result :+ v) | |
137 | 143 | case v: Unit => | |
138 | 144 | (result :+ v) | |
139 | 145 | case _ => | |
140 | 146 | throw() | |
141 | 147 | } | |
142 | 148 | ||
143 | 149 | ||
144 | 150 | func callCommon (funcName,caller,args,payments) = valueOrElse(isActive(), { | |
145 | - | let $ | |
151 | + | let $t039364020 = { | |
146 | 152 | let $l = payments | |
147 | 153 | let $s = size($l) | |
148 | 154 | let $acc0 = $Tuple2(nil, nil) | |
149 | 155 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
150 | 156 | then $a | |
151 | 157 | else collectPayments($a, $l[$i]) | |
152 | 158 | ||
153 | 159 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
154 | 160 | then $a | |
155 | 161 | else throw("List size exceeds 10") | |
156 | 162 | ||
157 | 163 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10) | |
158 | 164 | } | |
159 | - | let paymentAmounts = $t038163900._1 | |
160 | - | let paymentAssetIds = $t038163900._2 | |
161 | - | let $t039054053 = { | |
162 | - | let @ = reentrantInvoke(cpmmContract, funcName, [caller, args, paymentAmounts, paymentAssetIds], nil) | |
165 | + | let paymentAmounts = $t039364020._1 | |
166 | + | let paymentAssetIds = $t039364020._2 | |
167 | + | let lockPayment = if (if ((funcName == "replenishWithTwoTokens")) | |
168 | + | then (size(payments) == 3) | |
169 | + | else false) | |
170 | + | then [payments[2]] | |
171 | + | else if (if ((funcName == "replenishWithOneToken")) | |
172 | + | then (size(payments) == 2) | |
173 | + | else false) | |
174 | + | then [payments[1]] | |
175 | + | else nil | |
176 | + | let $t042504407 = { | |
177 | + | let @ = reentrantInvoke(cpmmContract, funcName, [caller, args, paymentAmounts, paymentAssetIds], lockPayment) | |
163 | 178 | if ($isInstanceOf(@, "(List[Any], List[Any])")) | |
164 | 179 | then @ | |
165 | 180 | else throw(($getType(@) + " couldn't be cast to (List[Any], List[Any])")) | |
166 | 181 | } | |
167 | - | if (($ | |
182 | + | if (($t042504407 == $t042504407)) | |
168 | 183 | then { | |
169 | - | let data = $ | |
170 | - | let actions = $ | |
184 | + | let data = $t042504407._2 | |
185 | + | let actions = $t042504407._1 | |
171 | 186 | let mappedData = { | |
172 | 187 | let $l = data | |
173 | 188 | let $s = size($l) | |
174 | 189 | let $acc0 = nil | |
175 | 190 | func $f1_1 ($a,$i) = if (($i >= $s)) | |
176 | 191 | then $a | |
177 | 192 | else collectData($a, $l[$i]) | |
178 | 193 | ||
179 | 194 | func $f1_2 ($a,$i) = if (($i >= $s)) | |
180 | 195 | then $a | |
181 | 196 | else throw("List size exceeds 10") | |
182 | 197 | ||
183 | 198 | $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10) | |
184 | 199 | } | |
185 | 200 | let mappedActions = { | |
186 | 201 | let $l = actions | |
187 | 202 | let $s = size($l) | |
188 | 203 | let $acc0 = nil | |
189 | 204 | func $f2_1 ($a,$i) = if (($i >= $s)) | |
190 | 205 | then $a | |
191 | 206 | else collectState($a, $l[$i]) | |
192 | 207 | ||
193 | 208 | func $f2_2 ($a,$i) = if (($i >= $s)) | |
194 | 209 | then $a | |
195 | 210 | else throw("List size exceeds 15") | |
196 | 211 | ||
197 | 212 | $f2_2($f2_1($f2_1($f2_1($f2_1($f2_1($f2_1($f2_1($f2_1($f2_1($f2_1($f2_1($f2_1($f2_1($f2_1($f2_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15) | |
198 | 213 | } | |
199 | 214 | $Tuple2(mappedActions, mappedData) | |
200 | 215 | } | |
201 | 216 | else throw("Strict value is not equal to itself.") | |
202 | 217 | }) | |
203 | 218 | ||
204 | 219 | ||
205 | 220 | @Callable(i) | |
206 | 221 | func callFunction (funcName,args) = callCommon(funcName, i.caller.bytes, args, i.payments) | |
207 | 222 | ||
208 | 223 | ||
209 | 224 | ||
210 | 225 | @Callable(i) | |
211 | 226 | func shutdown () = valueOrElse(isAdminCall(i.callerPublicKey), if (!(active)) | |
212 | 227 | then throw(("DApp is already suspended. Cause: " + valueOrElse(getString(this, kCause), "the cause wasn't specified"))) | |
213 | 228 | else suspend("Paused by admin")) | |
214 | 229 | ||
215 | 230 | ||
216 | 231 | ||
217 | 232 | @Callable(i) | |
218 | 233 | func activate () = valueOrElse(isAdminCall(i.callerPublicKey), if (active) | |
219 | 234 | then throw("DApp is already active") | |
220 | 235 | else [BooleanEntry(kActive, true), DeleteEntry(kCause)]) | |
221 | 236 | ||
222 | 237 | ||
223 | 238 | ||
224 | 239 | @Callable(i) | |
225 | 240 | func stakeUnstake (stake,amount,assetIdString) = valueOrElse(isActive(), if ((i.caller != cpmmContract)) | |
226 | 241 | then throw("Only global Contract can invoke this function") | |
227 | 242 | else if ((assetIdString == "WAVES")) | |
228 | 243 | then { | |
229 | 244 | let pool = addressFromStringValue(valueOrErrorMessage(getString(oracle, kLeasingPool), "No leasing pool in oracle")) | |
230 | 245 | let leasingId = getBinary(this, kLeasingId) | |
231 | 246 | let leasingAmount = valueOrElse(getInteger(this, kLeasingAmount), 0) | |
232 | 247 | let newLeaseAmount = if (stake) | |
233 | 248 | then (leasingAmount + amount) | |
234 | 249 | else (leasingAmount - amount) | |
235 | 250 | let newLease = Lease(pool, newLeaseAmount) | |
236 | 251 | let newLeaseId = calculateLeaseId(newLease) | |
237 | 252 | let baseEtry = [newLease, BinaryEntry(kLeasingId, newLeaseId), IntegerEntry(kLeasingAmount, newLeaseAmount)] | |
238 | 253 | match leasingId { | |
239 | 254 | case lId: ByteVector => | |
240 | 255 | ([LeaseCancel(lId)] ++ baseEtry) | |
241 | 256 | case _ => | |
242 | 257 | baseEtry | |
243 | 258 | } | |
244 | 259 | } | |
245 | 260 | else { | |
246 | - | let $ | |
247 | - | let call = $ | |
248 | - | let addr = $ | |
249 | - | let params = $ | |
250 | - | let payments = $ | |
261 | + | let $t064036506 = calcStakingParams(stake, amount, fromBase58String(assetIdString)) | |
262 | + | let call = $t064036506._1 | |
263 | + | let addr = $t064036506._2 | |
264 | + | let params = $t064036506._3 | |
265 | + | let payments = $t064036506._4 | |
251 | 266 | let inv = invoke(addr, call, params, payments) | |
252 | 267 | if ((inv == inv)) | |
253 | 268 | then nil | |
254 | 269 | else throw("Strict value is not equal to itself.") | |
255 | 270 | }) | |
256 | 271 | ||
257 | 272 | ||
258 | 273 | ||
259 | 274 | @Callable(i) | |
260 | 275 | func reissueShareToken (amount) = valueOrElse(isGlobalCaller(i.caller), valueOrElse(isActive(), { | |
261 | 276 | let shareAssetId = fromBase58String(getStringValue(this, kShareAssetId)) | |
262 | 277 | [Reissue(shareAssetId, amount, true), ScriptTransfer(i.caller, amount, shareAssetId)] | |
263 | 278 | })) | |
264 | 279 | ||
265 | 280 | ||
266 | 281 | ||
267 | 282 | @Callable(i) | |
268 | 283 | func replenishWithTwoTokens (slippageTolerance) = callCommon("replenishWithTwoTokens", i.caller.bytes, ["false", "0"], i.payments) | |
269 | 284 | ||
270 | 285 | ||
271 | 286 | ||
272 | 287 | @Callable(i) | |
273 | 288 | func withdraw () = callCommon("withdraw", i.caller.bytes, ["0"], i.payments) | |
274 | 289 | ||
275 | 290 | ||
276 | 291 | ||
277 | 292 | @Callable(i) | |
278 | 293 | func exchange (minAmountToReceive) = callCommon("exchange", i.caller.bytes, [toString(minAmountToReceive)], i.payments) | |
279 | 294 | ||
280 | 295 | ||
281 | 296 | @Verifier(tx) | |
282 | 297 | func verify () = { | |
283 | 298 | let multiSignedByAdmins = { | |
284 | 299 | let adminPubKey1Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey1)) | |
285 | 300 | then 1 | |
286 | 301 | else 0 | |
287 | 302 | let adminPubKey2Signed = if (sigVerify(tx.bodyBytes, tx.proofs[1], adminPubKey2)) | |
288 | 303 | then 1 | |
289 | 304 | else 0 | |
290 | 305 | let adminPubKey3Signed = if (sigVerify(tx.bodyBytes, tx.proofs[2], adminPubKey3)) | |
291 | 306 | then 1 | |
292 | 307 | else 0 | |
293 | 308 | (((adminPubKey1Signed + adminPubKey2Signed) + adminPubKey3Signed) >= 2) | |
294 | 309 | } | |
295 | 310 | multiSignedByAdmins | |
296 | 311 | } | |
297 | 312 |
github/deemru/w8io/0e76f2f 44.10 ms ◑