tx · 33Y9AaQ37qbyYsaGMLaLCF2VddeR5pxmCj3QwDwLNgis 3MzbJGw4eewZaFchoewZQv9mMH25AoNgMb3: -0.01000000 Waves 2019.09.13 19:38 [674670] smart account 3MzbJGw4eewZaFchoewZQv9mMH25AoNgMb3 > SELF 0.00000000 Waves
{ "type": 13, "id": "33Y9AaQ37qbyYsaGMLaLCF2VddeR5pxmCj3QwDwLNgis", "fee": 1000000, "feeAssetId": null, "timestamp": 1568392496316, "version": 1, "sender": "3MzbJGw4eewZaFchoewZQv9mMH25AoNgMb3", "senderPublicKey": "FTjfgevHkmD3kcdRadPPNCxfsWvfecQ1cLQTtCPyN3BZ", "proofs": [ "5hJAWSuhotMs1ugdDzGvK38gm2RBVMjqrz5ZiM4EVFRFitv39eDtTYSM52UWACZVh3nVecC8CGfv4jAhwgCCMNRw" ], "script": "base64:AAIDAAAAAAAAAAoIARIGCgQICAICAAAAAgAAAAAJUlNBS2V5NTEyCQACWwAAAAECAAAAh2Jhc2U2NDpNRnd3RFFZSktvWklodmNOQVFFQkJRQURTd0F3U0FKQkFKUmRlYnA1R1hIYWdlejdrWisrZ05JdDBmTWU3V0d2Z3NrQkpBY29EbFFWbkE4Y05oL3NqeFNINjhoblhFVlRlMTdJbHNWcUxqSFlXMkpKVVpraUoxVUNBd0VBQVE9PQAAAAAKUlNBS2V5MjA0OAkAAlsAAAABAgAAAY9iYXNlNjQ6TUlJQklqQU5CZ2txaGtpRzl3MEJBUUVGQUFPQ0FROEFNSUlCQ2dLQ0FRRUFsZW1yOTVKMWpaVXM3Y0ptcm1tbE40em83WVZzQkp6SWVKZGs4TERGR2hVS1NJNnlmczIwWnlKZTIxKzZHSndObktVVTFVeW9jMTd3U1dNS2tyWjBNTXZZRStaNUFpaWp2Qks0c1NKM0lnR2pkVTgvTmhJOENCRHUwRit4Uk05cTNUQjNMTGJEeTVzQmR1ZFlmSGZzVU9jK01UdkFENjluMjdkYjJSaDgreVpRTXR1Ymt1VFFOcDg5c3BoSFFhTEd5UUZhTmxLL05hM2xGeDZvbXF6YWExZ2pvcGxVcjZydllLZ2ZBSUNVQjN6Vm1KU2hpRWk3dzdSMGhXbE5SRDNxY1pqQ1VPTlNwRm80V2J6a25HT2F6dzg0QitJTUlGbklwWFd6UUw4Ulgwdk5jZnNCdkxEZk02azJaYWNxd3lNS2FMTHFpZ2RCaUdkSjdXKzBsT1N0T1FJREFRQUIAAAABAAAAAWkBAAAACWNoZWNrU2lnbgAAAAQAAAAGbnVtYmVyAAAABFR4SWQAAAAJU2lnbmF0dXJlAAAACVB1YmxpY0tleQQAAAAEcG1udAkBAAAAB2V4dHJhY3QAAAABCAUAAAABaQAAAAdwYXltZW50BAAAAAxhc3NldElkY2hlY2sJAQAAAAlpc0RlZmluZWQAAAABCAUAAAAEcG1udAAAAAdhc3NldElkBAAAAAdhc3NldElkBAAAAAckbWF0Y2gwCAUAAAAEcG1udAAAAAdhc3NldElkAwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAApCeXRlVmVjdG9yBAAAAAFhBQAAAAckbWF0Y2gwBQAAAAFhAgAAAARudWxsBAAAAAFhCQAB+AAAAAQFAAAABlNIQTI1NgkAAZsAAAABBQAAAARUeElkBQAAAAlTaWduYXR1cmUFAAAACVJTQUtleTUxMgkBAAAACFdyaXRlU2V0AAAAAQkABEwAAAACCQEAAAAJRGF0YUVudHJ5AAAAAgkAASwAAAACBQAAAAZudW1iZXICAAAABF9QdWIFAAAACVB1YmxpY0tleQkABEwAAAACCQEAAAAJRGF0YUVudHJ5AAAAAgkAASwAAAACBQAAAAZudW1iZXICAAAABV9UWElEBQAAAARUeElkCQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACCQABLAAAAAIFAAAABm51bWJlcgIAAAAKX1NpZ25hdHVyZQUAAAAJU2lnbmF0dXJlCQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACCQABLAAAAAIFAAAABm51bWJlcgIAAAAHX1ZlcmlmeQUAAAABYQkABEwAAAACCQEAAAAJRGF0YUVudHJ5AAAAAgkAASwAAAACBQAAAAZudW1iZXICAAAAD19hc3NldElkRGVmaW5lZAUAAAAMYXNzZXRJZGNoZWNrCQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACCQABLAAAAAIFAAAABm51bWJlcgIAAAAPX2Fzc2V0SWREZWZpbmVkBQAAAAdhc3NldElkBQAAAANuaWwAAAABAAAAAnR4AQAAAAZ2ZXJpZnkAAAAABgVwFCI=", "chainId": 84, "height": 674670, "spentComplexity": 0 } View: original | compacted Prev: none Next: FjXu5TEVVQBZhpfTEAE3JzLaC57CGA5jvHU8DNRWvnLL Full:
Old | New | Differences | |
---|---|---|---|
1 | - | # no script | |
1 | + | {-# STDLIB_VERSION 3 #-} | |
2 | + | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | + | {-# CONTENT_TYPE DAPP #-} | |
4 | + | let RSAKey512 = fromBase64String("base64:MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAJRdebp5GXHagez7kZ++gNIt0fMe7WGvgskBJAcoDlQVnA8cNh/sjxSH68hnXEVTe17IlsVqLjHYW2JJUZkiJ1UCAwEAAQ==") | |
5 | + | ||
6 | + | let RSAKey2048 = fromBase64String("base64:MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAlemr95J1jZUs7cJmrmmlN4zo7YVsBJzIeJdk8LDFGhUKSI6yfs20ZyJe21+6GJwNnKUU1Uyoc17wSWMKkrZ0MMvYE+Z5AiijvBK4sSJ3IgGjdU8/NhI8CBDu0F+xRM9q3TB3LLbDy5sBdudYfHfsUOc+MTvAD69n27db2Rh8+yZQMtubkuTQNp89sphHQaLGyQFaNlK/Na3lFx6omqzaa1gjoplUr6rvYKgfAICUB3zVmJShiEi7w7R0hWlNRD3qcZjCUONSpFo4WbzknGOazw84B+IMIFnIpXWzQL8RX0vNcfsBvLDfM6k2ZacqwyMKaLLqigdBiGdJ7W+0lOStOQIDAQAB") | |
7 | + | ||
8 | + | @Callable(i) | |
9 | + | func checkSign (number,TxId,Signature,PublicKey) = { | |
10 | + | let pmnt = extract(i.payment) | |
11 | + | let assetIdcheck = isDefined(pmnt.assetId) | |
12 | + | let assetId = match pmnt.assetId { | |
13 | + | case a: ByteVector => | |
14 | + | a | |
15 | + | case _ => | |
16 | + | "null" | |
17 | + | } | |
18 | + | let a = rsaVerify(SHA256, toBytes(TxId), Signature, RSAKey512) | |
19 | + | WriteSet([DataEntry((number + "_Pub"), PublicKey), DataEntry((number + "_TXID"), TxId), DataEntry((number + "_Signature"), Signature), DataEntry((number + "_Verify"), a), DataEntry((number + "_assetIdDefined"), assetIdcheck), DataEntry((number + "_assetIdDefined"), assetId)]) | |
20 | + | } | |
21 | + | ||
22 | + | ||
23 | + | @Verifier(tx) | |
24 | + | func verify () = true | |
25 | + |
github/deemru/w8io/169f3d6 16.53 ms ◑![]()