use super::mqtt_message::*;
use super::parser::*;
use crate::applayer::*;
-use crate::applayer::{self, LoggerFlags};
+use crate::applayer;
use crate::conf::{conf_get, get_memval};
use crate::core::*;
use crate::direction::Direction;
toclient: bool,
toserver: bool,
- logged: LoggerFlags,
tx_data: applayer::AppLayerTxData,
}
tx_id: 0,
pkt_id: None,
complete: false,
- logged: LoggerFlags::new(),
msg: Vec::new(),
toclient: direction.is_to_client(),
toserver: direction.is_to_server(),
// C exports.
-#[no_mangle]
-pub unsafe extern "C" fn rs_mqtt_probing_parser(
+unsafe extern "C" fn mqtt_probing_parser(
_flow: *const Flow, _direction: u8, input: *const u8, input_len: u32, _rdir: *mut u8,
) -> AppProto {
if input.is_null() {
}
}
-#[no_mangle]
-pub extern "C" fn rs_mqtt_state_new(
+extern "C" fn mqtt_state_new(
_orig_state: *mut std::os::raw::c_void, _orig_proto: AppProto,
) -> *mut std::os::raw::c_void {
let state = MQTTState::new();
return Box::into_raw(boxed) as *mut _;
}
-#[no_mangle]
-pub extern "C" fn rs_mqtt_state_free(state: *mut std::os::raw::c_void) {
+extern "C" fn mqtt_state_free(state: *mut std::os::raw::c_void) {
std::mem::drop(unsafe { Box::from_raw(state as *mut MQTTState) });
}
-#[no_mangle]
-pub unsafe extern "C" fn rs_mqtt_state_tx_free(state: *mut std::os::raw::c_void, tx_id: u64) {
+unsafe extern "C" fn mqtt_state_tx_free(state: *mut std::os::raw::c_void, tx_id: u64) {
let state = cast_pointer!(state, MQTTState);
state.free_tx(tx_id);
}
-#[no_mangle]
-pub unsafe extern "C" fn rs_mqtt_parse_request(
+unsafe extern "C" fn mqtt_parse_request(
flow: *const Flow, state: *mut std::os::raw::c_void, _pstate: *mut std::os::raw::c_void,
stream_slice: StreamSlice, _data: *const std::os::raw::c_void,
) -> AppLayerResult {
return state.parse_request(flow, stream_slice);
}
-#[no_mangle]
-pub unsafe extern "C" fn rs_mqtt_parse_response(
+unsafe extern "C" fn mqtt_parse_response(
flow: *const Flow, state: *mut std::os::raw::c_void, _pstate: *mut std::os::raw::c_void,
stream_slice: StreamSlice, _data: *const std::os::raw::c_void,
) -> AppLayerResult {
return state.parse_response(flow, stream_slice);
}
-#[no_mangle]
-pub unsafe extern "C" fn rs_mqtt_state_get_tx(
+unsafe extern "C" fn mqtt_state_get_tx(
state: *mut std::os::raw::c_void, tx_id: u64,
) -> *mut std::os::raw::c_void {
let state = cast_pointer!(state, MQTTState);
}
}
-#[no_mangle]
-pub unsafe extern "C" fn rs_mqtt_state_get_tx_count(state: *mut std::os::raw::c_void) -> u64 {
+unsafe extern "C" fn mqtt_state_get_tx_count(state: *mut std::os::raw::c_void) -> u64 {
let state = cast_pointer!(state, MQTTState);
return state.tx_id;
}
#[no_mangle]
-pub unsafe extern "C" fn rs_mqtt_tx_is_toclient(
+pub unsafe extern "C" fn SCMqttTxIsToClient(
tx: &MQTTTransaction,
) -> std::os::raw::c_int {
if tx.toclient {
return 0;
}
-#[no_mangle]
-pub unsafe extern "C" fn rs_mqtt_tx_get_alstate_progress(
+unsafe extern "C" fn mqtt_tx_get_alstate_progress(
tx: *mut std::os::raw::c_void, direction: u8,
) -> std::os::raw::c_int {
let tx = cast_pointer!(tx, MQTTTransaction);
return 0;
}
-#[no_mangle]
-pub unsafe extern "C" fn rs_mqtt_tx_get_logged(
- _state: *mut std::os::raw::c_void, tx: *mut std::os::raw::c_void,
-) -> u32 {
- let tx = cast_pointer!(tx, MQTTTransaction);
- return tx.logged.get();
-}
-
-#[no_mangle]
-pub unsafe extern "C" fn rs_mqtt_tx_set_logged(
- _state: *mut std::os::raw::c_void, tx: *mut std::os::raw::c_void, logged: u32,
-) {
- let tx = cast_pointer!(tx, MQTTTransaction);
- tx.logged.set(logged);
-}
-
// Parser name as a C style string.
const PARSER_NAME: &[u8] = b"mqtt\0";
name: PARSER_NAME.as_ptr() as *const std::os::raw::c_char,
default_port: default_port.as_ptr(),
ipproto: IPPROTO_TCP,
- probe_ts: Some(rs_mqtt_probing_parser),
- probe_tc: Some(rs_mqtt_probing_parser),
+ probe_ts: Some(mqtt_probing_parser),
+ probe_tc: Some(mqtt_probing_parser),
min_depth: 0,
max_depth: 16,
- state_new: rs_mqtt_state_new,
- state_free: rs_mqtt_state_free,
- tx_free: rs_mqtt_state_tx_free,
- parse_ts: rs_mqtt_parse_request,
- parse_tc: rs_mqtt_parse_response,
- get_tx_count: rs_mqtt_state_get_tx_count,
- get_tx: rs_mqtt_state_get_tx,
+ state_new: mqtt_state_new,
+ state_free: mqtt_state_free,
+ tx_free: mqtt_state_tx_free,
+ parse_ts: mqtt_parse_request,
+ parse_tc: mqtt_parse_response,
+ get_tx_count: mqtt_state_get_tx_count,
+ get_tx: mqtt_state_get_tx,
tx_comp_st_ts: 1,
tx_comp_st_tc: 1,
- tx_get_progress: rs_mqtt_tx_get_alstate_progress,
+ tx_get_progress: mqtt_tx_get_alstate_progress,
get_eventinfo: Some(MQTTEvent::get_event_info),
get_eventinfo_byid: Some(MQTTEvent::get_event_info_by_id),
localstorage_new: None,
bool JsonMQTTAddMetadata(void *vtx, JsonBuilder *js)
{
- return rs_mqtt_logger_log(vtx, MQTT_DEFAULT_FLAGS, MQTT_DEFAULT_MAXLOGLEN, js);
+ return SCMqttLoggerLog(vtx, MQTT_DEFAULT_FLAGS, MQTT_DEFAULT_MAXLOGLEN, js);
}
static int JsonMQTTLogger(ThreadVars *tv, void *thread_data,
LogMQTTLogThread *thread = thread_data;
enum OutputJsonLogDirection dir;
- if (rs_mqtt_tx_is_toclient((MQTTTransaction*) tx)) {
+ if (SCMqttTxIsToClient((MQTTTransaction *)tx)) {
dir = LOG_DIR_FLOW_TOCLIENT;
} else {
dir = LOG_DIR_FLOW_TOSERVER;
return TM_ECODE_FAILED;
}
- if (!rs_mqtt_logger_log(tx, thread->mqttlog_ctx->flags, thread->mqttlog_ctx->max_log_len, js))
+ if (!SCMqttLoggerLog(tx, thread->mqttlog_ctx->flags, thread->mqttlog_ctx->max_log_len, js))
goto error;
OutputJsonBuilderBuffer(tv, p, p->flow, js, thread->ctx);