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:
Old | New | Differences | |
---|---|---|---|
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 ◑![]()