tx · CH4zwvBA7zdmBWPTie8N9gubmUYWsif3pRNHNQDDXDbH

3Mu67KzPQ8JmXuFcdaD7X58KGss852c4aaL:  -0.01400000 Waves

2020.07.20 14:16 [1095701] smart account 3Mu67KzPQ8JmXuFcdaD7X58KGss852c4aaL > SELF 0.00000000 Waves

{ "type": 13, "id": "CH4zwvBA7zdmBWPTie8N9gubmUYWsif3pRNHNQDDXDbH", "fee": 1400000, "feeAssetId": null, "timestamp": 1595243871989, "version": 1, "sender": "3Mu67KzPQ8JmXuFcdaD7X58KGss852c4aaL", "senderPublicKey": "3g6nHFpXgQGGtr1dLPVQytaR1GStVaToJUuQ3r1jqmXB", "proofs": [ "3MwSikFZu9rekmSSa4U7pAabVs4eM58vywsKSBUrwmVhGoo6wL78Tj6bUg4F6qyMDNG5d9U54nAgNd1vdEZMZNYJ" ], "script": "base64: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", "chainId": 84, "height": 1095701, "spentComplexity": 0 } View: original | compacted Prev: none Next: none Full:
OldNewDifferences
1-# no script
1+{-# STDLIB_VERSION 3 #-}
2+{-# SCRIPT_TYPE ACCOUNT #-}
3+{-# CONTENT_TYPE DAPP #-}
4+let WAVES = "WAVES"
5+
6+func getNumberByKey (key) = match getInteger(this, key) {
7+ case v: Int =>
8+ v
9+ case _ =>
10+ 0
11+}
12+
13+
14+func getBytesByKey (key) = match getBinary(this, key) {
15+ case v: ByteVector =>
16+ v
17+ case _ =>
18+ base58'2CsAf'
19+}
20+
21+
22+func getStringByKey (key) = match getString(this, key) {
23+ case v: String =>
24+ v
25+ case _ =>
26+ ""
27+}
28+
29+
30+func getStringByAddressAndKey (address,key) = match getString(address, key) {
31+ case v: String =>
32+ v
33+ case _ =>
34+ ""
35+}
36+
37+
38+let OraclesKey = "oracles"
39+
40+let ConsulsKey = "consuls"
41+
42+let SubscriberAddressKey = "subscriber_address"
43+
44+let GravityContractKey = "gravity_contract"
45+
46+let BftCoefficientKey = "bft_coefficient"
47+
48+let LasrRoundKey = "last_round"
49+
50+let oracles = split(getStringByKey(OraclesKey), ",")
51+
52+let bftCoefficient = getNumberByKey(BftCoefficientKey)
53+
54+let gracityContract = addressFromStringValue(getStringByKey(GravityContractKey))
55+
56+let consuls = split(getStringByAddressAndKey(gracityContract, ConsulsKey), ",")
57+
58+let subscriberAddress = getStringByKey(SubscriberAddressKey)
59+
60+func validateSign (hash,sign,oracle) = if ((sign != "nil"))
61+ then if (sigVerify(hash, fromBase58String(sign), fromBase58String(oracle)))
62+ then 1
63+ else 0
64+ else 0
65+
66+
67+@Callable(i)
68+func confirmData (hash,signs) = {
69+ let signList = split(signs, ",")
70+ let count = ((((validateSign(hash, signList[0], oracles[0]) + validateSign(hash, signList[1], oracles[1])) + validateSign(hash, signList[2], oracles[2])) + validateSign(hash, signList[3], oracles[3])) + validateSign(hash, signList[4], oracles[4]))
71+ if ((count > bftCoefficient))
72+ then throw("invalid bft count")
73+ else if ((getBytesByKey(toString(height)) != base58'2CsAf'))
74+ then throw("data is exist")
75+ else WriteSet([DataEntry(toString(height), hash)])
76+ }
77+
78+
79+
80+@Callable(i)
81+func setSortedOracles (newSortedOracles,stringSigns,round) = {
82+ let signs = split(stringSigns, ",")
83+ let count = ((((validateSign(toBytes(newSortedOracles), signs[0], consuls[0]) + validateSign(toBytes(newSortedOracles), signs[1], consuls[1])) + validateSign(toBytes(newSortedOracles), signs[2], consuls[2])) + validateSign(toBytes(newSortedOracles), signs[3], consuls[3])) + validateSign(toBytes(newSortedOracles), signs[4], consuls[4]))
84+ if ((count > bftCoefficient))
85+ then throw("invalid bft count")
86+ else WriteSet([DataEntry(OraclesKey, newSortedOracles), DataEntry(((LasrRoundKey + "_") + toString(round)), round)])
87+ }
88+
89+
90+@Verifier(i)
91+func sendData () = match i {
92+ case in: InvokeScriptTransaction =>
93+ let v = match in.args[0] {
94+ case v: Int =>
95+ v
96+ case _ =>
97+ throw("invalid args[0] type")
98+ }
99+ let vHeight = match in.args[1] {
100+ case vHeight: Int =>
101+ vHeight
102+ case _ =>
103+ throw("invalid args[1] type")
104+ }
105+ if ((in.dApp != addressFromStringValue(subscriberAddress)))
106+ then throw("invalid dapp address")
107+ else if ((getStringByKey(toString(vHeight)) == ""))
108+ then throw("invalid height")
109+ else if ((keccak256(toBytes(v)) != fromBase58String(getStringByKey(toString(vHeight)))))
110+ then throw(("invalid keccak256(value) " + toString(v)))
111+ else true
112+ case _ =>
113+ true
114+}
115+

github/deemru/w8io/169f3d6 
32.39 ms