55 static void JsonDNP3LogLinkControl(SCJsonBuilder *js, uint8_t lc)
64 static void JsonDNP3LogIin(SCJsonBuilder *js, uint16_t iin)
67 SCJbOpenArray(js,
"indicators");
80 static void JsonDNP3LogApplicationControl(SCJsonBuilder *js, uint8_t ac)
94 static void JsonDNP3LogObjectItems(SCJsonBuilder *js,
DNP3Object *
object)
101 SCJbSetUint(js,
"prefix", item->
prefix);
102 SCJbSetUint(js,
"index", item->
index);
104 SCJbSetUint(js,
"size", item->
size);
118 static void JsonDNP3LogObjects(SCJsonBuilder *js, DNP3ObjectList *objects)
124 SCJbSetUint(js,
"group", object->
group);
125 SCJbSetUint(js,
"variation", object->
variation);
126 SCJbSetUint(js,
"qualifier", object->
qualifier);
127 SCJbSetUint(js,
"prefix_code", object->
prefix_code);
128 SCJbSetUint(js,
"range_code", object->
range_code);
129 SCJbSetUint(js,
"start", object->
start);
130 SCJbSetUint(js,
"stop", object->
stop);
131 SCJbSetUint(js,
"count", object->
count);
134 SCJbOpenArray(js,
"points");
135 JsonDNP3LogObjectItems(js,
object);
143 static void JsonDNP3LogRequest(SCJsonBuilder *js,
DNP3Transaction *dnp3tx)
147 SCJbOpenObject(js,
"control");
148 JsonDNP3LogLinkControl(js, dnp3tx->
lh.control);
154 SCJbOpenObject(js,
"application");
156 SCJbOpenObject(js,
"control");
157 JsonDNP3LogApplicationControl(js, dnp3tx->
ah.control);
160 SCJbSetUint(js,
"function_code", dnp3tx->
ah.function_code);
163 SCJbOpenArray(js,
"objects");
164 JsonDNP3LogObjects(js, &dnp3tx->
objects);
168 SCJbSetBool(js,
"complete", dnp3tx->
complete);
174 static void JsonDNP3LogResponse(SCJsonBuilder *js,
DNP3Transaction *dnp3tx)
182 SCJbOpenObject(js,
"control");
183 JsonDNP3LogLinkControl(js, dnp3tx->
lh.control);
189 SCJbOpenObject(js,
"application");
191 SCJbOpenObject(js,
"control");
192 JsonDNP3LogApplicationControl(js, dnp3tx->
ah.control);
195 SCJbSetUint(js,
"function_code", dnp3tx->
ah.function_code);
198 SCJbOpenArray(js,
"objects");
199 JsonDNP3LogObjects(js, &dnp3tx->
objects);
203 SCJbSetBool(js,
"complete", dnp3tx->
complete);
208 SCJbOpenObject(js,
"iin");
209 JsonDNP3LogIin(js, (uint16_t)(dnp3tx->
iin.iin1 << 8 | dnp3tx->
iin.iin2));
217 SCJbOpenObject(js,
"dnp3");
219 SCJbOpenObject(js,
"request");
220 JsonDNP3LogRequest(js, tx);
225 SCJbOpenObject(js,
"response");
226 JsonDNP3LogResponse(js, tx);
234 static int JsonDNP3LoggerToServer(
ThreadVars *
tv,
void *thread_data,
235 const Packet *p,
Flow *f,
void *state,
void *vtx, uint64_t tx_id)
247 SCJbOpenObject(js,
"dnp3");
248 JsonDNP3LogRequest(js, tx);
256 static int JsonDNP3LoggerToClient(
ThreadVars *
tv,
void *thread_data,
257 const Packet *p,
Flow *f,
void *state,
void *vtx, uint64_t tx_id)
269 SCJbOpenObject(js,
"dnp3");
270 JsonDNP3LogResponse(js, tx);
279 void *vtx, uint64_t tx_id)
284 JsonDNP3LoggerToServer(
tv, thread_data, p, f, state, vtx, tx_id);
286 JsonDNP3LoggerToClient(
tv, thread_data, p, f, state, vtx, tx_id);
291 static void OutputDNP3LogDeInitCtxSub(
OutputCtx *output_ctx)
293 SCLogDebug(
"cleaning up sub output_ctx %p", output_ctx);
305 if (
unlikely(dnp3log_ctx == NULL)) {
308 dnp3log_ctx->
eve_ctx = json_ctx;
315 output_ctx->
data = dnp3log_ctx;
316 output_ctx->
DeInit = OutputDNP3LogDeInitCtxSub;
318 SCLogInfo(
"DNP3 log sub-module initialized.");
322 result.
ctx = output_ctx;
328 static TmEcode JsonDNP3LogThreadInit(
ThreadVars *t,
const void *initdata,
void **data)
335 if (initdata == NULL) {
336 SCLogDebug(
"Error getting context for DNP3. \"initdata\" is NULL.");
342 if (thread->
ctx == NULL) {
346 *data = (
void *)thread;
358 if (thread == NULL) {
369 OutputDNP3LogInitSub,
ALPROTO_DNP3, JsonDNP3Logger, JsonDNP3LogThreadInit,
370 JsonDNP3LogThreadDeinit);