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:
OldNewDifferences
2222 else (assetId == base58'34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ'))
2323 then true
2424 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- }
9525
9626 match tx {
9727 case o: Order =>
15787 else lockExpired
15888 else false
15989 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))
22694 if (rightSetScript)
227- then sigVerify(s.bodyBytes, s.proofs[0], s.senderPublicKey)
95+ then sigVerify(s.bodyBytes, s.proofs[0], keys[0])
22896 else false
22997 case _ =>
23098 false
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 3 #-}
22 {-# CONTENT_TYPE EXPRESSION #-}
33 let payoutAddress = "3P8uxNCMRWjj2DUWAXaRXF4Q4thX9jQxXcs"
44 let redeemAddress = "3PAkNyfHB5NV9jXioZ1DG3mynhUZyUzHWML"
55 let votingAddress = "3PGEh2VpbpYyetTUTCY6bRxv2mpMwZoz5sP"
66 let lockExpired = (value(lastBlock.timestamp) >= (1609459200 * 1000))
77 let priceAssetId = Unit()
88 let amountAssetId = base58'BS1KFNR8zrXKBEWdUUvpaP6G57Hic3aESkwK7qQKdLpB'
99 let matcherFeeId = Unit()
1010 let payoutAssetId = base58'8LQW8f7P5d5PZM7GtZEBgaqRPGSzS3DfPuiXrURJ4AJS'
1111 let traderPubKey = extract(tx.senderPublicKey)
1212 let managerPubKey = base58'2jtARCoafX5CBQ9jXV265Fng8t58hMmmdpWQdgMzk1z9'
1313 let investorPubKeys = [base58'66BGZcJJ9yAWcHKZZeiuA71wAvC5GWTmdQWArjt1g6jC']
1414 func isFiatAsset (assetId) = if (if (if (if (if ((assetId == base58'Ft8X1v1LTa1ABafufpaCWyVj8KkaxUWE6xBhW6sNFJck'))
1515 then true
1616 else (assetId == base58'Gtb1WRznfchDnTh37ezoDTJ4wcoKaRsKqKjJjy7nm2zU'))
1717 then true
1818 else (assetId == base58'DEJbZipbKQjwEiRjx2AqQFucrj5CZ3rAc4ZvFM8nAsoA'))
1919 then true
2020 else (assetId == base58'2mX5DzVKWrAJw8iwdJnV2qtoeVG9h5nTDpTqC1wb1WEN'))
2121 then true
2222 else (assetId == base58'34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ'))
2323 then true
2424 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- }
9525
9626 match tx {
9727 case o: Order =>
9828 let rightOrder = if (if (if (if ((o.matcherFeeAssetId == matcherFeeId))
9929 then (o.assetPair.priceAsset == priceAssetId)
10030 else false)
10131 then (o.assetPair.amountAsset == amountAssetId)
10232 else false)
10333 then true
10434 else if (if (if ((o.orderType == Buy))
10535 then !(isDefined(o.matcherFeeAssetId))
10636 else false)
10737 then !(isDefined(o.assetPair.amountAsset))
10838 else false)
10939 then (o.assetPair.priceAsset == payoutAssetId)
11040 else false)
11141 then true
11242 else if (if (if ((o.orderType == Sell))
11343 then !(isDefined(o.matcherFeeAssetId))
11444 else false)
11545 then if (!(isDefined(o.assetPair.priceAsset)))
11646 then true
11747 else !(isDefined(o.assetPair.amountAsset))
11848 else false)
11949 then !(isFiatAsset(o.assetPair.priceAsset))
12050 else false
12151 if (rightOrder)
12252 then sigVerify(o.bodyBytes, o.proofs[0], traderPubKey)
12353 else false
12454 case b: BurnTransaction =>
12555 let rightBurn = if (if ((b.assetId != payoutAssetId))
12656 then (b.assetId != if (isDefined(priceAssetId))
12757 then priceAssetId
12858 else base58'')
12959 else false)
13060 then (b.assetId != if (isDefined(amountAssetId))
13161 then amountAssetId
13262 else base58'')
13363 else false
13464 if (rightBurn)
13565 then sigVerify(b.bodyBytes, b.proofs[0], traderPubKey)
13666 else false
13767 case l: LeaseCancelTransaction|LeaseTransaction =>
13868 sigVerify(l.bodyBytes, l.proofs[0], traderPubKey)
13969 case i: InvokeScriptTransaction =>
14070 let rightInvoke = (addressFromRecipient(i.dApp) == addressFromString(votingAddress))
14171 if (rightInvoke)
14272 then sigVerify(i.bodyBytes, i.proofs[0], traderPubKey)
14373 else false
14474 case t: TransferTransaction =>
14575 let rightTransfer = if (if ((t.assetId == payoutAssetId))
14676 then (addressFromRecipient(t.recipient) == addressFromString(payoutAddress))
14777 else false)
14878 then true
14979 else if (if ((t.assetId == priceAssetId))
15080 then true
15181 else (t.assetId == amountAssetId))
15282 then (addressFromRecipient(t.recipient) == addressFromString(redeemAddress))
15383 else false
15484 if (rightTransfer)
15585 then if (sigVerify(t.bodyBytes, t.proofs[1], managerPubKey))
15686 then true
15787 else lockExpired
15888 else false
15989 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))
22694 if (rightSetScript)
227- then sigVerify(s.bodyBytes, s.proofs[0], s.senderPublicKey)
95+ then sigVerify(s.bodyBytes, s.proofs[0], keys[0])
22896 else false
22997 case _ =>
23098 false
23199 }

github/deemru/w8io/3ef1775 
59.73 ms