tx · D25Keg6XbHdgDDDAKnVnv4EEEh9fBBmdQ25cR8hA9kcP

3MpiSwQCRamTZYf4QDmaynvB2tedBWCUFz7:  -0.01400000 Waves

2020.09.09 18:50 [1169981] smart account 3MpiSwQCRamTZYf4QDmaynvB2tedBWCUFz7 > SELF 0.00000000 Waves

{ "type": 13, "id": "D25Keg6XbHdgDDDAKnVnv4EEEh9fBBmdQ25cR8hA9kcP", "fee": 1400000, "feeAssetId": null, "timestamp": 1599666723764, "version": 1, "sender": "3MpiSwQCRamTZYf4QDmaynvB2tedBWCUFz7", "senderPublicKey": "CJHr6t5jpcJCrCsutW7BBE87deUDdxcBmST5zdCgSJqg", "proofs": [ "51f8LcH21ehHk3pwTiS5g1wBuy3FxLxoztzeuxmsmbSZ5Ah11M6G7jhahesUiks7Zq88ixV7pXa6gkH4VWgeZ2m2" ], "script": "base64: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", "chainId": 84, "height": 1169981, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: r5QeG5gora4chKTcfT1LqxFjJYSBGoxCa9HJRRhJZWQ Next: HdduA6Gi5SgSWLehwo7REMerc5zHcz6NZd4s7oES1edH Diff:
OldNewDifferences
5151 @Callable(i)
5252 func updateConsuls (newConsuls,stringSigns,round) = {
5353 let consuls = consulsByRound(lastRound)
54- let msg = toBytes(((newConsuls + ",") + toString(round)))
54+ let msg = keccak256(toBytes(((newConsuls + ",") + toString(round))))
5555 let signs = split(stringSigns, ",")
5656 let count = ((((validateSign(msg, signs[0], consuls[0]) + validateSign(msg, signs[1], consuls[1])) + validateSign(msg, signs[2], consuls[2])) + validateSign(msg, signs[3], consuls[3])) + validateSign(msg, signs[4], consuls[4]))
5757 if ((lastRound >= round))
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 3 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let MaxConsuls = 5
55
66 func getNumberByKey (key) = match getInteger(this, key) {
77 case v: Int =>
88 v
99 case _ =>
1010 0
1111 }
1212
1313
1414 func getStringByKey (key) = match getString(this, key) {
1515 case v: String =>
1616 v
1717 case _ =>
1818 ""
1919 }
2020
2121
2222 func getBooleanByKey (key) = match getBoolean(this, key) {
2323 case v: Boolean =>
2424 v
2525 case _ =>
2626 false
2727 }
2828
2929
3030 let BftCoefficientKey = "bft_coefficient"
3131
3232 let LastRoundKey = "last_round"
3333
3434 func ConsulsKey (round) = ("consuls_" + toString(round))
3535
3636
3737 let bftCoefficient = getNumberByKey(BftCoefficientKey)
3838
3939 let lastRound = getNumberByKey(LastRoundKey)
4040
4141 func consulsByRound (round) = split(getStringByKey(ConsulsKey(round)), ",")
4242
4343
4444 func validateSign (hash,sign,oracle) = if ((sign != "nil"))
4545 then if (sigVerify(hash, fromBase58String(sign), fromBase58String(oracle)))
4646 then 1
4747 else 0
4848 else 0
4949
5050
5151 @Callable(i)
5252 func updateConsuls (newConsuls,stringSigns,round) = {
5353 let consuls = consulsByRound(lastRound)
54- let msg = toBytes(((newConsuls + ",") + toString(round)))
54+ let msg = keccak256(toBytes(((newConsuls + ",") + toString(round))))
5555 let signs = split(stringSigns, ",")
5656 let count = ((((validateSign(msg, signs[0], consuls[0]) + validateSign(msg, signs[1], consuls[1])) + validateSign(msg, signs[2], consuls[2])) + validateSign(msg, signs[3], consuls[3])) + validateSign(msg, signs[4], consuls[4]))
5757 if ((lastRound >= round))
5858 then throw("round less last round")
5959 else if ((bftCoefficient > count))
6060 then throw("invalid bft count")
6161 else WriteSet([DataEntry(ConsulsKey(round), newConsuls), DataEntry(LastRoundKey, round)])
6262 }
6363
6464

github/deemru/w8io/3ef1775 
40.12 ms