tx · 4NPV2tWcrFhto2a4JhLT9orRxMTheEcVnB1ujBwxMx4X 3MuB15FfT7QUriD1R24GFbMPHz82NQ1Bm8X: -0.01400000 Waves 2023.02.22 21:11 [2461208] smart account 3MuB15FfT7QUriD1R24GFbMPHz82NQ1Bm8X > SELF 0.00000000 Waves
{ "type": 13, "id": "4NPV2tWcrFhto2a4JhLT9orRxMTheEcVnB1ujBwxMx4X", "fee": 1400000, "feeAssetId": null, "timestamp": 1677089321591, "version": 2, "chainId": 84, "sender": "3MuB15FfT7QUriD1R24GFbMPHz82NQ1Bm8X", "senderPublicKey": "7qxgAGEdFEuaxkfo1V6qHhBmhHqHkYmiow76yMaFuQBx", "proofs": [ "G6unF5wPY9Luj2D2RpgXyXTBcoWKrvRodeexRj97SDysDTBwmNyC4u5oWRm2ffZuP7kCknRNewKjqYgXFrsSmMb" ], "script": "base64:BgIrCAISBQoDCAEIEgsKCQgIGAEBAQgICBIFCgMICAgSABIAEgMKAQgSAwoBCCIACVNFUEFSQVRPUgICX18ACEtFWV9JTklUAgRJTklUAAxLRVlfTVVMVElTSUcCCE1VTFRJU0lHAApLRVlfU1RBVFVTAgZTVEFUVVMACktFWV9QQVVTRUQCBlBBVVNFRAAKS0VZX1BBVVNFUgIGUEFVU0VSAAxLRVlfQ0hBSU5fSUQCCENIQUlOX0lEABVLRVlfU0lHTkVSX1BVQkxJQ19LRVkCEVNJR05FUl9QVUJMSUNfS0VZAA1LRVlfREFUQV9IQVNIAglEQVRBX0hBU0gAB01BWF9JTlQA//////////9/ARBfdmFsaWRhdGVBZGRyZXNzAghhZGRyZXNzXwRlcnJfBAckbWF0Y2gwCQCmCAEFCGFkZHJlc3NfAwkAAQIFByRtYXRjaDACB0FkZHJlc3MEAWEFByRtYXRjaDAGCQACAQUEZXJyXwESX3ZhbGlkYXRlUHVibGljS2V5AgpwdWJsaWNLZXlfBGVycl8DCQECIT0CCQDIAQEJANkEAQUKcHVibGljS2V5XwAgCQACAQUEZXJyXwYBDF92YWxpZGF0ZUludAQEdmFsXw5sb3dlckJvdW5kYXJ5Xw51cHBlckJvdW5kYXJ5XwRlcnJfAwMJAGYCBQ5sb3dlckJvdW5kYXJ5XwUEdmFsXwYJAGYCBQR2YWxfBQ51cHBlckJvdW5kYXJ5XwkAAgEFBGVycl8GAQlfbG9hZEluaXQABAckbWF0Y2gwCQCgCAEFCEtFWV9JTklUAwkAAQIFByRtYXRjaDACB0Jvb2xlYW4EAWEFByRtYXRjaDAFAWEHAQlfc2F2ZUluaXQBB2lzSW5pdF8JAMwIAgkBDEJvb2xlYW5FbnRyeQIFCEtFWV9JTklUBQdpc0luaXRfBQNuaWwBCl9sb2FkUGF1c2UABAckbWF0Y2gwCQCgCAEFCktFWV9QQVVTRUQDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBYQUHJG1hdGNoMAUBYQcBCl9zYXZlUGF1c2UBCWlzUGF1c2VkXwkAzAgCCQEMQm9vbGVhbkVudHJ5AgUKS0VZX1BBVVNFRAUJaXNQYXVzZWRfBQNuaWwBC19sb2FkUGF1c2VyAAQHJG1hdGNoMAkAoggBBQpLRVlfUEFVU0VSAwkAAQIFByRtYXRjaDACBlN0cmluZwQBYQUHJG1hdGNoMAkBEUBleHRyTmF0aXZlKDEwNjIpAQUBYQkBB0FkZHJlc3MBAQABC19zYXZlUGF1c2VyAQdwYXVzZXJfCQDMCAIJAQtTdHJpbmdFbnRyeQIFCktFWV9QQVVTRVIJAKUIAQUHcGF1c2VyXwUDbmlsAQ1fbG9hZE11bHRpc2lnAAQHJG1hdGNoMAkAoggBBQxLRVlfTVVMVElTSUcDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFhBQckbWF0Y2gwCQERQGV4dHJOYXRpdmUoMTA2MikBBQFhCQEHQWRkcmVzcwEBAAENX3NhdmVNdWx0aXNpZwEJbXVsdGlzaWdfCQDMCAIJAQtTdHJpbmdFbnRyeQIFDEtFWV9NVUxUSVNJRwkApQgBBQltdWx0aXNpZ18FA25pbAEMX2xvYWRDaGFpbklkAAQHJG1hdGNoMAkAnwgBBQxLRVlfQ0hBSU5fSUQDCQABAgUHJG1hdGNoMAIDSW50BAFhBQckbWF0Y2gwBQFhAAABDF9zYXZlQ2hhaW5JZAEIY2hhaW5JZF8JAMwIAgkBDEludGVnZXJFbnRyeQIFDEtFWV9DSEFJTl9JRAUIY2hhaW5JZF8FA25pbAEUX2xvYWRTaWduZXJQdWJsaWNLZXkABAckbWF0Y2gwCQCiCAEFFUtFWV9TSUdORVJfUFVCTElDX0tFWQMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAWEFByRtYXRjaDAJANkEAQUBYQEAARRfc2F2ZVNpZ25lclB1YmxpY0tleQEQc2lnbmVyUHVibGljS2V5XwkAzAgCCQELU3RyaW5nRW50cnkCBRVLRVlfU0lHTkVSX1BVQkxJQ19LRVkJANgEAQUQc2lnbmVyUHVibGljS2V5XwUDbmlsAQ1fbG9hZERhdGFIYXNoAQlkYXRhSGFzaF8EByRtYXRjaDAJAJ8IAQkAuQkCCQDMCAIFDUtFWV9EQVRBX0hBU0gJAMwIAgkA2AQBBQlkYXRhSGFzaF8FA25pbAUJU0VQQVJBVE9SAwkAAQIFByRtYXRjaDACA0ludAQBYQUHJG1hdGNoMAUBYQAAAQ1fc2F2ZURhdGFIYXNoAglkYXRhSGFzaF8HaGVpZ2h0XwkAzAgCCQEMSW50ZWdlckVudHJ5AgkAuQkCCQDMCAIFDUtFWV9EQVRBX0hBU0gJAMwIAgkA2AQBBQlkYXRhSGFzaF8FA25pbAUJU0VQQVJBVE9SBQdoZWlnaHRfBQNuaWwBEV9vbmx5VGhpc0NvbnRyYWN0AQdjYWxsZXJfAwkBAiE9AgUHY2FsbGVyXwUEdGhpcwkAAgECGV9vbmx5VGhpc0NvbnRyYWN0OiByZXZlcnQGARBfd2hlbk11bHRpc2lnU2V0AAMJAAACCQENX2xvYWRNdWx0aXNpZwAJAQdBZGRyZXNzAQEACQACAQIYX3doZW5NdWx0aXNpZ1NldDogcmV2ZXJ0BgETX3doZW5Ob3RJbml0aWFsaXplZAADCQEJX2xvYWRJbml0AAkAAgECG193aGVuTm90SW5pdGlhbGl6ZWQ6IHJldmVydAYBEF93aGVuSW5pdGlhbGl6ZWQAAwkBASEBCQEJX2xvYWRJbml0AAkAAgECGF93aGVuSW5pdGlhbGl6ZWQ6IHJldmVydAYBDl93aGVuTm90UGF1c2VkAAMJAQpfbG9hZFBhdXNlAAkAAgECFl93aGVuTm90UGF1c2VkOiByZXZlcnQGAQtfd2hlblBhdXNlZAADCQEBIQEJAQpfbG9hZFBhdXNlAAkAAgECE193aGVuUGF1c2VkOiByZXZlcnQGAQtfb25seVBhdXNlcgEHY2FsbGVyXwMJAQIhPQIFB2NhbGxlcl8JAQtfbG9hZFBhdXNlcgAJAAIBAhNfb25seVBhdXNlcjogcmV2ZXJ0BgcBaQEEaW5pdAMHcGF1c2VyXwhjaGFpbklkXxBzaWduZXJQdWJsaWNLZXlfBANlcnIDAwMDAwkBEV9vbmx5VGhpc0NvbnRyYWN0AQgFAWkGY2FsbGVyCQETX3doZW5Ob3RJbml0aWFsaXplZAAHCQEQX3doZW5NdWx0aXNpZ1NldAAHCQEQX3ZhbGlkYXRlQWRkcmVzcwIFB3BhdXNlcl8CFGluaXQ6IGludmFsaWQgcGF1c2VyBwkBDF92YWxpZGF0ZUludAQFCGNoYWluSWRfAAAFB01BWF9JTlQCFmluaXQ6IGludmFsaWQgY2hhaW4gaWQHCQESX3ZhbGlkYXRlUHVibGljS2V5AgUQc2lnbmVyUHVibGljS2V5XwIfaW5pdDogaW52YWxpZCBzaWduZXIgcHVibGljIGtleQcDCQAAAgUDZXJyBQNlcnIJAJQKAgkAzggCCQDOCAIJAM4IAgkBCV9zYXZlSW5pdAEGCQELX3NhdmVQYXVzZXIBCQERQGV4dHJOYXRpdmUoMTA2MikBBQdwYXVzZXJfCQEMX3NhdmVDaGFpbklkAQUIY2hhaW5JZF8JARRfc2F2ZVNpZ25lclB1YmxpY0tleQEJANkEAQUQc2lnbmVyUHVibGljS2V5XwUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQdleGVjdXRlCQljb250cmFjdF8NZnVuY3Rpb25OYW1lXw1mdW5jdGlvbkFyZ3NfDmNhbGxlckNoYWluSWRfEWV4ZWN1dGlvbkNoYWluSWRfBm5vbmNlXw9jYWxsZXJDb250cmFjdF8HdHhIYXNoXwpzaWduYXR1cmVfBANlcnIDAwMJARBfd2hlbkluaXRpYWxpemVkAAkBDl93aGVuTm90UGF1c2VkAAcJARBfdmFsaWRhdGVBZGRyZXNzAgUJY29udHJhY3RfAhlleGVjdXRlOiBpbnZhbGlkIGNvbnRyYWN0BwMJAQIhPQIJAQxfbG9hZENoYWluSWQABRFleGVjdXRpb25DaGFpbklkXwkAAgECI2V4ZWN1dGU6IGludmFsaWQgZXhlY3V0aW9uIGNoYWluIGlkBgcDCQAAAgUDZXJyBQNlcnIKAQhmb2xkRnVuYwIDYWNjBGVsZW0JAMsBAgUDYWNjCQCbAwEFBGVsZW0ECWFyZ3NCeXRlcwoAAiRsBQ1mdW5jdGlvbkFyZ3NfCgACJHMJAJADAQUCJGwKAAUkYWNjMAEACgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQhmb2xkRnVuYwIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMjIJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwADQAOAA8AEAARABIAEwAUABUAFgQEZGF0YQkAywECCQDLAQIJAMsBAgkAywECCQDLAQIJAMsBAgkAywECCQCaAwEFDmNhbGxlckNoYWluSWRfCQCaAwEFEWV4ZWN1dGlvbkNoYWluSWRfCQCaAwEFBm5vbmNlXwkA2QQBBQ9jYWxsZXJDb250cmFjdF8JAJsDAQUHdHhIYXNoXwkA2QQBBQljb250cmFjdF8JAJsDAQUNZnVuY3Rpb25OYW1lXwUJYXJnc0J5dGVzBAhkYXRhSGFzaAkAjRUBBQRkYXRhBARlcnIxAwkBASEBCQD0AwMFCGRhdGFIYXNoCQDZBAEFCnNpZ25hdHVyZV8JARRfbG9hZFNpZ25lclB1YmxpY0tleQAJAAIBAhpleGVjdXRlOiBpbnZhbGlkIHNpZ25hdHVyZQMJAGYCCQENX2xvYWREYXRhSGFzaAEFCGRhdGFIYXNoAAAJAAIBAhdleGVjdXRlOiBkdXBsaWNhdGUgZGF0YQUEdW5pdAMJAAACBQRlcnIxBQRlcnIxBAppbnZvY2F0aW9uCQD8BwQJARFAZXh0ck5hdGl2ZSgxMDYyKQEFCWNvbnRyYWN0XwUNZnVuY3Rpb25OYW1lXwkAzAgCBQ9jYWxsZXJDb250cmFjdF8FDWZ1bmN0aW9uQXJnc18FA25pbAMJAAACBQppbnZvY2F0aW9uBQppbnZvY2F0aW9uCQCUCgIJAQ1fc2F2ZURhdGFIYXNoAgUIZGF0YUhhc2gFBmhlaWdodAUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQx1cGRhdGVTaWduZXIDE25ld1NpZ25lclB1YmxpY0tleV8Nb2xkU2lnbmF0dXJlXw1uZXdTaWduYXR1cmVfBANlcnIDAwkBEV9vbmx5VGhpc0NvbnRyYWN0AQgFAWkGY2FsbGVyCQEQX3doZW5Jbml0aWFsaXplZAAHCQESX3ZhbGlkYXRlUHVibGljS2V5AgUTbmV3U2lnbmVyUHVibGljS2V5XwIndXBkYXRlU2lnbmVyOiBpbnZhbGlkIHNpZ25lciBwdWJsaWMga2V5BwMJAAACBQNlcnIFA2VycgQSb2xkU2lnbmVyUHVibGljS2V5CQEUX2xvYWRTaWduZXJQdWJsaWNLZXkABAdvbGREYXRhCQDLAQIJAMsBAgkAmwMBAiU8PDxQVUJMSUMtLUtFWS0tTUlHUkFUSU9OLS1BTExPV0VEPj4+BRJvbGRTaWduZXJQdWJsaWNLZXkJANkEAQUTbmV3U2lnbmVyUHVibGljS2V5XwQSbmV3U2lnbmVyUHVibGljS2V5CQDZBAEFE25ld1NpZ25lclB1YmxpY0tleV8EB25ld0RhdGEJAMsBAgkAywECCQCbAwECJzw8PFBVQkxJQy0tS0VZLS1NSUdSQVRJT04tLUNPTkZJUk1FRD4+PgUSb2xkU2lnbmVyUHVibGljS2V5CQCbAwEFE25ld1NpZ25lclB1YmxpY0tleV8EBGVycjEDCQEBIQEJAMQTAwUHb2xkRGF0YQkA2QQBBQ1vbGRTaWduYXR1cmVfBRJvbGRTaWduZXJQdWJsaWNLZXkJAAIBAiN1cGRhdGVTaWduZXI6IGludmFsaWQgb2xkIHNpZ25hdHVyZQMJAQEhAQkAxBMDBQduZXdEYXRhCQDZBAEFDW5ld1NpZ25hdHVyZV8FEm5ld1NpZ25lclB1YmxpY0tleQkAAgECI3VwZGF0ZVNpZ25lcjogaW52YWxpZCBuZXcgc2lnbmF0dXJlBQR1bml0AwkAAAIFBGVycjEFBGVycjEJAJQKAgkBFF9zYXZlU2lnbmVyUHVibGljS2V5AQUSbmV3U2lnbmVyUHVibGljS2V5BQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBBXBhdXNlAAQDZXJyAwMJAQtfb25seVBhdXNlcgEIBQFpBmNhbGxlcgkBEF93aGVuSW5pdGlhbGl6ZWQABwkBDl93aGVuTm90UGF1c2VkAAcDCQAAAgUDZXJyBQNlcnIJAJQKAgkBCl9zYXZlUGF1c2UBBgUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQd1bnBhdXNlAAQDZXJyAwMJAQtfb25seVBhdXNlcgEIBQFpBmNhbGxlcgkBEF93aGVuSW5pdGlhbGl6ZWQABwkBC193aGVuUGF1c2VkAAcDCQAAAgUDZXJyBQNlcnIJAJQKAgkBCl9zYXZlUGF1c2UBBwUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQx1cGRhdGVQYXVzZXIBB3BhdXNlcl8EA2VycgMDCQERX29ubHlUaGlzQ29udHJhY3QBCAUBaQZjYWxsZXIJARBfd2hlbkluaXRpYWxpemVkAAcJARBfdmFsaWRhdGVBZGRyZXNzAgUHcGF1c2VyXwIUaW5pdDogaW52YWxpZCBwYXVzZXIHAwkAAAIFA2VycgUDZXJyCQCUCgIJAQtfc2F2ZVBhdXNlcgEJARFAZXh0ck5hdGl2ZSgxMDYyKQEFB3BhdXNlcl8FBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQELc2V0TXVsdGlzaWcBCW11bHRpc2lnXwQDZXJyAwkBEV9vbmx5VGhpc0NvbnRyYWN0AQgFAWkGY2FsbGVyCQEQX3ZhbGlkYXRlQWRkcmVzcwIFCW11bHRpc2lnXwIlc2V0TXVsdGlzaWc6IGludmFsaWQgbXVsdGlzaWcgYWRkcmVzcwcDCQAAAgUDZXJyBQNlcnIJAJQKAgkBDV9zYXZlTXVsdGlzaWcBCQERQGV4dHJOYXRpdmUoMTA2MikBBQltdWx0aXNpZ18FBHVuaXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAnR4AQZ2ZXJpZnkABAckbWF0Y2gwCQCiCAEFDEtFWV9NVUxUSVNJRwMJAAECBQckbWF0Y2gwAgZTdHJpbmcECG11bHRpc2lnBQckbWF0Y2gwCQELdmFsdWVPckVsc2UCCQCbCAIJARFAZXh0ck5hdGl2ZSgxMDYyKQEFCG11bHRpc2lnCQC5CQIJAMwIAgUKS0VZX1NUQVRVUwkAzAgCCQClCAEFBHRoaXMJAMwIAgkA2AQBCAUCdHgCaWQFA25pbAUJU0VQQVJBVE9SBwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAgFAnR4D3NlbmRlclB1YmxpY0tleenZc5A=", "height": 2461208, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 8dE7vpNc6D9y8oMor4Lvoi1rVdLn1r92kwVeXofGQ35x Next: 9Ujssntm6VUwkU6M9BvAmKGChWaGMeuwzP5uKaBzJzci Diff:
Old | New | Differences | |
---|---|---|---|
228 | 228 | } | |
229 | 229 | let av = (((((((toBytes(ae) + toBytes(af)) + toBytes(ag)) + fromBase58String(ah)) + toBytes(ai)) + fromBase58String(ab)) + toBytes(ac)) + an) | |
230 | 230 | let aw = keccak256_32Kb(av) | |
231 | - | let ax = if (( | |
231 | + | let ax = if (!(sigVerify(aw, fromBase58String(aj), K()))) | |
232 | 232 | then throw("execute: invalid signature") | |
233 | 233 | else if ((N(aw) > 0)) | |
234 | 234 | then throw("execute: duplicate data") |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let a = "__" | |
5 | 5 | ||
6 | 6 | let b = "INIT" | |
7 | 7 | ||
8 | 8 | let c = "MULTISIG" | |
9 | 9 | ||
10 | 10 | let d = "STATUS" | |
11 | 11 | ||
12 | 12 | let e = "PAUSED" | |
13 | 13 | ||
14 | 14 | let f = "PAUSER" | |
15 | 15 | ||
16 | 16 | let g = "CHAIN_ID" | |
17 | 17 | ||
18 | 18 | let h = "SIGNER_PUBLIC_KEY" | |
19 | 19 | ||
20 | 20 | let i = "DATA_HASH" | |
21 | 21 | ||
22 | 22 | let j = 9223372036854775807 | |
23 | 23 | ||
24 | 24 | func k (l,m) = { | |
25 | 25 | let n = addressFromString(l) | |
26 | 26 | if ($isInstanceOf(n, "Address")) | |
27 | 27 | then { | |
28 | 28 | let o = n | |
29 | 29 | true | |
30 | 30 | } | |
31 | 31 | else throw(m) | |
32 | 32 | } | |
33 | 33 | ||
34 | 34 | ||
35 | 35 | func p (q,m) = if ((size(fromBase58String(q)) != 32)) | |
36 | 36 | then throw(m) | |
37 | 37 | else true | |
38 | 38 | ||
39 | 39 | ||
40 | 40 | func r (s,t,u,m) = if (if ((t > s)) | |
41 | 41 | then true | |
42 | 42 | else (s > u)) | |
43 | 43 | then throw(m) | |
44 | 44 | else true | |
45 | 45 | ||
46 | 46 | ||
47 | 47 | func v () = { | |
48 | 48 | let n = getBoolean(b) | |
49 | 49 | if ($isInstanceOf(n, "Boolean")) | |
50 | 50 | then { | |
51 | 51 | let o = n | |
52 | 52 | o | |
53 | 53 | } | |
54 | 54 | else false | |
55 | 55 | } | |
56 | 56 | ||
57 | 57 | ||
58 | 58 | func w (x) = [BooleanEntry(b, x)] | |
59 | 59 | ||
60 | 60 | ||
61 | 61 | func y () = { | |
62 | 62 | let n = getBoolean(e) | |
63 | 63 | if ($isInstanceOf(n, "Boolean")) | |
64 | 64 | then { | |
65 | 65 | let o = n | |
66 | 66 | o | |
67 | 67 | } | |
68 | 68 | else false | |
69 | 69 | } | |
70 | 70 | ||
71 | 71 | ||
72 | 72 | func z (A) = [BooleanEntry(e, A)] | |
73 | 73 | ||
74 | 74 | ||
75 | 75 | func B () = { | |
76 | 76 | let n = getString(f) | |
77 | 77 | if ($isInstanceOf(n, "String")) | |
78 | 78 | then { | |
79 | 79 | let o = n | |
80 | 80 | addressFromStringValue(o) | |
81 | 81 | } | |
82 | 82 | else Address(base58'') | |
83 | 83 | } | |
84 | 84 | ||
85 | 85 | ||
86 | 86 | func C (D) = [StringEntry(f, toString(D))] | |
87 | 87 | ||
88 | 88 | ||
89 | 89 | func E () = { | |
90 | 90 | let n = getString(c) | |
91 | 91 | if ($isInstanceOf(n, "String")) | |
92 | 92 | then { | |
93 | 93 | let o = n | |
94 | 94 | addressFromStringValue(o) | |
95 | 95 | } | |
96 | 96 | else Address(base58'') | |
97 | 97 | } | |
98 | 98 | ||
99 | 99 | ||
100 | 100 | func F (G) = [StringEntry(c, toString(G))] | |
101 | 101 | ||
102 | 102 | ||
103 | 103 | func H () = { | |
104 | 104 | let n = getInteger(g) | |
105 | 105 | if ($isInstanceOf(n, "Int")) | |
106 | 106 | then { | |
107 | 107 | let o = n | |
108 | 108 | o | |
109 | 109 | } | |
110 | 110 | else 0 | |
111 | 111 | } | |
112 | 112 | ||
113 | 113 | ||
114 | 114 | func I (J) = [IntegerEntry(g, J)] | |
115 | 115 | ||
116 | 116 | ||
117 | 117 | func K () = { | |
118 | 118 | let n = getString(h) | |
119 | 119 | if ($isInstanceOf(n, "String")) | |
120 | 120 | then { | |
121 | 121 | let o = n | |
122 | 122 | fromBase58String(o) | |
123 | 123 | } | |
124 | 124 | else base58'' | |
125 | 125 | } | |
126 | 126 | ||
127 | 127 | ||
128 | 128 | func L (M) = [StringEntry(h, toBase58String(M))] | |
129 | 129 | ||
130 | 130 | ||
131 | 131 | func N (O) = { | |
132 | 132 | let n = getInteger(makeString([i, toBase58String(O)], a)) | |
133 | 133 | if ($isInstanceOf(n, "Int")) | |
134 | 134 | then { | |
135 | 135 | let o = n | |
136 | 136 | o | |
137 | 137 | } | |
138 | 138 | else 0 | |
139 | 139 | } | |
140 | 140 | ||
141 | 141 | ||
142 | 142 | func P (O,Q) = [IntegerEntry(makeString([i, toBase58String(O)], a), Q)] | |
143 | 143 | ||
144 | 144 | ||
145 | 145 | func R (S) = if ((S != this)) | |
146 | 146 | then throw("_onlyThisContract: revert") | |
147 | 147 | else true | |
148 | 148 | ||
149 | 149 | ||
150 | 150 | func T () = if ((E() == Address(base58''))) | |
151 | 151 | then throw("_whenMultisigSet: revert") | |
152 | 152 | else true | |
153 | 153 | ||
154 | 154 | ||
155 | 155 | func U () = if (v()) | |
156 | 156 | then throw("_whenNotInitialized: revert") | |
157 | 157 | else true | |
158 | 158 | ||
159 | 159 | ||
160 | 160 | func V () = if (!(v())) | |
161 | 161 | then throw("_whenInitialized: revert") | |
162 | 162 | else true | |
163 | 163 | ||
164 | 164 | ||
165 | 165 | func W () = if (y()) | |
166 | 166 | then throw("_whenNotPaused: revert") | |
167 | 167 | else true | |
168 | 168 | ||
169 | 169 | ||
170 | 170 | func X () = if (!(y())) | |
171 | 171 | then throw("_whenPaused: revert") | |
172 | 172 | else true | |
173 | 173 | ||
174 | 174 | ||
175 | 175 | func Y (S) = if ((S != B())) | |
176 | 176 | then throw("_onlyPauser: revert") | |
177 | 177 | else true | |
178 | 178 | ||
179 | 179 | ||
180 | 180 | @Callable(Z) | |
181 | 181 | func init (D,J,M) = { | |
182 | 182 | let aa = if (if (if (if (if (R(Z.caller)) | |
183 | 183 | then U() | |
184 | 184 | else false) | |
185 | 185 | then T() | |
186 | 186 | else false) | |
187 | 187 | then k(D, "init: invalid pauser") | |
188 | 188 | else false) | |
189 | 189 | then r(J, 0, j, "init: invalid chain id") | |
190 | 190 | else false) | |
191 | 191 | then p(M, "init: invalid signer public key") | |
192 | 192 | else false | |
193 | 193 | if ((aa == aa)) | |
194 | 194 | then $Tuple2((((w(true) ++ C(addressFromStringValue(D))) ++ I(J)) ++ L(fromBase58String(M))), unit) | |
195 | 195 | else throw("Strict value is not equal to itself.") | |
196 | 196 | } | |
197 | 197 | ||
198 | 198 | ||
199 | 199 | ||
200 | 200 | @Callable(Z) | |
201 | 201 | func execute (ab,ac,ad,ae,af,ag,ah,ai,aj) = { | |
202 | 202 | let aa = if (if (if (V()) | |
203 | 203 | then W() | |
204 | 204 | else false) | |
205 | 205 | then k(ab, "execute: invalid contract") | |
206 | 206 | else false) | |
207 | 207 | then if ((H() != af)) | |
208 | 208 | then throw("execute: invalid execution chain id") | |
209 | 209 | else true | |
210 | 210 | else false | |
211 | 211 | if ((aa == aa)) | |
212 | 212 | then { | |
213 | 213 | func ak (al,am) = (al + toBytes(am)) | |
214 | 214 | ||
215 | 215 | let an = { | |
216 | 216 | let ao = ad | |
217 | 217 | let ap = size(ao) | |
218 | 218 | let aq = base58'' | |
219 | 219 | func ar (as,at) = if ((at >= ap)) | |
220 | 220 | then as | |
221 | 221 | else ak(as, ao[at]) | |
222 | 222 | ||
223 | 223 | func au (as,at) = if ((at >= ap)) | |
224 | 224 | then as | |
225 | 225 | else throw("List size exceeds 22") | |
226 | 226 | ||
227 | 227 | au(ar(ar(ar(ar(ar(ar(ar(ar(ar(ar(ar(ar(ar(ar(ar(ar(ar(ar(ar(ar(ar(ar(aq, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22) | |
228 | 228 | } | |
229 | 229 | let av = (((((((toBytes(ae) + toBytes(af)) + toBytes(ag)) + fromBase58String(ah)) + toBytes(ai)) + fromBase58String(ab)) + toBytes(ac)) + an) | |
230 | 230 | let aw = keccak256_32Kb(av) | |
231 | - | let ax = if (( | |
231 | + | let ax = if (!(sigVerify(aw, fromBase58String(aj), K()))) | |
232 | 232 | then throw("execute: invalid signature") | |
233 | 233 | else if ((N(aw) > 0)) | |
234 | 234 | then throw("execute: duplicate data") | |
235 | 235 | else unit | |
236 | 236 | if ((ax == ax)) | |
237 | 237 | then { | |
238 | 238 | let ay = invoke(addressFromStringValue(ab), ac, ah :: ad, nil) | |
239 | 239 | if ((ay == ay)) | |
240 | 240 | then $Tuple2(P(aw, height), unit) | |
241 | 241 | else throw("Strict value is not equal to itself.") | |
242 | 242 | } | |
243 | 243 | else throw("Strict value is not equal to itself.") | |
244 | 244 | } | |
245 | 245 | else throw("Strict value is not equal to itself.") | |
246 | 246 | } | |
247 | 247 | ||
248 | 248 | ||
249 | 249 | ||
250 | 250 | @Callable(Z) | |
251 | 251 | func updateSigner (az,aA,aB) = { | |
252 | 252 | let aa = if (if (R(Z.caller)) | |
253 | 253 | then V() | |
254 | 254 | else false) | |
255 | 255 | then p(az, "updateSigner: invalid signer public key") | |
256 | 256 | else false | |
257 | 257 | if ((aa == aa)) | |
258 | 258 | then { | |
259 | 259 | let aC = K() | |
260 | 260 | let aD = ((toBytes("<<<PUBLIC--KEY--MIGRATION--ALLOWED>>>") + aC) + fromBase58String(az)) | |
261 | 261 | let aE = fromBase58String(az) | |
262 | 262 | let aF = ((toBytes("<<<PUBLIC--KEY--MIGRATION--CONFIRMED>>>") + aC) + toBytes(az)) | |
263 | 263 | let ax = if (!(sigVerify_8Kb(aD, fromBase58String(aA), aC))) | |
264 | 264 | then throw("updateSigner: invalid old signature") | |
265 | 265 | else if (!(sigVerify_8Kb(aF, fromBase58String(aB), aE))) | |
266 | 266 | then throw("updateSigner: invalid new signature") | |
267 | 267 | else unit | |
268 | 268 | if ((ax == ax)) | |
269 | 269 | then $Tuple2(L(aE), unit) | |
270 | 270 | else throw("Strict value is not equal to itself.") | |
271 | 271 | } | |
272 | 272 | else throw("Strict value is not equal to itself.") | |
273 | 273 | } | |
274 | 274 | ||
275 | 275 | ||
276 | 276 | ||
277 | 277 | @Callable(Z) | |
278 | 278 | func pause () = { | |
279 | 279 | let aa = if (if (Y(Z.caller)) | |
280 | 280 | then V() | |
281 | 281 | else false) | |
282 | 282 | then W() | |
283 | 283 | else false | |
284 | 284 | if ((aa == aa)) | |
285 | 285 | then $Tuple2(z(true), unit) | |
286 | 286 | else throw("Strict value is not equal to itself.") | |
287 | 287 | } | |
288 | 288 | ||
289 | 289 | ||
290 | 290 | ||
291 | 291 | @Callable(Z) | |
292 | 292 | func unpause () = { | |
293 | 293 | let aa = if (if (Y(Z.caller)) | |
294 | 294 | then V() | |
295 | 295 | else false) | |
296 | 296 | then X() | |
297 | 297 | else false | |
298 | 298 | if ((aa == aa)) | |
299 | 299 | then $Tuple2(z(false), unit) | |
300 | 300 | else throw("Strict value is not equal to itself.") | |
301 | 301 | } | |
302 | 302 | ||
303 | 303 | ||
304 | 304 | ||
305 | 305 | @Callable(Z) | |
306 | 306 | func updatePauser (D) = { | |
307 | 307 | let aa = if (if (R(Z.caller)) | |
308 | 308 | then V() | |
309 | 309 | else false) | |
310 | 310 | then k(D, "init: invalid pauser") | |
311 | 311 | else false | |
312 | 312 | if ((aa == aa)) | |
313 | 313 | then $Tuple2(C(addressFromStringValue(D)), unit) | |
314 | 314 | else throw("Strict value is not equal to itself.") | |
315 | 315 | } | |
316 | 316 | ||
317 | 317 | ||
318 | 318 | ||
319 | 319 | @Callable(Z) | |
320 | 320 | func setMultisig (G) = { | |
321 | 321 | let aa = if (R(Z.caller)) | |
322 | 322 | then k(G, "setMultisig: invalid multisig address") | |
323 | 323 | else false | |
324 | 324 | if ((aa == aa)) | |
325 | 325 | then $Tuple2(F(addressFromStringValue(G)), unit) | |
326 | 326 | else throw("Strict value is not equal to itself.") | |
327 | 327 | } | |
328 | 328 | ||
329 | 329 | ||
330 | 330 | @Verifier(aG) | |
331 | 331 | func aH () = { | |
332 | 332 | let n = getString(c) | |
333 | 333 | if ($isInstanceOf(n, "String")) | |
334 | 334 | then { | |
335 | 335 | let aI = n | |
336 | 336 | valueOrElse(getBoolean(addressFromStringValue(aI), makeString([d, toString(this), toBase58String(aG.id)], a)), false) | |
337 | 337 | } | |
338 | 338 | else sigVerify(aG.bodyBytes, aG.proofs[0], aG.senderPublicKey) | |
339 | 339 | } | |
340 | 340 |
github/deemru/w8io/169f3d6 306.86 ms ◑![]()