From b1bc75276dafda12189f57566d0dba287fd8c0e0 Mon Sep 17 00:00:00 2001 From: Jason Ish Date: Tue, 22 Oct 2024 11:55:21 -0600 Subject: [PATCH] app-layer: use uint8_t consistent for event IDs Introduce a common function for mapping names to IDs that performs bounds checking. Note: For event IDs in the enum that are larger than a uint8_t, -1 will be returned instead of -4. -4 has special meaning during signature parsin that means requirements were not met. -4 has no special handling prior to requirements, or the meaning has been lost. (cherry picked from commit ab6dcb3fc1443161702f1108670b69841453874f) Additional fixup for ENIP that was no in master. --- rust/derive/src/applayerevent.rs | 10 +++--- rust/src/applayer.rs | 24 ++++++++------- rust/src/ftp/event.rs | 4 +-- rust/src/smb/smb.rs | 4 +-- src/app-layer-dnp3.c | 22 +++++--------- src/app-layer-enip.c | 23 +++++--------- src/app-layer-events.c | 52 +++++++++++++++++--------------- src/app-layer-events.h | 11 ++++--- src/app-layer-htp.c | 23 +++++--------- src/app-layer-parser.c | 22 +++++++------- src/app-layer-parser.h | 14 ++++----- src/app-layer-register.h | 8 ++--- src/app-layer-smtp.c | 23 +++++--------- src/app-layer-ssl.c | 23 +++++--------- src/app-layer-tftp.c | 4 +-- src/detect-app-layer-event.c | 11 ++----- 16 files changed, 123 insertions(+), 155 deletions(-) diff --git a/rust/derive/src/applayerevent.rs b/rust/derive/src/applayerevent.rs index 990d5e664f85..6071c19af2fe 100644 --- a/rust/derive/src/applayerevent.rs +++ b/rust/derive/src/applayerevent.rs @@ -41,7 +41,7 @@ pub fn derive_app_layer_event(input: TokenStream) -> TokenStream { let cname = format!("{}\0", event_name); event_names.push(event_name); event_cstrings.push(cname); - event_ids.push(i as i32); + event_ids.push(i as u8); } } _ => panic!("AppLayerEvent can only be derived for enums"), @@ -60,14 +60,14 @@ pub fn derive_app_layer_event(input: TokenStream) -> TokenStream { let expanded = quote! { impl #crate_id::applayer::AppLayerEvent for #name { - fn from_id(id: i32) -> Option<#name> { + fn from_id(id: u8) -> Option<#name> { match id { #( #event_ids => Some(#name::#fields) ,)* _ => None, } } - fn as_i32(&self) -> i32 { + fn as_u8(&self) -> u8 { match *self { #( #name::#fields => #event_ids ,)* } @@ -88,14 +88,14 @@ pub fn derive_app_layer_event(input: TokenStream) -> TokenStream { unsafe extern "C" fn get_event_info( event_name: *const std::os::raw::c_char, - event_id: *mut std::os::raw::c_int, + event_id: *mut u8, event_type: *mut #crate_id::core::AppLayerEventType, ) -> std::os::raw::c_int { #crate_id::applayer::get_event_info::<#name>(event_name, event_id, event_type) } unsafe extern "C" fn get_event_info_by_id( - event_id: std::os::raw::c_int, + event_id: u8, event_name: *mut *const std::os::raw::c_char, event_type: *mut #crate_id::core::AppLayerEventType, ) -> std::os::raw::c_int { diff --git a/rust/src/applayer.rs b/rust/src/applayer.rs index 113aa238b370..473fc1fe6686 100644 --- a/rust/src/applayer.rs +++ b/rust/src/applayer.rs @@ -444,8 +444,8 @@ pub type StateTxFreeFn = unsafe extern "C" fn (*mut c_void, u64); pub type StateGetTxFn = unsafe extern "C" fn (*mut c_void, u64) -> *mut c_void; pub type StateGetTxCntFn = unsafe extern "C" fn (*mut c_void) -> u64; pub type StateGetProgressFn = unsafe extern "C" fn (*mut c_void, u8) -> c_int; -pub type GetEventInfoFn = unsafe extern "C" fn (*const c_char, *mut c_int, *mut AppLayerEventType) -> c_int; -pub type GetEventInfoByIdFn = unsafe extern "C" fn (c_int, *mut *const c_char, *mut AppLayerEventType) -> c_int; +pub type GetEventInfoFn = unsafe extern "C" fn (*const c_char, event_id: *mut u8, *mut AppLayerEventType) -> c_int; +pub type GetEventInfoByIdFn = unsafe extern "C" fn (event_id: u8, *mut *const c_char, *mut AppLayerEventType) -> c_int; pub type LocalStorageNewFn = extern "C" fn () -> *mut c_void; pub type LocalStorageFreeFn = extern "C" fn (*mut c_void); pub type GetTxFilesFn = unsafe extern "C" fn (*mut c_void, *mut c_void, u8) -> AppLayerGetFileState; @@ -566,7 +566,7 @@ impl LoggerFlags { /// derive AppLayerEvent. pub trait AppLayerEvent { /// Return the enum variant of the given ID. - fn from_id(id: i32) -> Option where Self: std::marker::Sized; + fn from_id(id: u8) -> Option where Self: std::marker::Sized; /// Convert the enum variant to a C-style string (suffixed with \0). fn to_cstring(&self) -> &str; @@ -575,16 +575,16 @@ pub trait AppLayerEvent { fn from_string(s: &str) -> Option where Self: std::marker::Sized; /// Return the ID value of the enum variant. - fn as_i32(&self) -> i32; + fn as_u8(&self) -> u8; unsafe extern "C" fn get_event_info( event_name: *const std::os::raw::c_char, - event_id: *mut std::os::raw::c_int, + event_id: *mut u8, event_type: *mut core::AppLayerEventType, ) -> std::os::raw::c_int; unsafe extern "C" fn get_event_info_by_id( - event_id: std::os::raw::c_int, + event_id: u8, event_name: *mut *const std::os::raw::c_char, event_type: *mut core::AppLayerEventType, ) -> std::os::raw::c_int; @@ -608,7 +608,7 @@ pub trait AppLayerEvent { #[inline(always)] pub unsafe fn get_event_info( event_name: *const std::os::raw::c_char, - event_id: *mut std::os::raw::c_int, + event_id: *mut u8, event_type: *mut core::AppLayerEventType, ) -> std::os::raw::c_int { if event_name.is_null() { @@ -616,11 +616,13 @@ pub unsafe fn get_event_info( } let event = match CStr::from_ptr(event_name).to_str().map(T::from_string) { - Ok(Some(event)) => event.as_i32(), - _ => -1, + Ok(Some(event)) => event.as_u8(), + _ => { + return -1; + } }; *event_type = core::AppLayerEventType::APP_LAYER_EVENT_TYPE_TRANSACTION; - *event_id = event as std::os::raw::c_int; + *event_id = event; return 0; } @@ -628,7 +630,7 @@ pub unsafe fn get_event_info( /// AppLayerEvent. #[inline(always)] pub unsafe fn get_event_info_by_id( - event_id: std::os::raw::c_int, + event_id: u8, event_name: *mut *const std::os::raw::c_char, event_type: *mut core::AppLayerEventType, ) -> std::os::raw::c_int { diff --git a/rust/src/ftp/event.rs b/rust/src/ftp/event.rs index 04cc9e3f1e3b..cc327369d875 100644 --- a/rust/src/ftp/event.rs +++ b/rust/src/ftp/event.rs @@ -33,7 +33,7 @@ pub enum FtpEvent { /// Unsafe as called from C. #[no_mangle] pub unsafe extern "C" fn ftp_get_event_info( - event_name: *const c_char, event_id: *mut c_int, event_type: *mut AppLayerEventType, + event_name: *const c_char, event_id: *mut u8, event_type: *mut AppLayerEventType, ) -> c_int { crate::applayer::get_event_info::(event_name, event_id, event_type) } @@ -44,7 +44,7 @@ pub unsafe extern "C" fn ftp_get_event_info( /// Unsafe as called from C. #[no_mangle] pub unsafe extern "C" fn ftp_get_event_info_by_id( - event_id: c_int, event_name: *mut *const c_char, event_type: *mut AppLayerEventType, + event_id: u8, event_name: *mut *const c_char, event_type: *mut AppLayerEventType, ) -> c_int { crate::applayer::get_event_info_by_id::(event_id, event_name, event_type) as c_int } diff --git a/rust/src/smb/smb.rs b/rust/src/smb/smb.rs index 53058890b1b0..a1ccda41c7b7 100644 --- a/rust/src/smb/smb.rs +++ b/rust/src/smb/smb.rs @@ -2226,7 +2226,7 @@ pub unsafe extern "C" fn rs_smb_state_truncate( #[no_mangle] pub unsafe extern "C" fn rs_smb_state_get_event_info_by_id( - event_id: std::os::raw::c_int, + event_id: u8, event_name: *mut *const std::os::raw::c_char, event_type: *mut AppLayerEventType, ) -> std::os::raw::c_int { @@ -2236,7 +2236,7 @@ pub unsafe extern "C" fn rs_smb_state_get_event_info_by_id( #[no_mangle] pub unsafe extern "C" fn rs_smb_state_get_event_info( event_name: *const std::os::raw::c_char, - event_id: *mut std::os::raw::c_int, + event_id: *mut u8, event_type: *mut AppLayerEventType, ) -> std::os::raw::c_int { SMBEvent::get_event_info(event_name, event_id, event_type) diff --git a/src/app-layer-dnp3.c b/src/app-layer-dnp3.c index 9501b9f5ea57..34a142e5f251 100644 --- a/src/app-layer-dnp3.c +++ b/src/app-layer-dnp3.c @@ -1443,27 +1443,21 @@ static int DNP3GetAlstateProgress(void *tx, uint8_t direction) /** * \brief App-layer support. */ -static int DNP3StateGetEventInfo(const char *event_name, int *event_id, - AppLayerEventType *event_type) +static int DNP3StateGetEventInfo( + const char *event_name, uint8_t *event_id, AppLayerEventType *event_type) { - *event_id = SCMapEnumNameToValue(event_name, dnp3_decoder_event_table); - if (*event_id == -1) { - SCLogError("Event \"%s\" not present in " - "the DNP3 enum event map table.", - event_name); - return -1; + if (SCAppLayerGetEventIdByName(event_name, dnp3_decoder_event_table, event_id) == 0) { + *event_type = APP_LAYER_EVENT_TYPE_TRANSACTION; + return 0; } - - *event_type = APP_LAYER_EVENT_TYPE_TRANSACTION; - - return 0; + return -1; } /** * \brief App-layer support. */ -static int DNP3StateGetEventInfoById(int event_id, const char **event_name, - AppLayerEventType *event_type) +static int DNP3StateGetEventInfoById( + uint8_t event_id, const char **event_name, AppLayerEventType *event_type) { *event_name = SCMapEnumValueToName(event_id, dnp3_decoder_event_table); if (*event_name == NULL) { diff --git a/src/app-layer-enip.c b/src/app-layer-enip.c index 94c707c144b8..04d1cd7cb374 100644 --- a/src/app-layer-enip.c +++ b/src/app-layer-enip.c @@ -103,25 +103,18 @@ static uint64_t ENIPGetTxCnt(void *alstate) return ((ENIPState *)alstate)->transaction_max; } -static int ENIPStateGetEventInfo(const char *event_name, int *event_id, AppLayerEventType *event_type) +static int ENIPStateGetEventInfo( + const char *event_name, uint8_t *event_id, AppLayerEventType *event_type) { - *event_id = SCMapEnumNameToValue(event_name, enip_decoder_event_table); - - if (*event_id == -1) { - SCLogError("event \"%s\" not present in " - "enip's enum map table.", - event_name); - /* yes this is fatal */ - return -1; + if (SCAppLayerGetEventIdByName(event_name, enip_decoder_event_table, event_id)) { + *event_type = APP_LAYER_EVENT_TYPE_TRANSACTION; + return 0; } - - *event_type = APP_LAYER_EVENT_TYPE_TRANSACTION; - - return 0; + return -1; } -static int ENIPStateGetEventInfoById(int event_id, const char **event_name, - AppLayerEventType *event_type) +static int ENIPStateGetEventInfoById( + uint8_t event_id, const char **event_name, AppLayerEventType *event_type) { *event_name = SCMapEnumValueToName(event_id, enip_decoder_event_table); if (*event_name == NULL) { diff --git a/src/app-layer-events.c b/src/app-layer-events.c index e3d381135085..0c27ed14c806 100644 --- a/src/app-layer-events.c +++ b/src/app-layer-events.c @@ -1,4 +1,4 @@ -/* Copyright (C) 2014-2022 Open Information Security Foundation +/* Copyright (C) 2014-2024 Open Information Security Foundation * * You can copy, redistribute or modify this Program under the terms of * the GNU General Public License version 2 as published by the Free @@ -29,6 +29,22 @@ #include "app-layer-parser.h" #include "util-enum.h" +int SCAppLayerGetEventIdByName(const char *event_name, SCEnumCharMap *table, uint8_t *event_id) +{ + int value = SCMapEnumNameToValue(event_name, table); + if (value == -1) { + SCLogError("event \"%s\" not present in enum table.", event_name); + /* this should be treated as fatal */ + return -1; + } else if (value < -1 || value > UINT8_MAX) { + SCLogError("event \"%s\" has out of range value", event_name); + /* this should be treated as fatal */ + return -1; + } + *event_id = (uint8_t)value; + return 0; +} + /* events raised during protocol detection are stored in the * packets storage, not in the flow. */ SCEnumCharMap app_layer_event_pkt_table[ ] = { @@ -48,8 +64,8 @@ SCEnumCharMap app_layer_event_pkt_table[ ] = { -1 }, }; -int AppLayerGetEventInfoById(int event_id, const char **event_name, - AppLayerEventType *event_type) +int AppLayerGetEventInfoById( + uint8_t event_id, const char **event_name, AppLayerEventType *event_type) { *event_name = SCMapEnumValueToName(event_id, app_layer_event_pkt_table); if (*event_name == NULL) { @@ -65,18 +81,9 @@ int AppLayerGetEventInfoById(int event_id, const char **event_name, return 0; } -int AppLayerGetPktEventInfo(const char *event_name, int *event_id) +int AppLayerGetPktEventInfo(const char *event_name, uint8_t *event_id) { - *event_id = SCMapEnumNameToValue(event_name, app_layer_event_pkt_table); - if (*event_id == -1) { - SCLogError("event \"%s\" not present in " - "app-layer-event's packet event table.", - event_name); - /* this should be treated as fatal */ - return -1; - } - - return 0; + return SCAppLayerGetEventIdByName(event_name, app_layer_event_pkt_table, event_id); } #define DECODER_EVENTS_BUFFER_STEPS 8 @@ -162,17 +169,12 @@ SCEnumCharMap det_ctx_event_table[] = { { NULL, -1 }, }; -int DetectEngineGetEventInfo(const char *event_name, int *event_id, AppLayerEventType *event_type) +int DetectEngineGetEventInfo( + const char *event_name, uint8_t *event_id, AppLayerEventType *event_type) { - *event_id = SCMapEnumNameToValue(event_name, det_ctx_event_table); - if (*event_id == -1) { - SCLogError("event \"%s\" not present in " - "det_ctx's enum map table.", - event_name); - /* this should be treated as fatal */ - return -1; + if (SCAppLayerGetEventIdByName(event_name, det_ctx_event_table, event_id) == 0) { + *event_type = APP_LAYER_EVENT_TYPE_TRANSACTION; + return 0; } - *event_type = APP_LAYER_EVENT_TYPE_TRANSACTION; - - return 0; + return -1; } diff --git a/src/app-layer-events.h b/src/app-layer-events.h index 83cb0d9ba471..bda8dc5c4969 100644 --- a/src/app-layer-events.h +++ b/src/app-layer-events.h @@ -28,6 +28,7 @@ /* contains fwd declaration of AppLayerDecoderEvents_ */ #include "decode.h" #include "rust.h" +#include "util-enum.h" /** * \brief Data structure to store app layer decoder events. @@ -53,10 +54,10 @@ enum { APPLAYER_UNEXPECTED_PROTOCOL, }; -int AppLayerGetPktEventInfo(const char *event_name, int *event_id); +int AppLayerGetPktEventInfo(const char *event_name, uint8_t *event_id); -int AppLayerGetEventInfoById(int event_id, const char **event_name, - AppLayerEventType *event_type); +int AppLayerGetEventInfoById( + uint8_t event_id, const char **event_name, AppLayerEventType *event_type); void AppLayerDecoderEventsSetEventRaw(AppLayerDecoderEvents **sevents, uint8_t event); static inline int AppLayerDecoderEventsIsEventSet(AppLayerDecoderEvents *devents, @@ -77,7 +78,9 @@ static inline int AppLayerDecoderEventsIsEventSet(AppLayerDecoderEvents *devents void AppLayerDecoderEventsResetEvents(AppLayerDecoderEvents *events); void AppLayerDecoderEventsFreeEvents(AppLayerDecoderEvents **events); -int DetectEngineGetEventInfo(const char *event_name, int *event_id, AppLayerEventType *event_type); +int DetectEngineGetEventInfo( + const char *event_name, uint8_t *event_id, AppLayerEventType *event_type); +int SCAppLayerGetEventIdByName(const char *event_name, SCEnumCharMap *table, uint8_t *event_id); #endif /* __APP_LAYER_EVENTS_H__ */ diff --git a/src/app-layer-htp.c b/src/app-layer-htp.c index 84cfd2148cf8..d6bd90b1f856 100644 --- a/src/app-layer-htp.c +++ b/src/app-layer-htp.c @@ -3144,25 +3144,18 @@ void *HtpGetTxForH2(void *alstate) return NULL; } -static int HTPStateGetEventInfo(const char *event_name, - int *event_id, AppLayerEventType *event_type) +static int HTPStateGetEventInfo( + const char *event_name, uint8_t *event_id, AppLayerEventType *event_type) { - *event_id = SCMapEnumNameToValue(event_name, http_decoder_event_table); - if (*event_id == -1) { - SCLogError("event \"%s\" not present in " - "http's enum map table.", - event_name); - /* this should be treated as fatal */ - return -1; + if (SCAppLayerGetEventIdByName(event_name, http_decoder_event_table, event_id) == 0) { + *event_type = APP_LAYER_EVENT_TYPE_TRANSACTION; + return 0; } - - *event_type = APP_LAYER_EVENT_TYPE_TRANSACTION; - - return 0; + return -1; } -static int HTPStateGetEventInfoById(int event_id, const char **event_name, - AppLayerEventType *event_type) +static int HTPStateGetEventInfoById( + uint8_t event_id, const char **event_name, AppLayerEventType *event_type) { *event_name = SCMapEnumValueToName(event_id, http_decoder_event_table); if (*event_name == NULL) { diff --git a/src/app-layer-parser.c b/src/app-layer-parser.c index a051616dd3b9..d5ff4a4fe5bc 100644 --- a/src/app-layer-parser.c +++ b/src/app-layer-parser.c @@ -103,10 +103,10 @@ typedef struct AppLayerParserProtoCtx_ AppLayerGetTxIteratorFunc StateGetTxIterator; int complete_ts; int complete_tc; - int (*StateGetEventInfoById)(int event_id, const char **event_name, - AppLayerEventType *event_type); - int (*StateGetEventInfo)(const char *event_name, - int *event_id, AppLayerEventType *event_type); + int (*StateGetEventInfoById)( + uint8_t event_id, const char **event_name, AppLayerEventType *event_type); + int (*StateGetEventInfo)( + const char *event_name, uint8_t *event_id, AppLayerEventType *event_type); AppLayerStateData *(*GetStateData)(void *state); AppLayerTxData *(*GetTxData)(void *tx); @@ -561,8 +561,8 @@ void AppLayerParserRegisterStateProgressCompletionStatus( } void AppLayerParserRegisterGetEventInfoById(uint8_t ipproto, AppProto alproto, - int (*StateGetEventInfoById)(int event_id, const char **event_name, - AppLayerEventType *event_type)) + int (*StateGetEventInfoById)( + uint8_t event_id, const char **event_name, AppLayerEventType *event_type)) { SCEnter(); @@ -583,8 +583,8 @@ void AppLayerParserRegisterGetFrameFuncs(uint8_t ipproto, AppProto alproto, } void AppLayerParserRegisterGetEventInfo(uint8_t ipproto, AppProto alproto, - int (*StateGetEventInfo)(const char *event_name, int *event_id, - AppLayerEventType *event_type)) + int (*StateGetEventInfo)( + const char *event_name, uint8_t *event_id, AppLayerEventType *event_type)) { SCEnter(); @@ -1140,7 +1140,7 @@ int AppLayerParserGetStateProgressCompletionStatus(AppProto alproto, } int AppLayerParserGetEventInfo(uint8_t ipproto, AppProto alproto, const char *event_name, - int *event_id, AppLayerEventType *event_type) + uint8_t *event_id, AppLayerEventType *event_type) { SCEnter(); const int ipproto_map = FlowGetProtoMapping(ipproto); @@ -1149,8 +1149,8 @@ int AppLayerParserGetEventInfo(uint8_t ipproto, AppProto alproto, const char *ev SCReturnInt(r); } -int AppLayerParserGetEventInfoById(uint8_t ipproto, AppProto alproto, int event_id, - const char **event_name, AppLayerEventType *event_type) +int AppLayerParserGetEventInfoById(uint8_t ipproto, AppProto alproto, uint8_t event_id, + const char **event_name, AppLayerEventType *event_type) { SCEnter(); const int ipproto_map = FlowGetProtoMapping(ipproto); diff --git a/src/app-layer-parser.h b/src/app-layer-parser.h index d27a08c85119..850c43316716 100644 --- a/src/app-layer-parser.h +++ b/src/app-layer-parser.h @@ -198,11 +198,11 @@ void AppLayerParserRegisterGetTxIterator(uint8_t ipproto, AppProto alproto, void AppLayerParserRegisterStateProgressCompletionStatus( AppProto alproto, const int ts, const int tc); void AppLayerParserRegisterGetEventInfo(uint8_t ipproto, AppProto alproto, - int (*StateGetEventInfo)(const char *event_name, int *event_id, - AppLayerEventType *event_type)); + int (*StateGetEventInfo)( + const char *event_name, uint8_t *event_id, AppLayerEventType *event_type)); void AppLayerParserRegisterGetEventInfoById(uint8_t ipproto, AppProto alproto, - int (*StateGetEventInfoById)(int event_id, const char **event_name, - AppLayerEventType *event_type)); + int (*StateGetEventInfoById)( + uint8_t event_id, const char **event_name, AppLayerEventType *event_type)); void AppLayerParserRegisterGetFrameFuncs(uint8_t ipproto, AppProto alproto, AppLayerParserGetFrameIdByNameFn GetFrameIdByName, AppLayerParserGetFrameNameByIdFn GetFrameNameById); @@ -245,9 +245,9 @@ uint64_t AppLayerParserGetTxCnt(const Flow *, void *alstate); void *AppLayerParserGetTx(uint8_t ipproto, AppProto alproto, void *alstate, uint64_t tx_id); int AppLayerParserGetStateProgressCompletionStatus(AppProto alproto, uint8_t direction); int AppLayerParserGetEventInfo(uint8_t ipproto, AppProto alproto, const char *event_name, - int *event_id, AppLayerEventType *event_type); -int AppLayerParserGetEventInfoById(uint8_t ipproto, AppProto alproto, int event_id, - const char **event_name, AppLayerEventType *event_type); + uint8_t *event_id, AppLayerEventType *event_type); +int AppLayerParserGetEventInfoById(uint8_t ipproto, AppProto alproto, uint8_t event_id, + const char **event_name, AppLayerEventType *event_type); uint64_t AppLayerParserGetTransactionActive(const Flow *f, AppLayerParserState *pstate, uint8_t direction); diff --git a/src/app-layer-register.h b/src/app-layer-register.h index 4fcbe6cf8b6c..6316bffc8cbd 100644 --- a/src/app-layer-register.h +++ b/src/app-layer-register.h @@ -51,10 +51,10 @@ typedef struct AppLayerParser { const int complete_tc; int (*StateGetProgress)(void *alstate, uint8_t direction); - int (*StateGetEventInfo)(const char *event_name, - int *event_id, AppLayerEventType *event_type); - int (*StateGetEventInfoById)(int event_id, const char **event_name, - AppLayerEventType *event_type); + int (*StateGetEventInfo)( + const char *event_name, uint8_t *event_id, AppLayerEventType *event_type); + int (*StateGetEventInfoById)( + uint8_t event_id, const char **event_name, AppLayerEventType *event_type); void *(*LocalStorageAlloc)(void); void (*LocalStorageFree)(void *); diff --git a/src/app-layer-smtp.c b/src/app-layer-smtp.c index 5a08c02ce46a..bdb3f654a6e8 100644 --- a/src/app-layer-smtp.c +++ b/src/app-layer-smtp.c @@ -1691,25 +1691,18 @@ static void SMTPFreeMpmState(void) } } -static int SMTPStateGetEventInfo(const char *event_name, - int *event_id, AppLayerEventType *event_type) +static int SMTPStateGetEventInfo( + const char *event_name, uint8_t *event_id, AppLayerEventType *event_type) { - *event_id = SCMapEnumNameToValue(event_name, smtp_decoder_event_table); - if (*event_id == -1) { - SCLogError("event \"%s\" not present in " - "smtp's enum map table.", - event_name); - /* yes this is fatal */ - return -1; + if (SCAppLayerGetEventIdByName(event_name, smtp_decoder_event_table, event_id) == 0) { + *event_type = APP_LAYER_EVENT_TYPE_TRANSACTION; + return 0; } - - *event_type = APP_LAYER_EVENT_TYPE_TRANSACTION; - - return 0; + return -1; } -static int SMTPStateGetEventInfoById(int event_id, const char **event_name, - AppLayerEventType *event_type) +static int SMTPStateGetEventInfoById( + uint8_t event_id, const char **event_name, AppLayerEventType *event_type) { *event_name = SCMapEnumValueToName(event_id, smtp_decoder_event_table); if (*event_name == NULL) { diff --git a/src/app-layer-ssl.c b/src/app-layer-ssl.c index 7dff89dac6c3..867d70da391e 100644 --- a/src/app-layer-ssl.c +++ b/src/app-layer-ssl.c @@ -2948,25 +2948,18 @@ static const char *SSLStateGetFrameNameById(const uint8_t frame_id) return name; } -static int SSLStateGetEventInfo(const char *event_name, - int *event_id, AppLayerEventType *event_type) +static int SSLStateGetEventInfo( + const char *event_name, uint8_t *event_id, AppLayerEventType *event_type) { - *event_id = SCMapEnumNameToValue(event_name, tls_decoder_event_table); - if (*event_id == -1) { - SCLogError("event \"%s\" not present in " - "ssl's enum map table.", - event_name); - /* yes this is fatal */ - return -1; + if (SCAppLayerGetEventIdByName(event_name, tls_decoder_event_table, event_id) == 0) { + *event_type = APP_LAYER_EVENT_TYPE_TRANSACTION; + return 0; } - - *event_type = APP_LAYER_EVENT_TYPE_TRANSACTION; - - return 0; + return -1; } -static int SSLStateGetEventInfoById(int event_id, const char **event_name, - AppLayerEventType *event_type) +static int SSLStateGetEventInfoById( + uint8_t event_id, const char **event_name, AppLayerEventType *event_type) { *event_name = SCMapEnumValueToName(event_id, tls_decoder_event_table); if (*event_name == NULL) { diff --git a/src/app-layer-tftp.c b/src/app-layer-tftp.c index 73dc52a59eac..3d3434156e38 100644 --- a/src/app-layer-tftp.c +++ b/src/app-layer-tftp.c @@ -67,8 +67,8 @@ static void TFTPStateTxFree(void *state, uint64_t tx_id) rs_tftp_state_tx_free(state, tx_id); } -static int TFTPStateGetEventInfo(const char *event_name, int *event_id, - AppLayerEventType *event_type) +static int TFTPStateGetEventInfo( + const char *event_name, uint8_t *event_id, AppLayerEventType *event_type) { return -1; } diff --git a/src/detect-app-layer-event.c b/src/detect-app-layer-event.c index bf306d363d39..c09a7cf7ea38 100644 --- a/src/detect-app-layer-event.c +++ b/src/detect-app-layer-event.c @@ -144,9 +144,8 @@ static int DetectAppLayerEventPktMatch(DetectEngineThreadCtx *det_ctx, static DetectAppLayerEventData *DetectAppLayerEventParsePkt(const char *arg, AppLayerEventType *event_type) { - int event_id = 0; - int r = AppLayerGetPktEventInfo(arg, &event_id); - if (r < 0 || r > UINT8_MAX) { + uint8_t event_id = 0; + if (AppLayerGetPktEventInfo(arg, &event_id) != 0) { SCLogError("app-layer-event keyword " "supplied with packet based event - \"%s\" that isn't " "supported yet.", @@ -247,7 +246,7 @@ static int DetectAppLayerEventSetup(DetectEngineCtx *de_ctx, Signature *s, const } int r; - int event_id = 0; + uint8_t event_id = 0; if (!needs_detctx) { r = AppLayerParserGetEventInfo(ipproto, alproto, event_name, &event_id, &event_type); } else { @@ -266,10 +265,6 @@ static int DetectAppLayerEventSetup(DetectEngineCtx *de_ctx, Signature *s, const return -3; } } - if (event_id > UINT8_MAX) { - SCLogWarning("app-layer-event keyword's id has invalid value"); - return -4; - } data = SCCalloc(1, sizeof(*data)); if (unlikely(data == NULL)) return -1;