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