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