tx · 7srjy3e9FksS9aKhvjrNWZnwA9QbHD6ZmVQAMo64RHpX 3My9uDN1mW9uk1FZXEPGrShd4mue54JXzXU: -0.05000000 Waves 2020.01.17 17:57 [858302] smart account 3My9uDN1mW9uk1FZXEPGrShd4mue54JXzXU > SELF 0.00000000 Waves
{ "type": 13, "id": "7srjy3e9FksS9aKhvjrNWZnwA9QbHD6ZmVQAMo64RHpX", "fee": 5000000, "feeAssetId": null, "timestamp": 1579273149013, "version": 1, "sender": "3My9uDN1mW9uk1FZXEPGrShd4mue54JXzXU", "senderPublicKey": "95WQpA13wTFDDvyMzJM8sjgYqsMxRbJ1J6ECJ3Jn35F4", "proofs": [ "41o9EeJzj2zzy3gz2BxhDnmmeHqj9i8b1eM79mfyoizWgcZD3HNPzKYrudbLgn6iumtVXBzWN6XgUzhp5wGtLPsT" ], "script": "base64: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", "chainId": 84, "height": 858302, "spentComplexity": 0 } View: original | compacted Prev: 5J37DDqAVF9uXYy93R3frecR3x4YY5aR7baztxBeXs3W Next: GiPhqpAKdiNSNUKFwUkUxDeusqajZGgdM4GxdpNQeDY5 Diff:
Old | New | Differences | |
---|---|---|---|
82 | 82 | case _ => | |
83 | 83 | 0 | |
84 | 84 | } | |
85 | - | if (( | |
85 | + | if ((height >= nStatus)) | |
86 | 86 | then throw("F") | |
87 | - | else ScriptResult(WriteSet([DataEntry("nstatus", | |
87 | + | else ScriptResult(WriteSet([DataEntry("nstatus", nStatus)]), TransferSet(nil)) | |
88 | 88 | } | |
89 | 89 | ||
90 | 90 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 3 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let RSA = addressFromStringValue("3My9uDN1mW9uk1FZXEPGrShd4mue54JXzXU") | |
5 | 5 | ||
6 | 6 | let keeper = RSA | |
7 | 7 | ||
8 | 8 | let pub = getBinaryValue(keeper, "pub") | |
9 | 9 | ||
10 | 10 | @Callable(i) | |
11 | 11 | func f () = { | |
12 | 12 | let msg0 = getBinaryValue(keeper, "msg_0") | |
13 | 13 | let sig0 = getBinaryValue(keeper, "sig_0") | |
14 | 14 | let add0 = addressFromPublicKey(take(msg0, 32)) | |
15 | 15 | let msg1 = getBinaryValue(keeper, "msg_1") | |
16 | 16 | let sig1 = getBinaryValue(keeper, "sig_1") | |
17 | 17 | let add1 = addressFromPublicKey(take(msg1, 32)) | |
18 | 18 | let msg2 = getBinaryValue(keeper, "msg_2") | |
19 | 19 | let sig2 = getBinaryValue(keeper, "sig_2") | |
20 | 20 | let add2 = addressFromPublicKey(take(msg2, 32)) | |
21 | 21 | let msg3 = getBinaryValue(keeper, "msg_3") | |
22 | 22 | let sig3 = getBinaryValue(keeper, "sig_3") | |
23 | 23 | let add3 = addressFromPublicKey(take(msg3, 32)) | |
24 | 24 | let msg4 = getBinaryValue(keeper, "msg_4") | |
25 | 25 | let sig4 = getBinaryValue(keeper, "sig_4") | |
26 | 26 | let add4 = addressFromPublicKey(take(msg4, 32)) | |
27 | 27 | let add5 = addressFromPublicKey(take(drop(msg4, 32), 32)) | |
28 | 28 | let add6 = addressFromPublicKey(take(drop(drop(msg4, 32), 32), 32)) | |
29 | 29 | let add7 = addressFromPublicKey(take(drop(drop(drop(msg4, 32), 32), 32), 32)) | |
30 | 30 | let add8 = addressFromPublicKey(take(drop(drop(drop(drop(msg4, 32), 32), 32), 32), 32)) | |
31 | 31 | let add9 = addressFromPublicKey(take(drop(drop(drop(drop(drop(msg4, 32), 32), 32), 32), 32), 32)) | |
32 | 32 | let valid = if (if (if (if (rsaVerify(SHA512, msg0, sig0, pub)) | |
33 | 33 | then rsaVerify(SHA512, msg1, sig1, pub) | |
34 | 34 | else false) | |
35 | 35 | then rsaVerify(SHA512, msg2, sig2, pub) | |
36 | 36 | else false) | |
37 | 37 | then rsaVerify(SHA512, msg3, sig3, pub) | |
38 | 38 | else false) | |
39 | 39 | then rsaVerify(SHA512, msg4, sig4, pub) | |
40 | 40 | else false | |
41 | 41 | if (!(valid)) | |
42 | 42 | then throw("F") | |
43 | 43 | else ScriptResult(WriteSet([DataEntry("STATUS", "DONE")]), TransferSet(nil)) | |
44 | 44 | } | |
45 | 45 | ||
46 | 46 | ||
47 | 47 | ||
48 | 48 | @Callable(i) | |
49 | 49 | func f1 () = { | |
50 | 50 | let msg0 = getBinaryValue(keeper, "msg_0") | |
51 | 51 | let sig0 = getBinaryValue(keeper, "sig_0") | |
52 | 52 | let add0 = addressFromPublicKey(take(msg0, 32)) | |
53 | 53 | let msg1 = getBinaryValue(keeper, "msg_1") | |
54 | 54 | let sig1 = getBinaryValue(keeper, "sig_1") | |
55 | 55 | let add1 = addressFromPublicKey(take(msg1, 32)) | |
56 | 56 | let msg2 = getBinaryValue(keeper, "msg_2") | |
57 | 57 | let sig2 = getBinaryValue(keeper, "sig_2") | |
58 | 58 | let add2 = addressFromPublicKey(take(msg2, 32)) | |
59 | 59 | let msg3 = getBinaryValue(keeper, "msg_3") | |
60 | 60 | let sig3 = getBinaryValue(keeper, "sig_3") | |
61 | 61 | let add3 = addressFromPublicKey(take(msg3, 32)) | |
62 | 62 | let msg4 = getBinaryValue(keeper, "msg_4") | |
63 | 63 | let sig4 = getBinaryValue(keeper, "sig_4") | |
64 | 64 | let add4 = addressFromPublicKey(take(msg4, 32)) | |
65 | 65 | let add5 = addressFromPublicKey(take(drop(msg4, 32), 32)) | |
66 | 66 | let add6 = addressFromPublicKey(take(drop(drop(msg4, 32), 32), 32)) | |
67 | 67 | let add7 = addressFromPublicKey(take(drop(drop(drop(msg4, 32), 32), 32), 32)) | |
68 | 68 | let add8 = addressFromPublicKey(take(drop(drop(drop(drop(msg4, 32), 32), 32), 32), 32)) | |
69 | 69 | let add9 = addressFromPublicKey(take(drop(drop(drop(drop(drop(msg4, 32), 32), 32), 32), 32), 32)) | |
70 | 70 | let valid = if (if (if (if (rsaVerify(SHA512, msg0, sig0, pub)) | |
71 | 71 | then rsaVerify(SHA512, msg1, sig1, pub) | |
72 | 72 | else false) | |
73 | 73 | then rsaVerify(SHA512, msg2, sig2, pub) | |
74 | 74 | else false) | |
75 | 75 | then rsaVerify(SHA512, msg3, sig3, pub) | |
76 | 76 | else false) | |
77 | 77 | then rsaVerify(SHA512, msg4, sig4, pub) | |
78 | 78 | else false | |
79 | 79 | let nStatus = match getInteger(this, "nstatus") { | |
80 | 80 | case a: Int => | |
81 | 81 | a | |
82 | 82 | case _ => | |
83 | 83 | 0 | |
84 | 84 | } | |
85 | - | if (( | |
85 | + | if ((height >= nStatus)) | |
86 | 86 | then throw("F") | |
87 | - | else ScriptResult(WriteSet([DataEntry("nstatus", | |
87 | + | else ScriptResult(WriteSet([DataEntry("nstatus", nStatus)]), TransferSet(nil)) | |
88 | 88 | } | |
89 | 89 | ||
90 | 90 | ||
91 | 91 | @Verifier(tx) | |
92 | 92 | func standardVerifier () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
93 | 93 |
github/deemru/w8io/3ef1775 51.80 ms ◑