tx · 73jLi6goRXX951dDr2esg5xjFeogv4iMHAStPJVz62LM

3N4gGXLoQLDL8J6rHho3CK714TWiAw3ahi4:  -0.01400000 Waves

2020.09.10 14:24 [1171153] smart account 3N4gGXLoQLDL8J6rHho3CK714TWiAw3ahi4 > SELF 0.00000000 Waves

{ "type": 13, "id": "73jLi6goRXX951dDr2esg5xjFeogv4iMHAStPJVz62LM", "fee": 1400000, "feeAssetId": null, "timestamp": 1599737088613, "version": 1, "sender": "3N4gGXLoQLDL8J6rHho3CK714TWiAw3ahi4", "senderPublicKey": "2G2SB6hLj6PxUgshtzMt5QLV3XzLbQNhvXk5f6QTkTZy", "proofs": [ "2jmapVRGXe6DxsJgbKJBevSZh474Rz89vyN2aBxBE66HrbrLKBtU9P1i8wUA9fEbC4F4tpkJ6hNq33mDMMtxmuVr" ], "script": "base64:AAIDAAAAAAAAAA8IARIECgICCBIFCgMICAEAAAAdAAAAAAVXQVZFUwIAAAAFV0FWRVMAAAAAB0ludFR5cGUAAAAAAAAAAAAAAAAAClN0cmluZ1R5cGUAAAAAAAAAAAEAAAAACUJ5dGVzVHlwZQAAAAAAAAAAAgEAAAAOZ2V0TnVtYmVyQnlLZXkAAAABAAAAA2tleQQAAAAHJG1hdGNoMAkABBoAAAACBQAAAAR0aGlzBQAAAANrZXkDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAAA0ludAQAAAABdgUAAAAHJG1hdGNoMAUAAAABdgAAAAAAAAAAAAEAAAANZ2V0Qnl0ZXNCeUtleQAAAAEAAAADa2V5BAAAAAckbWF0Y2gwCQAEHAAAAAIFAAAABHRoaXMFAAAAA2tleQMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAKQnl0ZVZlY3RvcgQAAAABdgUAAAAHJG1hdGNoMAUAAAABdgEAAAAD0AAAAQAAAA5nZXRTdHJpbmdCeUtleQAAAAEAAAADa2V5BAAAAAckbWF0Y2gwCQAEHQAAAAIFAAAABHRoaXMFAAAAA2tleQMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAGU3RyaW5nBAAAAAF2BQAAAAckbWF0Y2gwBQAAAAF2AgAAAAABAAAAGGdldFN0cmluZ0J5QWRkcmVzc0FuZEtleQAAAAIAAAAHYWRkcmVzcwAAAANrZXkEAAAAByRtYXRjaDAJAAQdAAAAAgUAAAAHYWRkcmVzcwUAAAADa2V5AwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAAZTdHJpbmcEAAAAAXYFAAAAByRtYXRjaDAFAAAAAXYCAAAAAAAAAAAKT3JhY2xlc0tleQIAAAAHb3JhY2xlcwAAAAAKQ29uc3Vsc0tleQIAAAAHY29uc3VscwAAAAAUU3Vic2NyaWJlckFkZHJlc3NLZXkCAAAAEnN1YnNjcmliZXJfYWRkcmVzcwAAAAAHVHlwZUtleQIAAAAEdHlwZQAAAAASR3Jhdml0eUNvbnRyYWN0S2V5AgAAABBncmF2aXR5X2NvbnRyYWN0AAAAABFCZnRDb2VmZmljaWVudEtleQIAAAAPYmZ0X2NvZWZmaWNpZW50AAAAAA1MYXN0SGVpZ2h0S2V5AgAAAAtsYXN0X2hlaWdodAAAAAAMTGFzdFJvdW5kS2V5AgAAAApsYXN0X3JvdW5kAAAAAA5MYXN0UHVsc2VJZEtleQIAAAANbGFzdF9wdWxzZV9pZAEAAAAOZ2V0SGFzaERhdGFLZXkAAAABAAAAB3B1bHNlSWQJAAEsAAAAAgIAAAAKZGF0YV9oYXNoXwkAAaQAAAABBQAAAAdwdWxzZUlkAQAAABNnZXRIZWlnaHRCeVB1bHNlS2V5AAAAAQAAAAdwdWxzZUlkCQABLAAAAAICAAAAB2hlaWdodF8JAAGkAAAAAQUAAAAHcHVsc2VJZAAAAAAHb3JhY2xlcwkABLUAAAACCQEAAAAOZ2V0U3RyaW5nQnlLZXkAAAABBQAAAApPcmFjbGVzS2V5AgAAAAEsAAAAAA5iZnRDb2VmZmljaWVudAkBAAAADmdldE51bWJlckJ5S2V5AAAAAQUAAAARQmZ0Q29lZmZpY2llbnRLZXkAAAAAD2dyYWNpdHlDb250cmFjdAkBAAAAHEBleHRyVXNlcihhZGRyZXNzRnJvbVN0cmluZykAAAABCQEAAAAOZ2V0U3RyaW5nQnlLZXkAAAABBQAAABJHcmF2aXR5Q29udHJhY3RLZXkAAAAAB2NvbnN1bHMJAAS1AAAAAgkBAAAAGGdldFN0cmluZ0J5QWRkcmVzc0FuZEtleQAAAAIFAAAAD2dyYWNpdHlDb250cmFjdAUAAAAKQ29uc3Vsc0tleQIAAAABLAAAAAARc3Vic2NyaWJlckFkZHJlc3MJAQAAAA5nZXRTdHJpbmdCeUtleQAAAAEFAAAAFFN1YnNjcmliZXJBZGRyZXNzS2V5AAAAAAR0eXBlCQEAAAAOZ2V0TnVtYmVyQnlLZXkAAAABBQAAAAdUeXBlS2V5AAAAAAtsYXN0UHVsc2VJZAkBAAAADmdldE51bWJlckJ5S2V5AAAAAQUAAAAOTGFzdFB1bHNlSWRLZXkBAAAAC2dldEhhc2hEYXRhAAAAAQAAAAdwdWxzZUlkCQEAAAANZ2V0Qnl0ZXNCeUtleQAAAAEJAQAAAA5nZXRIYXNoRGF0YUtleQAAAAEFAAAAB3B1bHNlSWQBAAAAEGdldEhlaWdodEJ5UHVsc2UAAAABAAAAB3B1bHNlSWQJAQAAAA5nZXROdW1iZXJCeUtleQAAAAEJAQAAABNnZXRIZWlnaHRC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", "chainId": 84, "height": 1171153, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: none Next: Z5rggi8L8UJSebTuqcyq5xH6M5NMBcY3YX8qXUaZchm Full:
OldNewDifferences
1-# no script
1+{-# STDLIB_VERSION 3 #-}
2+{-# SCRIPT_TYPE ACCOUNT #-}
3+{-# CONTENT_TYPE DAPP #-}
4+let WAVES = "WAVES"
5+
6+let IntType = 0
7+
8+let StringType = 1
9+
10+let BytesType = 2
11+
12+func getNumberByKey (key) = match getInteger(this, key) {
13+ case v: Int =>
14+ v
15+ case _ =>
16+ 0
17+}
18+
19+
20+func getBytesByKey (key) = match getBinary(this, key) {
21+ case v: ByteVector =>
22+ v
23+ case _ =>
24+ base58'2CsAf'
25+}
26+
27+
28+func getStringByKey (key) = match getString(this, key) {
29+ case v: String =>
30+ v
31+ case _ =>
32+ ""
33+}
34+
35+
36+func getStringByAddressAndKey (address,key) = match getString(address, key) {
37+ case v: String =>
38+ v
39+ case _ =>
40+ ""
41+}
42+
43+
44+let OraclesKey = "oracles"
45+
46+let ConsulsKey = "consuls"
47+
48+let SubscriberAddressKey = "subscriber_address"
49+
50+let TypeKey = "type"
51+
52+let GravityContractKey = "gravity_contract"
53+
54+let BftCoefficientKey = "bft_coefficient"
55+
56+let LastHeightKey = "last_height"
57+
58+let LastRoundKey = "last_round"
59+
60+let LastPulseIdKey = "last_pulse_id"
61+
62+func getHashDataKey (pulseId) = ("data_hash_" + toString(pulseId))
63+
64+
65+func getHeightByPulseKey (pulseId) = ("height_" + toString(pulseId))
66+
67+
68+let oracles = split(getStringByKey(OraclesKey), ",")
69+
70+let bftCoefficient = getNumberByKey(BftCoefficientKey)
71+
72+let gracityContract = addressFromStringValue(getStringByKey(GravityContractKey))
73+
74+let consuls = split(getStringByAddressAndKey(gracityContract, ConsulsKey), ",")
75+
76+let subscriberAddress = getStringByKey(SubscriberAddressKey)
77+
78+let type = getNumberByKey(TypeKey)
79+
80+let lastPulseId = getNumberByKey(LastPulseIdKey)
81+
82+func getHashData (pulseId) = getBytesByKey(getHashDataKey(pulseId))
83+
84+
85+func getHeightByPulse (pulseId) = getNumberByKey(getHeightByPulseKey(pulseId))
86+
87+
88+func validateSign (hash,sign,oracle) = if ((sign != "nil"))
89+ then if (sigVerify(hash, fromBase58String(sign), fromBase58String(oracle)))
90+ then 1
91+ else 0
92+ else 0
93+
94+
95+@Callable(i)
96+func sendHashValue (hash,signs) = {
97+ let signList = split(signs, ",")
98+ 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]))
99+ if ((bftCoefficient > count))
100+ then throw("invalid bft count")
101+ else if ((getBytesByKey(toString(height)) != base58'2CsAf'))
102+ then throw("data is exist")
103+ else {
104+ let pulseId = (lastPulseId + 1)
105+ WriteSet([DataEntry(getHashDataKey(pulseId), hash), DataEntry(getHeightByPulseKey(pulseId), height), DataEntry(LastHeightKey, height), DataEntry(LastPulseIdKey, pulseId)])
106+ }
107+ }
108+
109+
110+
111+@Callable(i)
112+func updateOracles (newSortedOracles,stringSigns,round) = {
113+ let signs = split(stringSigns, ",")
114+ 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]))
115+ if ((count > bftCoefficient))
116+ then throw("invalid bft count")
117+ else WriteSet([DataEntry(OraclesKey, newSortedOracles), DataEntry(((LastRoundKey + "_") + toString(round)), round)])
118+ }
119+
120+
121+@Verifier(i)
122+func sendValueToSub () = match i {
123+ case invokeTx: InvokeScriptTransaction =>
124+ let vBytes = if ((type == IntType))
125+ then {
126+ let v = match invokeTx.args[0] {
127+ case v: Int =>
128+ v
129+ case _ =>
130+ throw("invalid value type")
131+ }
132+ toBytes(v)
133+ }
134+ else if ((type == StringType))
135+ then {
136+ let v = match invokeTx.args[0] {
137+ case v: String =>
138+ v
139+ case _ =>
140+ throw("invalid value type")
141+ }
142+ toBytes(v)
143+ }
144+ else if ((type == BytesType))
145+ then {
146+ let v = match invokeTx.args[0] {
147+ case v: ByteVector =>
148+ v
149+ case _ =>
150+ throw("invalid value type")
151+ }
152+ v
153+ }
154+ else throw("invalid value type")
155+ let vPulseId = match invokeTx.args[1] {
156+ case vPulseId: Int =>
157+ vPulseId
158+ case _ =>
159+ throw("invalid height type")
160+ }
161+ if ((invokeTx.function != "attachValue"))
162+ then throw("invalid function name")
163+ else if ((size(invokeTx.args) != 2))
164+ then throw("invalid args size")
165+ else if ((invokeTx.dApp != addressFromStringValue(subscriberAddress)))
166+ then throw("invalid dapp address")
167+ else if ((getHeightByPulse(vPulseId) != height))
168+ then throw("invalid height")
169+ else if ((getHashData(vPulseId) == base58'2CsAf'))
170+ then throw("invalid pulse id")
171+ else if ((keccak256(vBytes) != getHashData(vPulseId)))
172+ then throw("invalid keccak256(value)")
173+ else true
174+ case _ =>
175+ sigVerify(i.bodyBytes, i.proofs[0], i.senderPublicKey)
176+}
177+

github/deemru/w8io/3ef1775 
46.29 ms