tx · 9wvGZv3kERjvzttNhsWSiY95nHszU95P2rNuCrtNRbHS 3N4mapsqVLDdiatjTF2rYB5KiLn2e6Y4eJb: -0.01400000 Waves 2019.01.30 12:45 [472830] smart account 3N4mapsqVLDdiatjTF2rYB5KiLn2e6Y4eJb > SELF 0.00000000 Waves
{ "type": 13, "id": "9wvGZv3kERjvzttNhsWSiY95nHszU95P2rNuCrtNRbHS", "fee": 1400000, "feeAssetId": null, "timestamp": 1548841539903, "version": 1, "sender": "3N4mapsqVLDdiatjTF2rYB5KiLn2e6Y4eJb", "senderPublicKey": "BTdTmTBfL5TMXno6wjKmpDfg3m4L5A71Kaujb4kJtuYe", "proofs": [ "66xcTzRznb1WzV4bfV1Xd2x2SG4TZHYkCfxUJ1HGEY2B2RC4x9pZvYbS3rsBYK4uk8nX3uyYGkqCE5gKfAUx6NFL" ], "script": "base64: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", "chainId": 84, "height": 472830, "spentComplexity": 0 } View: original | compacted Prev: HPEBwTUmdisQQzSVviqyXPR4wJzXNzkHLXsaPMdiYrku Next: none Diff:
Old | New | Differences | |
---|---|---|---|
53 | 53 | else false | |
54 | 54 | case t: TransferTransaction => | |
55 | 55 | let voteSecret = toBase58String(sha256(t.attachment)) | |
56 | - | let voterAddress = addressFromPublicKey( | |
56 | + | let voterAddress = addressFromPublicKey(t.proofs[0]) | |
57 | 57 | if (isDefined(getString(voteBank, voteSecret))) | |
58 | 58 | then { | |
59 | 59 | let voteStarter = extract(addressFromString(extract(getString(voteBank, voteSecret)))) | |
70 | 70 | else false) | |
71 | 71 | then (wavesBalance(voterAddress) > 100000000) | |
72 | 72 | else false) | |
73 | - | then sigVerify(t.bodyBytes, t.proofs[ | |
73 | + | then sigVerify(t.bodyBytes, t.proofs[1], t.proofs[0]) | |
74 | 74 | else false | |
75 | 75 | } | |
76 | 76 | else false |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 1 #-} | |
2 | 2 | {-# CONTENT_TYPE EXPRESSION #-} | |
3 | 3 | let voteBank = addressFromPublicKey(fromBase58String("BTdTmTBfL5TMXno6wjKmpDfg3m4L5A71Kaujb4kJtuYe")) | |
4 | 4 | let minimalVotingHeight = 10 | |
5 | 5 | match tx { | |
6 | 6 | case d: DataTransaction => | |
7 | 7 | if ((size(d.data) == 3)) | |
8 | 8 | then { | |
9 | 9 | let feeTransferId = transactionById(d.proofs[0]) | |
10 | 10 | let assetTranserId = transactionById(d.proofs[1]) | |
11 | 11 | match assetTranserId { | |
12 | 12 | case aT: TransferTransaction => | |
13 | 13 | match feeTransferId { | |
14 | 14 | case fT: TransferTransaction => | |
15 | 15 | let votingHeight = d.data[1].value | |
16 | 16 | if (if (if (if (if (if (if (if (if (if (if (if (!(isDefined(getString(voteBank, d.data[0].key)))) | |
17 | 17 | then isDefined(getString(aT.sender, "YES")) | |
18 | 18 | else false) | |
19 | 19 | then isDefined(getString(aT.sender, "NO")) | |
20 | 20 | else false) | |
21 | 21 | then (aT.recipient == voteBank) | |
22 | 22 | else false) | |
23 | 23 | then (fT.recipient == voteBank) | |
24 | 24 | else false) | |
25 | 25 | then (fT.amount >= (aT.amount * 500000)) | |
26 | 26 | else false) | |
27 | 27 | then (d.data[0].key == toBase58String(sha256(aT.attachment))) | |
28 | 28 | else false) | |
29 | 29 | then (d.data[0].key == toBase58String(sha256(fT.attachment))) | |
30 | 30 | else false) | |
31 | 31 | then (d.data[1].key == (toBase58String(sha256(fT.attachment)) + "_height")) | |
32 | 32 | else false) | |
33 | 33 | then (d.data[2].key == (toBase58String(sha256(fT.attachment)) + "_asset")) | |
34 | 34 | else false) | |
35 | 35 | then match votingHeight { | |
36 | 36 | case h: Int => | |
37 | 37 | (h > height) | |
38 | 38 | case _ => | |
39 | 39 | false | |
40 | 40 | } | |
41 | 41 | else false) | |
42 | 42 | then (d.data[2].value == aT.assetId) | |
43 | 43 | else false) | |
44 | 44 | then sigVerify(d.bodyBytes, d.proofs[3], d.proofs[2]) | |
45 | 45 | else false | |
46 | 46 | case _ => | |
47 | 47 | false | |
48 | 48 | } | |
49 | 49 | case _ => | |
50 | 50 | false | |
51 | 51 | } | |
52 | 52 | } | |
53 | 53 | else false | |
54 | 54 | case t: TransferTransaction => | |
55 | 55 | let voteSecret = toBase58String(sha256(t.attachment)) | |
56 | - | let voterAddress = addressFromPublicKey( | |
56 | + | let voterAddress = addressFromPublicKey(t.proofs[0]) | |
57 | 57 | if (isDefined(getString(voteBank, voteSecret))) | |
58 | 58 | then { | |
59 | 59 | let voteStarter = extract(addressFromString(extract(getString(voteBank, voteSecret)))) | |
60 | 60 | if (if (if (if (if (if ((extract(getInteger(voteBank, (voteSecret + "_height"))) > height)) | |
61 | 61 | then if ((addressFromRecipient(t.recipient) == addressFromString(extract(getString(voteStarter, "YES"))))) | |
62 | 62 | then true | |
63 | 63 | else (addressFromRecipient(t.recipient) == addressFromString(extract(getString(voteStarter, "NO")))) | |
64 | 64 | else false) | |
65 | 65 | then (t.assetId == extract(getBinary(voteBank, (voteSecret + "_asset")))) | |
66 | 66 | else false) | |
67 | 67 | then (t.amount == 1) | |
68 | 68 | else false) | |
69 | 69 | then (t.fee == 500000) | |
70 | 70 | else false) | |
71 | 71 | then (wavesBalance(voterAddress) > 100000000) | |
72 | 72 | else false) | |
73 | - | then sigVerify(t.bodyBytes, t.proofs[ | |
73 | + | then sigVerify(t.bodyBytes, t.proofs[1], t.proofs[0]) | |
74 | 74 | else false | |
75 | 75 | } | |
76 | 76 | else false | |
77 | 77 | case s: SetScriptTransaction => | |
78 | 78 | sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
79 | 79 | case _ => | |
80 | 80 | false | |
81 | 81 | } |
github/deemru/w8io/026f985 33.82 ms ◑