tx · EdzjEi9Tyr3j4npz6bQ5hFTuDfttFqfpcwqnckJGFPXu 3PMZXEJXC7LEJh75ZgGmuB8rKc74kZvecro: -0.01400000 Waves 2019.04.04 15:46 [1467689] smart account 3PMZXEJXC7LEJh75ZgGmuB8rKc74kZvecro > SELF 0.00000000 Waves
{ "type": 13, "id": "EdzjEi9Tyr3j4npz6bQ5hFTuDfttFqfpcwqnckJGFPXu", "fee": 1400000, "feeAssetId": null, "timestamp": 1554381982258, "version": 1, "sender": "3PMZXEJXC7LEJh75ZgGmuB8rKc74kZvecro", "senderPublicKey": "7iVcq9EbiExo1t2pgUgpqnKEcofjv7Qdo7oJdnAxqsBB", "proofs": [ "2NkXK9gR8cLojceX3ntmEiWJN6upR2vvrR62QHSVRxMZDGTWU5sftcqNmVPsqFm33YcS4D2WkhJEkpjV6FVHRcs9" ], "script": "base64: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", "chainId": 87, "height": 1467689, "spentComplexity": 0 } View: original | compacted Prev: HwDv2m8NYiJde59s8oFoMcWDLFbJ4Jj2WQ9VigWHwTPQ Next: none Diff:
Old | New | Differences | |
---|---|---|---|
16 | 16 | let iInit = 3 | |
17 | 17 | match tx { | |
18 | 18 | case thisTx: TransferTransaction => | |
19 | - | match transactionById(thisTx.proofs[iTrig]) { | |
20 | - | case triggerTx: TransferTransaction => | |
21 | - | if ((triggerTx.recipient == aliasInit)) | |
22 | - | then { | |
23 | - | let initTx = thisTx | |
24 | - | let triggerInitTx = triggerTx | |
25 | - | let initTxbodyBytes = (initTx.bodyBytes + initTx.proofs[iTrig]) | |
26 | - | let R = initTx.proofs[iRaw] | |
27 | - | if (if (if (if (if (if (if (if (if (!(isDefined(triggerInitTx.assetId))) | |
28 | - | then (triggerInitTx.amount >= triggerMinCost) | |
29 | - | else false) | |
30 | - | then (triggerInitTx.sender == initTx.recipient) | |
31 | - | else false) | |
32 | - | then !(isDefined(initTx.feeAssetId)) | |
33 | - | else false) | |
34 | - | then if ((initTx.fee == triggerMaxCost)) | |
35 | - | then true | |
36 | - | else (initTx.fee == triggerInitTx.amount) | |
37 | - | else false) | |
38 | - | then (initTx.assetId == assetInit) | |
39 | - | else false) | |
40 | - | then (initTx.amount == 1) | |
41 | - | else false) | |
42 | - | then (size(initTx.attachment) == codeSize) | |
43 | - | else false) | |
44 | - | then (initTx.attachment == toBytes(toBase58String((codeR + R)))) | |
45 | - | else false) | |
46 | - | then sigVerify(initTxbodyBytes, initTx.proofs[iSig], vecroPublicKey) | |
19 | + | if (if (!(isDefined(thisTx.assetId))) | |
20 | + | then true | |
21 | + | else if ((thisTx.assetId != assetInit)) | |
22 | + | then (thisTx.assetId != assetRandom) | |
23 | + | else false) | |
24 | + | then sigVerify(tx.bodyBytes, tx.proofs[iSig], vecroPublicKey) | |
25 | + | else match transactionById(thisTx.proofs[iTrig]) { | |
26 | + | case triggerTx: TransferTransaction => | |
27 | + | if ((triggerTx.recipient == aliasInit)) | |
28 | + | then { | |
29 | + | let initTx = thisTx | |
30 | + | let triggerInitTx = triggerTx | |
31 | + | let initTxbodyBytes = (initTx.bodyBytes + initTx.proofs[iTrig]) | |
32 | + | let R = initTx.proofs[iRaw] | |
33 | + | if (if (if (if (if (if (if (if (if (!(isDefined(triggerInitTx.assetId))) | |
34 | + | then (triggerInitTx.amount >= triggerMinCost) | |
35 | + | else false) | |
36 | + | then (triggerInitTx.sender == initTx.recipient) | |
37 | + | else false) | |
38 | + | then !(isDefined(initTx.feeAssetId)) | |
39 | + | else false) | |
40 | + | then if ((initTx.fee == triggerMaxCost)) | |
41 | + | then true | |
42 | + | else (initTx.fee == triggerInitTx.amount) | |
43 | + | else false) | |
44 | + | then (initTx.assetId == assetInit) | |
45 | + | else false) | |
46 | + | then (initTx.amount == 1) | |
47 | + | else false) | |
48 | + | then (size(initTx.attachment) == codeSize) | |
49 | + | else false) | |
50 | + | then (initTx.attachment == toBytes(toBase58String((codeR + R)))) | |
51 | + | else false) | |
52 | + | then sigVerify(initTxbodyBytes, initTx.proofs[iSig], vecroPublicKey) | |
53 | + | else false | |
54 | + | } | |
55 | + | else if ((triggerTx.recipient == aliasRandom)) | |
56 | + | then match transactionById(thisTx.proofs[iInit]) { | |
57 | + | case initTx: TransferTransaction => | |
58 | + | match transactionById(initTx.proofs[iTrig]) { | |
59 | + | case triggerInitTx: TransferTransaction => | |
60 | + | if ((triggerInitTx.recipient == aliasInit)) | |
61 | + | then { | |
62 | + | let randomTx = thisTx | |
63 | + | let triggerRandomTx = triggerTx | |
64 | + | let initTxbodyBytes = (initTx.bodyBytes + initTx.proofs[iTrig]) | |
65 | + | let randomTxbodyBytes = ((randomTx.bodyBytes + randomTx.proofs[iTrig]) + randomTx.proofs[iInit]) | |
66 | + | let R = initTx.proofs[iRaw] | |
67 | + | let S = thisTx.proofs[iRaw] | |
68 | + | let sig = (R + S) | |
69 | + | let msg = triggerRandomTx.attachment | |
70 | + | if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if ((triggerRandomTx.sender == triggerInitTx.sender)) | |
71 | + | then (take(msg, codeSize) == initTx.attachment) | |
72 | + | else false) | |
73 | + | then sigVerify(msg, sig, vecroPublicKey) | |
74 | + | else false) | |
75 | + | then !(isDefined(triggerRandomTx.assetId)) | |
76 | + | else false) | |
77 | + | then (triggerRandomTx.amount >= triggerMinCost) | |
78 | + | else false) | |
79 | + | then (triggerRandomTx.sender == randomTx.recipient) | |
80 | + | else false) | |
81 | + | then !(isDefined(randomTx.feeAssetId)) | |
82 | + | else false) | |
83 | + | then if ((randomTx.fee == triggerMaxCost)) | |
84 | + | then true | |
85 | + | else (randomTx.fee == triggerRandomTx.amount) | |
86 | + | else false) | |
87 | + | then (randomTx.assetId == assetRandom) | |
88 | + | else false) | |
89 | + | then (randomTx.amount == 1) | |
90 | + | else false) | |
91 | + | then (size(randomTx.attachment) == codeSize) | |
92 | + | else false) | |
93 | + | then (randomTx.attachment == toBytes(toBase58String((codeS + S)))) | |
94 | + | else false) | |
95 | + | then sigVerify(randomTxbodyBytes, randomTx.proofs[iSig], vecroPublicKey) | |
96 | + | else false) | |
97 | + | then !(isDefined(triggerInitTx.assetId)) | |
98 | + | else false) | |
99 | + | then (triggerInitTx.amount >= triggerMinCost) | |
100 | + | else false) | |
101 | + | then (triggerInitTx.sender == initTx.recipient) | |
102 | + | else false) | |
103 | + | then !(isDefined(initTx.feeAssetId)) | |
104 | + | else false) | |
105 | + | then if ((initTx.fee == triggerMaxCost)) | |
106 | + | then true | |
107 | + | else (initTx.fee == triggerInitTx.amount) | |
108 | + | else false) | |
109 | + | then (initTx.assetId == assetInit) | |
110 | + | else false) | |
111 | + | then (initTx.amount == 1) | |
112 | + | else false) | |
113 | + | then (size(initTx.attachment) == codeSize) | |
114 | + | else false) | |
115 | + | then (initTx.attachment == toBytes(toBase58String((codeR + R)))) | |
116 | + | else false) | |
117 | + | then sigVerify(initTxbodyBytes, initTx.proofs[iSig], vecroPublicKey) | |
118 | + | else false | |
119 | + | } | |
120 | + | else false | |
121 | + | case _ => | |
122 | + | false | |
123 | + | } | |
124 | + | case _ => | |
125 | + | false | |
126 | + | } | |
47 | 127 | else false | |
48 | - | } | |
49 | - | else if ((triggerTx.recipient == aliasRandom)) | |
50 | - | then match transactionById(thisTx.proofs[iInit]) { | |
51 | - | case initTx: TransferTransaction => | |
52 | - | match transactionById(initTx.proofs[iTrig]) { | |
53 | - | case triggerInitTx: TransferTransaction => | |
54 | - | if ((triggerInitTx.recipient == aliasInit)) | |
55 | - | then { | |
56 | - | let randomTx = thisTx | |
57 | - | let triggerRandomTx = triggerTx | |
58 | - | let initTxbodyBytes = (initTx.bodyBytes + initTx.proofs[iTrig]) | |
59 | - | let randomTxbodyBytes = ((randomTx.bodyBytes + randomTx.proofs[iTrig]) + randomTx.proofs[iInit]) | |
60 | - | let R = initTx.proofs[iRaw] | |
61 | - | let S = thisTx.proofs[iRaw] | |
62 | - | let sig = (R + S) | |
63 | - | let msg = triggerRandomTx.attachment | |
64 | - | if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if ((triggerRandomTx.sender == triggerInitTx.sender)) | |
65 | - | then (take(msg, codeSize) == initTx.attachment) | |
66 | - | else false) | |
67 | - | then sigVerify(msg, sig, vecroPublicKey) | |
68 | - | else false) | |
69 | - | then !(isDefined(triggerRandomTx.assetId)) | |
70 | - | else false) | |
71 | - | then (triggerRandomTx.amount >= triggerMinCost) | |
72 | - | else false) | |
73 | - | then (triggerRandomTx.sender == randomTx.recipient) | |
74 | - | else false) | |
75 | - | then !(isDefined(randomTx.feeAssetId)) | |
76 | - | else false) | |
77 | - | then if ((randomTx.fee == triggerMaxCost)) | |
78 | - | then true | |
79 | - | else (randomTx.fee == triggerRandomTx.amount) | |
80 | - | else false) | |
81 | - | then (randomTx.assetId == assetRandom) | |
82 | - | else false) | |
83 | - | then (randomTx.amount == 1) | |
84 | - | else false) | |
85 | - | then (size(randomTx.attachment) == codeSize) | |
86 | - | else false) | |
87 | - | then (randomTx.attachment == toBytes(toBase58String((codeS + S)))) | |
88 | - | else false) | |
89 | - | then sigVerify(randomTxbodyBytes, randomTx.proofs[iSig], vecroPublicKey) | |
90 | - | else false) | |
91 | - | then !(isDefined(triggerInitTx.assetId)) | |
92 | - | else false) | |
93 | - | then (triggerInitTx.amount >= triggerMinCost) | |
94 | - | else false) | |
95 | - | then (triggerInitTx.sender == initTx.recipient) | |
96 | - | else false) | |
97 | - | then !(isDefined(initTx.feeAssetId)) | |
98 | - | else false) | |
99 | - | then if ((initTx.fee == triggerMaxCost)) | |
100 | - | then true | |
101 | - | else (initTx.fee == triggerInitTx.amount) | |
102 | - | else false) | |
103 | - | then (initTx.assetId == assetInit) | |
104 | - | else false) | |
105 | - | then (initTx.amount == 1) | |
106 | - | else false) | |
107 | - | then (size(initTx.attachment) == codeSize) | |
108 | - | else false) | |
109 | - | then (initTx.attachment == toBytes(toBase58String((codeR + R)))) | |
110 | - | else false) | |
111 | - | then sigVerify(initTxbodyBytes, initTx.proofs[iSig], vecroPublicKey) | |
112 | - | else false | |
113 | - | } | |
114 | - | else false | |
115 | - | case _ => | |
116 | - | false | |
117 | - | } | |
118 | - | case _ => | |
119 | - | false | |
120 | - | } | |
121 | - | else false | |
122 | - | case _ => | |
123 | - | false | |
124 | - | } | |
128 | + | case _ => | |
129 | + | false | |
130 | + | } | |
125 | 131 | case _ => | |
126 | - | | |
132 | + | false | |
127 | 133 | } |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 2 #-} | |
2 | 2 | {-# CONTENT_TYPE EXPRESSION #-} | |
3 | 3 | let vecroPublicKey = tx.senderPublicKey | |
4 | 4 | let triggerMinCost = 500000 | |
5 | 5 | let triggerMaxCost = 100000000 | |
6 | 6 | let aliasInit = Alias("init@vecro") | |
7 | 7 | let aliasRandom = Alias("random@vecro") | |
8 | 8 | let assetInit = base58'6sQPWhyFc3yE1pHUsTvQKn9yLjtDx6GTPk5VPwFukxH7' | |
9 | 9 | let assetRandom = base58'FRm3pU6cM6zmMWC1KGafHweGNg8Ag7gS9NX3FsZFMEGg' | |
10 | 10 | let codeR = toBytes("R") | |
11 | 11 | let codeS = toBytes("S") | |
12 | 12 | let codeSize = 45 | |
13 | 13 | let iSig = 0 | |
14 | 14 | let iRaw = 1 | |
15 | 15 | let iTrig = 2 | |
16 | 16 | let iInit = 3 | |
17 | 17 | match tx { | |
18 | 18 | case thisTx: TransferTransaction => | |
19 | - | match transactionById(thisTx.proofs[iTrig]) { | |
20 | - | case triggerTx: TransferTransaction => | |
21 | - | if ((triggerTx.recipient == aliasInit)) | |
22 | - | then { | |
23 | - | let initTx = thisTx | |
24 | - | let triggerInitTx = triggerTx | |
25 | - | let initTxbodyBytes = (initTx.bodyBytes + initTx.proofs[iTrig]) | |
26 | - | let R = initTx.proofs[iRaw] | |
27 | - | if (if (if (if (if (if (if (if (if (!(isDefined(triggerInitTx.assetId))) | |
28 | - | then (triggerInitTx.amount >= triggerMinCost) | |
29 | - | else false) | |
30 | - | then (triggerInitTx.sender == initTx.recipient) | |
31 | - | else false) | |
32 | - | then !(isDefined(initTx.feeAssetId)) | |
33 | - | else false) | |
34 | - | then if ((initTx.fee == triggerMaxCost)) | |
35 | - | then true | |
36 | - | else (initTx.fee == triggerInitTx.amount) | |
37 | - | else false) | |
38 | - | then (initTx.assetId == assetInit) | |
39 | - | else false) | |
40 | - | then (initTx.amount == 1) | |
41 | - | else false) | |
42 | - | then (size(initTx.attachment) == codeSize) | |
43 | - | else false) | |
44 | - | then (initTx.attachment == toBytes(toBase58String((codeR + R)))) | |
45 | - | else false) | |
46 | - | then sigVerify(initTxbodyBytes, initTx.proofs[iSig], vecroPublicKey) | |
19 | + | if (if (!(isDefined(thisTx.assetId))) | |
20 | + | then true | |
21 | + | else if ((thisTx.assetId != assetInit)) | |
22 | + | then (thisTx.assetId != assetRandom) | |
23 | + | else false) | |
24 | + | then sigVerify(tx.bodyBytes, tx.proofs[iSig], vecroPublicKey) | |
25 | + | else match transactionById(thisTx.proofs[iTrig]) { | |
26 | + | case triggerTx: TransferTransaction => | |
27 | + | if ((triggerTx.recipient == aliasInit)) | |
28 | + | then { | |
29 | + | let initTx = thisTx | |
30 | + | let triggerInitTx = triggerTx | |
31 | + | let initTxbodyBytes = (initTx.bodyBytes + initTx.proofs[iTrig]) | |
32 | + | let R = initTx.proofs[iRaw] | |
33 | + | if (if (if (if (if (if (if (if (if (!(isDefined(triggerInitTx.assetId))) | |
34 | + | then (triggerInitTx.amount >= triggerMinCost) | |
35 | + | else false) | |
36 | + | then (triggerInitTx.sender == initTx.recipient) | |
37 | + | else false) | |
38 | + | then !(isDefined(initTx.feeAssetId)) | |
39 | + | else false) | |
40 | + | then if ((initTx.fee == triggerMaxCost)) | |
41 | + | then true | |
42 | + | else (initTx.fee == triggerInitTx.amount) | |
43 | + | else false) | |
44 | + | then (initTx.assetId == assetInit) | |
45 | + | else false) | |
46 | + | then (initTx.amount == 1) | |
47 | + | else false) | |
48 | + | then (size(initTx.attachment) == codeSize) | |
49 | + | else false) | |
50 | + | then (initTx.attachment == toBytes(toBase58String((codeR + R)))) | |
51 | + | else false) | |
52 | + | then sigVerify(initTxbodyBytes, initTx.proofs[iSig], vecroPublicKey) | |
53 | + | else false | |
54 | + | } | |
55 | + | else if ((triggerTx.recipient == aliasRandom)) | |
56 | + | then match transactionById(thisTx.proofs[iInit]) { | |
57 | + | case initTx: TransferTransaction => | |
58 | + | match transactionById(initTx.proofs[iTrig]) { | |
59 | + | case triggerInitTx: TransferTransaction => | |
60 | + | if ((triggerInitTx.recipient == aliasInit)) | |
61 | + | then { | |
62 | + | let randomTx = thisTx | |
63 | + | let triggerRandomTx = triggerTx | |
64 | + | let initTxbodyBytes = (initTx.bodyBytes + initTx.proofs[iTrig]) | |
65 | + | let randomTxbodyBytes = ((randomTx.bodyBytes + randomTx.proofs[iTrig]) + randomTx.proofs[iInit]) | |
66 | + | let R = initTx.proofs[iRaw] | |
67 | + | let S = thisTx.proofs[iRaw] | |
68 | + | let sig = (R + S) | |
69 | + | let msg = triggerRandomTx.attachment | |
70 | + | if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if ((triggerRandomTx.sender == triggerInitTx.sender)) | |
71 | + | then (take(msg, codeSize) == initTx.attachment) | |
72 | + | else false) | |
73 | + | then sigVerify(msg, sig, vecroPublicKey) | |
74 | + | else false) | |
75 | + | then !(isDefined(triggerRandomTx.assetId)) | |
76 | + | else false) | |
77 | + | then (triggerRandomTx.amount >= triggerMinCost) | |
78 | + | else false) | |
79 | + | then (triggerRandomTx.sender == randomTx.recipient) | |
80 | + | else false) | |
81 | + | then !(isDefined(randomTx.feeAssetId)) | |
82 | + | else false) | |
83 | + | then if ((randomTx.fee == triggerMaxCost)) | |
84 | + | then true | |
85 | + | else (randomTx.fee == triggerRandomTx.amount) | |
86 | + | else false) | |
87 | + | then (randomTx.assetId == assetRandom) | |
88 | + | else false) | |
89 | + | then (randomTx.amount == 1) | |
90 | + | else false) | |
91 | + | then (size(randomTx.attachment) == codeSize) | |
92 | + | else false) | |
93 | + | then (randomTx.attachment == toBytes(toBase58String((codeS + S)))) | |
94 | + | else false) | |
95 | + | then sigVerify(randomTxbodyBytes, randomTx.proofs[iSig], vecroPublicKey) | |
96 | + | else false) | |
97 | + | then !(isDefined(triggerInitTx.assetId)) | |
98 | + | else false) | |
99 | + | then (triggerInitTx.amount >= triggerMinCost) | |
100 | + | else false) | |
101 | + | then (triggerInitTx.sender == initTx.recipient) | |
102 | + | else false) | |
103 | + | then !(isDefined(initTx.feeAssetId)) | |
104 | + | else false) | |
105 | + | then if ((initTx.fee == triggerMaxCost)) | |
106 | + | then true | |
107 | + | else (initTx.fee == triggerInitTx.amount) | |
108 | + | else false) | |
109 | + | then (initTx.assetId == assetInit) | |
110 | + | else false) | |
111 | + | then (initTx.amount == 1) | |
112 | + | else false) | |
113 | + | then (size(initTx.attachment) == codeSize) | |
114 | + | else false) | |
115 | + | then (initTx.attachment == toBytes(toBase58String((codeR + R)))) | |
116 | + | else false) | |
117 | + | then sigVerify(initTxbodyBytes, initTx.proofs[iSig], vecroPublicKey) | |
118 | + | else false | |
119 | + | } | |
120 | + | else false | |
121 | + | case _ => | |
122 | + | false | |
123 | + | } | |
124 | + | case _ => | |
125 | + | false | |
126 | + | } | |
47 | 127 | else false | |
48 | - | } | |
49 | - | else if ((triggerTx.recipient == aliasRandom)) | |
50 | - | then match transactionById(thisTx.proofs[iInit]) { | |
51 | - | case initTx: TransferTransaction => | |
52 | - | match transactionById(initTx.proofs[iTrig]) { | |
53 | - | case triggerInitTx: TransferTransaction => | |
54 | - | if ((triggerInitTx.recipient == aliasInit)) | |
55 | - | then { | |
56 | - | let randomTx = thisTx | |
57 | - | let triggerRandomTx = triggerTx | |
58 | - | let initTxbodyBytes = (initTx.bodyBytes + initTx.proofs[iTrig]) | |
59 | - | let randomTxbodyBytes = ((randomTx.bodyBytes + randomTx.proofs[iTrig]) + randomTx.proofs[iInit]) | |
60 | - | let R = initTx.proofs[iRaw] | |
61 | - | let S = thisTx.proofs[iRaw] | |
62 | - | let sig = (R + S) | |
63 | - | let msg = triggerRandomTx.attachment | |
64 | - | if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if (if ((triggerRandomTx.sender == triggerInitTx.sender)) | |
65 | - | then (take(msg, codeSize) == initTx.attachment) | |
66 | - | else false) | |
67 | - | then sigVerify(msg, sig, vecroPublicKey) | |
68 | - | else false) | |
69 | - | then !(isDefined(triggerRandomTx.assetId)) | |
70 | - | else false) | |
71 | - | then (triggerRandomTx.amount >= triggerMinCost) | |
72 | - | else false) | |
73 | - | then (triggerRandomTx.sender == randomTx.recipient) | |
74 | - | else false) | |
75 | - | then !(isDefined(randomTx.feeAssetId)) | |
76 | - | else false) | |
77 | - | then if ((randomTx.fee == triggerMaxCost)) | |
78 | - | then true | |
79 | - | else (randomTx.fee == triggerRandomTx.amount) | |
80 | - | else false) | |
81 | - | then (randomTx.assetId == assetRandom) | |
82 | - | else false) | |
83 | - | then (randomTx.amount == 1) | |
84 | - | else false) | |
85 | - | then (size(randomTx.attachment) == codeSize) | |
86 | - | else false) | |
87 | - | then (randomTx.attachment == toBytes(toBase58String((codeS + S)))) | |
88 | - | else false) | |
89 | - | then sigVerify(randomTxbodyBytes, randomTx.proofs[iSig], vecroPublicKey) | |
90 | - | else false) | |
91 | - | then !(isDefined(triggerInitTx.assetId)) | |
92 | - | else false) | |
93 | - | then (triggerInitTx.amount >= triggerMinCost) | |
94 | - | else false) | |
95 | - | then (triggerInitTx.sender == initTx.recipient) | |
96 | - | else false) | |
97 | - | then !(isDefined(initTx.feeAssetId)) | |
98 | - | else false) | |
99 | - | then if ((initTx.fee == triggerMaxCost)) | |
100 | - | then true | |
101 | - | else (initTx.fee == triggerInitTx.amount) | |
102 | - | else false) | |
103 | - | then (initTx.assetId == assetInit) | |
104 | - | else false) | |
105 | - | then (initTx.amount == 1) | |
106 | - | else false) | |
107 | - | then (size(initTx.attachment) == codeSize) | |
108 | - | else false) | |
109 | - | then (initTx.attachment == toBytes(toBase58String((codeR + R)))) | |
110 | - | else false) | |
111 | - | then sigVerify(initTxbodyBytes, initTx.proofs[iSig], vecroPublicKey) | |
112 | - | else false | |
113 | - | } | |
114 | - | else false | |
115 | - | case _ => | |
116 | - | false | |
117 | - | } | |
118 | - | case _ => | |
119 | - | false | |
120 | - | } | |
121 | - | else false | |
122 | - | case _ => | |
123 | - | false | |
124 | - | } | |
128 | + | case _ => | |
129 | + | false | |
130 | + | } | |
125 | 131 | case _ => | |
126 | - | | |
132 | + | false | |
127 | 133 | } |
github/deemru/w8io/3ef1775 88.90 ms ◑