tx · 7sPm7CRLwBPBCtXMMmAn8mpJSSCJRBRbk4gAZFbh6gk9

3N666c9jMPp2LgthP7QpdaHbfcyCXp6pfk2:  -0.01400000 Waves

2020.07.14 14:31 [1086929] smart account 3N666c9jMPp2LgthP7QpdaHbfcyCXp6pfk2 > SELF 0.00000000 Waves

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

github/deemru/w8io/873ac7e 
21.73 ms