|
|
|
@ -561,7 +561,7 @@ fn probe_tc(input: &[u8]) -> bool {
|
|
|
|
|
|
|
|
|
|
/// C entry point for a probing parser.
|
|
|
|
|
#[no_mangle]
|
|
|
|
|
pub unsafe extern "C" fn rs_pgsql_probing_parser_ts(
|
|
|
|
|
pub unsafe extern "C" fn SCPgsqlProbingParserTS(
|
|
|
|
|
_flow: *const Flow, _direction: u8, input: *const u8, input_len: u32, _rdir: *mut u8,
|
|
|
|
|
) -> AppProto {
|
|
|
|
|
if input_len >= 1 && !input.is_null() {
|
|
|
|
@ -587,7 +587,7 @@ pub unsafe extern "C" fn rs_pgsql_probing_parser_ts(
|
|
|
|
|
|
|
|
|
|
/// C entry point for a probing parser.
|
|
|
|
|
#[no_mangle]
|
|
|
|
|
pub unsafe extern "C" fn rs_pgsql_probing_parser_tc(
|
|
|
|
|
pub unsafe extern "C" fn SCPgsqlProbingParserTC(
|
|
|
|
|
_flow: *const Flow, _direction: u8, input: *const u8, input_len: u32, _rdir: *mut u8,
|
|
|
|
|
) -> AppProto {
|
|
|
|
|
if input_len >= 1 && !input.is_null() {
|
|
|
|
@ -616,7 +616,7 @@ pub unsafe extern "C" fn rs_pgsql_probing_parser_tc(
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[no_mangle]
|
|
|
|
|
pub extern "C" fn rs_pgsql_state_new(
|
|
|
|
|
pub extern "C" fn SCPgsqlStateNew(
|
|
|
|
|
_orig_state: *mut std::os::raw::c_void, _orig_proto: AppProto,
|
|
|
|
|
) -> *mut std::os::raw::c_void {
|
|
|
|
|
let state = PgsqlState::new();
|
|
|
|
@ -625,13 +625,13 @@ pub extern "C" fn rs_pgsql_state_new(
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[no_mangle]
|
|
|
|
|
pub extern "C" fn rs_pgsql_state_free(state: *mut std::os::raw::c_void) {
|
|
|
|
|
pub extern "C" fn SCPgsqlStateFree(state: *mut std::os::raw::c_void) {
|
|
|
|
|
// Just unbox...
|
|
|
|
|
std::mem::drop(unsafe { Box::from_raw(state as *mut PgsqlState) });
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[no_mangle]
|
|
|
|
|
pub extern "C" fn rs_pgsql_state_tx_free(state: *mut std::os::raw::c_void, tx_id: u64) {
|
|
|
|
|
pub extern "C" fn SCPgsqlStateTxFree(state: *mut std::os::raw::c_void, tx_id: u64) {
|
|
|
|
|
let state_safe: &mut PgsqlState;
|
|
|
|
|
unsafe {
|
|
|
|
|
state_safe = cast_pointer!(state, PgsqlState);
|
|
|
|
@ -640,7 +640,7 @@ pub extern "C" fn rs_pgsql_state_tx_free(state: *mut std::os::raw::c_void, tx_id
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[no_mangle]
|
|
|
|
|
pub unsafe extern "C" fn rs_pgsql_parse_request(
|
|
|
|
|
pub unsafe extern "C" fn SCPgsqlParseRequest(
|
|
|
|
|
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 {
|
|
|
|
@ -664,7 +664,7 @@ pub unsafe extern "C" fn rs_pgsql_parse_request(
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[no_mangle]
|
|
|
|
|
pub unsafe extern "C" fn rs_pgsql_parse_response(
|
|
|
|
|
pub unsafe extern "C" fn SCPgsqlParseResponse(
|
|
|
|
|
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 {
|
|
|
|
@ -687,7 +687,7 @@ pub unsafe extern "C" fn rs_pgsql_parse_response(
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[no_mangle]
|
|
|
|
|
pub unsafe extern "C" fn rs_pgsql_state_get_tx(
|
|
|
|
|
pub unsafe extern "C" fn SCPgsqlStateGetTx(
|
|
|
|
|
state: *mut std::os::raw::c_void, tx_id: u64,
|
|
|
|
|
) -> *mut std::os::raw::c_void {
|
|
|
|
|
let state_safe: &mut PgsqlState = cast_pointer!(state, PgsqlState);
|
|
|
|
@ -702,7 +702,7 @@ pub unsafe extern "C" fn rs_pgsql_state_get_tx(
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[no_mangle]
|
|
|
|
|
pub extern "C" fn rs_pgsql_state_get_tx_count(state: *mut std::os::raw::c_void) -> u64 {
|
|
|
|
|
pub extern "C" fn SCPgsqlStateGetTxCount(state: *mut std::os::raw::c_void) -> u64 {
|
|
|
|
|
let state_safe: &mut PgsqlState;
|
|
|
|
|
unsafe {
|
|
|
|
|
state_safe = cast_pointer!(state, PgsqlState);
|
|
|
|
@ -710,7 +710,8 @@ pub extern "C" fn rs_pgsql_state_get_tx_count(state: *mut std::os::raw::c_void)
|
|
|
|
|
return state_safe.tx_id;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
unsafe extern "C" fn rs_pgsql_tx_get_alstate_progress(
|
|
|
|
|
#[no_mangle]
|
|
|
|
|
pub unsafe extern "C" fn SCPgsqlTxGetALStateProgress(
|
|
|
|
|
tx: *mut std::os::raw::c_void, _direction: u8,
|
|
|
|
|
) -> std::os::raw::c_int {
|
|
|
|
|
let tx = cast_pointer!(tx, PgsqlTransaction);
|
|
|
|
@ -724,27 +725,27 @@ export_state_data_get!(rs_pgsql_get_state_data, PgsqlState);
|
|
|
|
|
const PARSER_NAME: &[u8] = b"pgsql\0";
|
|
|
|
|
|
|
|
|
|
#[no_mangle]
|
|
|
|
|
pub unsafe extern "C" fn rs_pgsql_register_parser() {
|
|
|
|
|
pub unsafe extern "C" fn SCRegisterPgsqlParser() {
|
|
|
|
|
let default_port = CString::new("[5432]").unwrap();
|
|
|
|
|
let mut stream_depth = PGSQL_CONFIG_DEFAULT_STREAM_DEPTH;
|
|
|
|
|
let parser = RustParser {
|
|
|
|
|
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_pgsql_probing_parser_ts),
|
|
|
|
|
probe_tc: Some(rs_pgsql_probing_parser_tc),
|
|
|
|
|
probe_ts: Some(SCPgsqlProbingParserTS),
|
|
|
|
|
probe_tc: Some(SCPgsqlProbingParserTC),
|
|
|
|
|
min_depth: 0,
|
|
|
|
|
max_depth: 16,
|
|
|
|
|
state_new: rs_pgsql_state_new,
|
|
|
|
|
state_free: rs_pgsql_state_free,
|
|
|
|
|
tx_free: rs_pgsql_state_tx_free,
|
|
|
|
|
parse_ts: rs_pgsql_parse_request,
|
|
|
|
|
parse_tc: rs_pgsql_parse_response,
|
|
|
|
|
get_tx_count: rs_pgsql_state_get_tx_count,
|
|
|
|
|
get_tx: rs_pgsql_state_get_tx,
|
|
|
|
|
state_new: SCPgsqlStateNew,
|
|
|
|
|
state_free: SCPgsqlStateFree,
|
|
|
|
|
tx_free: SCPgsqlStateTxFree,
|
|
|
|
|
parse_ts: SCPgsqlParseRequest,
|
|
|
|
|
parse_tc: SCPgsqlParseResponse,
|
|
|
|
|
get_tx_count: SCPgsqlStateGetTxCount,
|
|
|
|
|
get_tx: SCPgsqlStateGetTx,
|
|
|
|
|
tx_comp_st_ts: PgsqlTransactionState::RequestReceived as i32,
|
|
|
|
|
tx_comp_st_tc: PgsqlTransactionState::ResponseDone as i32,
|
|
|
|
|
tx_get_progress: rs_pgsql_tx_get_alstate_progress,
|
|
|
|
|
tx_get_progress: SCPgsqlTxGetALStateProgress,
|
|
|
|
|
get_eventinfo: None,
|
|
|
|
|
get_eventinfo_byid: None,
|
|
|
|
|
localstorage_new: None,
|
|
|
|
|