tx · ATjg6MaVfZLT2z2mMzzmThxXzyfJSwrc4r4u5kxjZwY3 3P7ok1T2xn87ea5xjxBPFZPNeShgSqHeaHg: -0.01400000 Waves 2020.01.02 21:32 [1867006] smart account 3P7ok1T2xn87ea5xjxBPFZPNeShgSqHeaHg > SELF 0.00000000 Waves
{ "type": 13, "id": "ATjg6MaVfZLT2z2mMzzmThxXzyfJSwrc4r4u5kxjZwY3", "fee": 1400000, "feeAssetId": null, "timestamp": 1577989944813, "version": 1, "sender": "3P7ok1T2xn87ea5xjxBPFZPNeShgSqHeaHg", "senderPublicKey": "5KD6eu1HF3Fnzdr5L6ebB4u1fQEDtLwtpvTGJfKgQc4h", "proofs": [ "5sU4gApLFZftLua9KVgHEPj8tUadXocgUNKKzbMkpeeNRzWTMXpR2Qj2PsCwvRdQjQZRCcpUmyzC77TY4N7Pky1G", "5WQhaLbrCsBsLDabfL49DDRMwouw61chjTk9xzNonfMV9anxtKZJeVFTjcYx4TdgfFo1uA6giwXUcQp4bQeLazpn" ], "script": "base64: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", "chainId": 87, "height": 1867006, "spentComplexity": 0 } View: original | compacted Prev: 2aqrkvdgUT6EUGy2ca28nb1tANUwJogScmQcHoYG5C63 Next: CcFWaVLFcAXc6xDfC1FkoxGgCBzVkyVzDdT3VpHYd3Q Diff:
Old | New | Differences | |
---|---|---|---|
22 | 22 | else (assetId == base58'34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ')) | |
23 | 23 | then true | |
24 | 24 | else (assetId == base58'DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p') | |
25 | - | ||
26 | - | func checkProofs (cnt,sig) = { | |
27 | - | func isSigned (chk,pub) = if (chk) | |
28 | - | then true | |
29 | - | else sigVerify(tx.bodyBytes, sig, pub) | |
30 | - | ||
31 | - | (cnt + (if ({ | |
32 | - | let $list22342276 = investorPubKeys | |
33 | - | let $size22342276 = size($list22342276) | |
34 | - | let $acc022342276 = false | |
35 | - | if (($size22342276 == 0)) | |
36 | - | then $acc022342276 | |
37 | - | else { | |
38 | - | let $acc122342276 = isSigned($acc022342276, $list22342276[0]) | |
39 | - | if (($size22342276 == 1)) | |
40 | - | then $acc122342276 | |
41 | - | else { | |
42 | - | let $acc222342276 = isSigned($acc122342276, $list22342276[1]) | |
43 | - | if (($size22342276 == 2)) | |
44 | - | then $acc222342276 | |
45 | - | else { | |
46 | - | let $acc322342276 = isSigned($acc222342276, $list22342276[2]) | |
47 | - | if (($size22342276 == 3)) | |
48 | - | then $acc322342276 | |
49 | - | else { | |
50 | - | let $acc422342276 = isSigned($acc322342276, $list22342276[3]) | |
51 | - | if (($size22342276 == 4)) | |
52 | - | then $acc422342276 | |
53 | - | else { | |
54 | - | let $acc522342276 = isSigned($acc422342276, $list22342276[4]) | |
55 | - | if (($size22342276 == 5)) | |
56 | - | then $acc522342276 | |
57 | - | else { | |
58 | - | let $acc622342276 = isSigned($acc522342276, $list22342276[5]) | |
59 | - | if (($size22342276 == 6)) | |
60 | - | then $acc622342276 | |
61 | - | else { | |
62 | - | let $acc722342276 = isSigned($acc622342276, $list22342276[6]) | |
63 | - | if (($size22342276 == 7)) | |
64 | - | then $acc722342276 | |
65 | - | else { | |
66 | - | let $acc822342276 = isSigned($acc722342276, $list22342276[7]) | |
67 | - | if (($size22342276 == 8)) | |
68 | - | then $acc822342276 | |
69 | - | else { | |
70 | - | let $acc922342276 = isSigned($acc822342276, $list22342276[8]) | |
71 | - | if (($size22342276 == 9)) | |
72 | - | then $acc922342276 | |
73 | - | else { | |
74 | - | let $acc1022342276 = isSigned($acc922342276, $list22342276[9]) | |
75 | - | if (($size22342276 == 10)) | |
76 | - | then $acc1022342276 | |
77 | - | else { | |
78 | - | let $acc1122342276 = isSigned($acc1022342276, $list22342276[10]) | |
79 | - | throw("List size exceed 10") | |
80 | - | } | |
81 | - | } | |
82 | - | } | |
83 | - | } | |
84 | - | } | |
85 | - | } | |
86 | - | } | |
87 | - | } | |
88 | - | } | |
89 | - | } | |
90 | - | } | |
91 | - | }) | |
92 | - | then 1 | |
93 | - | else 0)) | |
94 | - | } | |
95 | 25 | ||
96 | 26 | match tx { | |
97 | 27 | case o: Order => | |
157 | 87 | else lockExpired | |
158 | 88 | else false | |
159 | 89 | case s: SetScriptTransaction => | |
160 | - | let rightSetScript = ({ | |
161 | - | let $list53005334 = s.proofs | |
162 | - | let $size53005334 = size($list53005334) | |
163 | - | let $acc053005334 = 0 | |
164 | - | if (($size53005334 == 0)) | |
165 | - | then $acc053005334 | |
166 | - | else { | |
167 | - | let $acc153005334 = checkProofs($acc053005334, $list53005334[0]) | |
168 | - | if (($size53005334 == 1)) | |
169 | - | then $acc153005334 | |
170 | - | else { | |
171 | - | let $acc253005334 = checkProofs($acc153005334, $list53005334[1]) | |
172 | - | if (($size53005334 == 2)) | |
173 | - | then $acc253005334 | |
174 | - | else { | |
175 | - | let $acc353005334 = checkProofs($acc253005334, $list53005334[2]) | |
176 | - | if (($size53005334 == 3)) | |
177 | - | then $acc353005334 | |
178 | - | else { | |
179 | - | let $acc453005334 = checkProofs($acc353005334, $list53005334[3]) | |
180 | - | if (($size53005334 == 4)) | |
181 | - | then $acc453005334 | |
182 | - | else { | |
183 | - | let $acc553005334 = checkProofs($acc453005334, $list53005334[4]) | |
184 | - | if (($size53005334 == 5)) | |
185 | - | then $acc553005334 | |
186 | - | else { | |
187 | - | let $acc653005334 = checkProofs($acc553005334, $list53005334[5]) | |
188 | - | if (($size53005334 == 6)) | |
189 | - | then $acc653005334 | |
190 | - | else { | |
191 | - | let $acc753005334 = checkProofs($acc653005334, $list53005334[6]) | |
192 | - | if (($size53005334 == 7)) | |
193 | - | then $acc753005334 | |
194 | - | else { | |
195 | - | let $acc853005334 = checkProofs($acc753005334, $list53005334[7]) | |
196 | - | if (($size53005334 == 8)) | |
197 | - | then $acc853005334 | |
198 | - | else { | |
199 | - | let $acc953005334 = checkProofs($acc853005334, $list53005334[8]) | |
200 | - | if (($size53005334 == 9)) | |
201 | - | then $acc953005334 | |
202 | - | else { | |
203 | - | let $acc1053005334 = checkProofs($acc953005334, $list53005334[9]) | |
204 | - | if (($size53005334 == 10)) | |
205 | - | then $acc1053005334 | |
206 | - | else { | |
207 | - | let $acc1153005334 = checkProofs($acc1053005334, $list53005334[10]) | |
208 | - | if (($size53005334 == 11)) | |
209 | - | then $acc1153005334 | |
210 | - | else { | |
211 | - | let $acc1253005334 = checkProofs($acc1153005334, $list53005334[11]) | |
212 | - | throw("List size exceed 11") | |
213 | - | } | |
214 | - | } | |
215 | - | } | |
216 | - | } | |
217 | - | } | |
218 | - | } | |
219 | - | } | |
220 | - | } | |
221 | - | } | |
222 | - | } | |
223 | - | } | |
224 | - | } | |
225 | - | } > (size(investorPubKeys) / 2)) | |
90 | + | let keys = extract(s.senderPublicKey) :: investorPubKeys | |
91 | + | let rightSetScript = ((if (sigVerify(s.bodyBytes, s.proofs[1], keys[1])) | |
92 | + | then 1 | |
93 | + | else 0) > (size(investorPubKeys) / 2)) | |
226 | 94 | if (rightSetScript) | |
227 | - | then sigVerify(s.bodyBytes, s.proofs[0], | |
95 | + | then sigVerify(s.bodyBytes, s.proofs[0], keys[0]) | |
228 | 96 | else false | |
229 | 97 | case _ => | |
230 | 98 | false |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 3 #-} | |
2 | 2 | {-# CONTENT_TYPE EXPRESSION #-} | |
3 | 3 | let payoutAddress = "3P8uxNCMRWjj2DUWAXaRXF4Q4thX9jQxXcs" | |
4 | 4 | let redeemAddress = "3PAkNyfHB5NV9jXioZ1DG3mynhUZyUzHWML" | |
5 | 5 | let votingAddress = "3PGEh2VpbpYyetTUTCY6bRxv2mpMwZoz5sP" | |
6 | 6 | let lockExpired = (value(lastBlock.timestamp) >= (1609459200 * 1000)) | |
7 | 7 | let priceAssetId = Unit() | |
8 | 8 | let amountAssetId = base58'BS1KFNR8zrXKBEWdUUvpaP6G57Hic3aESkwK7qQKdLpB' | |
9 | 9 | let matcherFeeId = Unit() | |
10 | 10 | let payoutAssetId = base58'8LQW8f7P5d5PZM7GtZEBgaqRPGSzS3DfPuiXrURJ4AJS' | |
11 | 11 | let traderPubKey = extract(tx.senderPublicKey) | |
12 | 12 | let managerPubKey = base58'2jtARCoafX5CBQ9jXV265Fng8t58hMmmdpWQdgMzk1z9' | |
13 | 13 | let investorPubKeys = [base58'66BGZcJJ9yAWcHKZZeiuA71wAvC5GWTmdQWArjt1g6jC'] | |
14 | 14 | func isFiatAsset (assetId) = if (if (if (if (if ((assetId == base58'Ft8X1v1LTa1ABafufpaCWyVj8KkaxUWE6xBhW6sNFJck')) | |
15 | 15 | then true | |
16 | 16 | else (assetId == base58'Gtb1WRznfchDnTh37ezoDTJ4wcoKaRsKqKjJjy7nm2zU')) | |
17 | 17 | then true | |
18 | 18 | else (assetId == base58'DEJbZipbKQjwEiRjx2AqQFucrj5CZ3rAc4ZvFM8nAsoA')) | |
19 | 19 | then true | |
20 | 20 | else (assetId == base58'2mX5DzVKWrAJw8iwdJnV2qtoeVG9h5nTDpTqC1wb1WEN')) | |
21 | 21 | then true | |
22 | 22 | else (assetId == base58'34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ')) | |
23 | 23 | then true | |
24 | 24 | else (assetId == base58'DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p') | |
25 | - | ||
26 | - | func checkProofs (cnt,sig) = { | |
27 | - | func isSigned (chk,pub) = if (chk) | |
28 | - | then true | |
29 | - | else sigVerify(tx.bodyBytes, sig, pub) | |
30 | - | ||
31 | - | (cnt + (if ({ | |
32 | - | let $list22342276 = investorPubKeys | |
33 | - | let $size22342276 = size($list22342276) | |
34 | - | let $acc022342276 = false | |
35 | - | if (($size22342276 == 0)) | |
36 | - | then $acc022342276 | |
37 | - | else { | |
38 | - | let $acc122342276 = isSigned($acc022342276, $list22342276[0]) | |
39 | - | if (($size22342276 == 1)) | |
40 | - | then $acc122342276 | |
41 | - | else { | |
42 | - | let $acc222342276 = isSigned($acc122342276, $list22342276[1]) | |
43 | - | if (($size22342276 == 2)) | |
44 | - | then $acc222342276 | |
45 | - | else { | |
46 | - | let $acc322342276 = isSigned($acc222342276, $list22342276[2]) | |
47 | - | if (($size22342276 == 3)) | |
48 | - | then $acc322342276 | |
49 | - | else { | |
50 | - | let $acc422342276 = isSigned($acc322342276, $list22342276[3]) | |
51 | - | if (($size22342276 == 4)) | |
52 | - | then $acc422342276 | |
53 | - | else { | |
54 | - | let $acc522342276 = isSigned($acc422342276, $list22342276[4]) | |
55 | - | if (($size22342276 == 5)) | |
56 | - | then $acc522342276 | |
57 | - | else { | |
58 | - | let $acc622342276 = isSigned($acc522342276, $list22342276[5]) | |
59 | - | if (($size22342276 == 6)) | |
60 | - | then $acc622342276 | |
61 | - | else { | |
62 | - | let $acc722342276 = isSigned($acc622342276, $list22342276[6]) | |
63 | - | if (($size22342276 == 7)) | |
64 | - | then $acc722342276 | |
65 | - | else { | |
66 | - | let $acc822342276 = isSigned($acc722342276, $list22342276[7]) | |
67 | - | if (($size22342276 == 8)) | |
68 | - | then $acc822342276 | |
69 | - | else { | |
70 | - | let $acc922342276 = isSigned($acc822342276, $list22342276[8]) | |
71 | - | if (($size22342276 == 9)) | |
72 | - | then $acc922342276 | |
73 | - | else { | |
74 | - | let $acc1022342276 = isSigned($acc922342276, $list22342276[9]) | |
75 | - | if (($size22342276 == 10)) | |
76 | - | then $acc1022342276 | |
77 | - | else { | |
78 | - | let $acc1122342276 = isSigned($acc1022342276, $list22342276[10]) | |
79 | - | throw("List size exceed 10") | |
80 | - | } | |
81 | - | } | |
82 | - | } | |
83 | - | } | |
84 | - | } | |
85 | - | } | |
86 | - | } | |
87 | - | } | |
88 | - | } | |
89 | - | } | |
90 | - | } | |
91 | - | }) | |
92 | - | then 1 | |
93 | - | else 0)) | |
94 | - | } | |
95 | 25 | ||
96 | 26 | match tx { | |
97 | 27 | case o: Order => | |
98 | 28 | let rightOrder = if (if (if (if ((o.matcherFeeAssetId == matcherFeeId)) | |
99 | 29 | then (o.assetPair.priceAsset == priceAssetId) | |
100 | 30 | else false) | |
101 | 31 | then (o.assetPair.amountAsset == amountAssetId) | |
102 | 32 | else false) | |
103 | 33 | then true | |
104 | 34 | else if (if (if ((o.orderType == Buy)) | |
105 | 35 | then !(isDefined(o.matcherFeeAssetId)) | |
106 | 36 | else false) | |
107 | 37 | then !(isDefined(o.assetPair.amountAsset)) | |
108 | 38 | else false) | |
109 | 39 | then (o.assetPair.priceAsset == payoutAssetId) | |
110 | 40 | else false) | |
111 | 41 | then true | |
112 | 42 | else if (if (if ((o.orderType == Sell)) | |
113 | 43 | then !(isDefined(o.matcherFeeAssetId)) | |
114 | 44 | else false) | |
115 | 45 | then if (!(isDefined(o.assetPair.priceAsset))) | |
116 | 46 | then true | |
117 | 47 | else !(isDefined(o.assetPair.amountAsset)) | |
118 | 48 | else false) | |
119 | 49 | then !(isFiatAsset(o.assetPair.priceAsset)) | |
120 | 50 | else false | |
121 | 51 | if (rightOrder) | |
122 | 52 | then sigVerify(o.bodyBytes, o.proofs[0], traderPubKey) | |
123 | 53 | else false | |
124 | 54 | case b: BurnTransaction => | |
125 | 55 | let rightBurn = if (if ((b.assetId != payoutAssetId)) | |
126 | 56 | then (b.assetId != if (isDefined(priceAssetId)) | |
127 | 57 | then priceAssetId | |
128 | 58 | else base58'') | |
129 | 59 | else false) | |
130 | 60 | then (b.assetId != if (isDefined(amountAssetId)) | |
131 | 61 | then amountAssetId | |
132 | 62 | else base58'') | |
133 | 63 | else false | |
134 | 64 | if (rightBurn) | |
135 | 65 | then sigVerify(b.bodyBytes, b.proofs[0], traderPubKey) | |
136 | 66 | else false | |
137 | 67 | case l: LeaseCancelTransaction|LeaseTransaction => | |
138 | 68 | sigVerify(l.bodyBytes, l.proofs[0], traderPubKey) | |
139 | 69 | case i: InvokeScriptTransaction => | |
140 | 70 | let rightInvoke = (addressFromRecipient(i.dApp) == addressFromString(votingAddress)) | |
141 | 71 | if (rightInvoke) | |
142 | 72 | then sigVerify(i.bodyBytes, i.proofs[0], traderPubKey) | |
143 | 73 | else false | |
144 | 74 | case t: TransferTransaction => | |
145 | 75 | let rightTransfer = if (if ((t.assetId == payoutAssetId)) | |
146 | 76 | then (addressFromRecipient(t.recipient) == addressFromString(payoutAddress)) | |
147 | 77 | else false) | |
148 | 78 | then true | |
149 | 79 | else if (if ((t.assetId == priceAssetId)) | |
150 | 80 | then true | |
151 | 81 | else (t.assetId == amountAssetId)) | |
152 | 82 | then (addressFromRecipient(t.recipient) == addressFromString(redeemAddress)) | |
153 | 83 | else false | |
154 | 84 | if (rightTransfer) | |
155 | 85 | then if (sigVerify(t.bodyBytes, t.proofs[1], managerPubKey)) | |
156 | 86 | then true | |
157 | 87 | else lockExpired | |
158 | 88 | else false | |
159 | 89 | case s: SetScriptTransaction => | |
160 | - | let rightSetScript = ({ | |
161 | - | let $list53005334 = s.proofs | |
162 | - | let $size53005334 = size($list53005334) | |
163 | - | let $acc053005334 = 0 | |
164 | - | if (($size53005334 == 0)) | |
165 | - | then $acc053005334 | |
166 | - | else { | |
167 | - | let $acc153005334 = checkProofs($acc053005334, $list53005334[0]) | |
168 | - | if (($size53005334 == 1)) | |
169 | - | then $acc153005334 | |
170 | - | else { | |
171 | - | let $acc253005334 = checkProofs($acc153005334, $list53005334[1]) | |
172 | - | if (($size53005334 == 2)) | |
173 | - | then $acc253005334 | |
174 | - | else { | |
175 | - | let $acc353005334 = checkProofs($acc253005334, $list53005334[2]) | |
176 | - | if (($size53005334 == 3)) | |
177 | - | then $acc353005334 | |
178 | - | else { | |
179 | - | let $acc453005334 = checkProofs($acc353005334, $list53005334[3]) | |
180 | - | if (($size53005334 == 4)) | |
181 | - | then $acc453005334 | |
182 | - | else { | |
183 | - | let $acc553005334 = checkProofs($acc453005334, $list53005334[4]) | |
184 | - | if (($size53005334 == 5)) | |
185 | - | then $acc553005334 | |
186 | - | else { | |
187 | - | let $acc653005334 = checkProofs($acc553005334, $list53005334[5]) | |
188 | - | if (($size53005334 == 6)) | |
189 | - | then $acc653005334 | |
190 | - | else { | |
191 | - | let $acc753005334 = checkProofs($acc653005334, $list53005334[6]) | |
192 | - | if (($size53005334 == 7)) | |
193 | - | then $acc753005334 | |
194 | - | else { | |
195 | - | let $acc853005334 = checkProofs($acc753005334, $list53005334[7]) | |
196 | - | if (($size53005334 == 8)) | |
197 | - | then $acc853005334 | |
198 | - | else { | |
199 | - | let $acc953005334 = checkProofs($acc853005334, $list53005334[8]) | |
200 | - | if (($size53005334 == 9)) | |
201 | - | then $acc953005334 | |
202 | - | else { | |
203 | - | let $acc1053005334 = checkProofs($acc953005334, $list53005334[9]) | |
204 | - | if (($size53005334 == 10)) | |
205 | - | then $acc1053005334 | |
206 | - | else { | |
207 | - | let $acc1153005334 = checkProofs($acc1053005334, $list53005334[10]) | |
208 | - | if (($size53005334 == 11)) | |
209 | - | then $acc1153005334 | |
210 | - | else { | |
211 | - | let $acc1253005334 = checkProofs($acc1153005334, $list53005334[11]) | |
212 | - | throw("List size exceed 11") | |
213 | - | } | |
214 | - | } | |
215 | - | } | |
216 | - | } | |
217 | - | } | |
218 | - | } | |
219 | - | } | |
220 | - | } | |
221 | - | } | |
222 | - | } | |
223 | - | } | |
224 | - | } | |
225 | - | } > (size(investorPubKeys) / 2)) | |
90 | + | let keys = extract(s.senderPublicKey) :: investorPubKeys | |
91 | + | let rightSetScript = ((if (sigVerify(s.bodyBytes, s.proofs[1], keys[1])) | |
92 | + | then 1 | |
93 | + | else 0) > (size(investorPubKeys) / 2)) | |
226 | 94 | if (rightSetScript) | |
227 | - | then sigVerify(s.bodyBytes, s.proofs[0], | |
95 | + | then sigVerify(s.bodyBytes, s.proofs[0], keys[0]) | |
228 | 96 | else false | |
229 | 97 | case _ => | |
230 | 98 | false | |
231 | 99 | } |
github/deemru/w8io/3ef1775 59.73 ms ◑