use nom;
use std;
use std::collections::HashSet;
-use std::ffi::{CStr, CString};
+use std::ffi::CString;
-#[repr(u32)]
+#[derive(AppLayerEvent)]
pub enum IkeEvent {
- MalformedData = 0,
+ MalformedData,
NoEncryption,
WeakCryptoEnc,
- WeakCryptoPRF,
- WeakCryptoDH,
+ WeakCryptoPrf,
+ WeakCryptoDh,
WeakCryptoAuth,
- WeakCryptoNoDH,
+ WeakCryptoNoDh,
WeakCryptoNoAuth,
InvalidProposal,
UnknownProposal,
MultipleServerProposal,
}
-impl IkeEvent {
- pub fn from_i32(value: i32) -> Option<IkeEvent> {
- match value {
- 0 => Some(IkeEvent::MalformedData),
- 1 => Some(IkeEvent::NoEncryption),
- 2 => Some(IkeEvent::WeakCryptoEnc),
- 3 => Some(IkeEvent::WeakCryptoPRF),
- 4 => Some(IkeEvent::WeakCryptoDH),
- 5 => Some(IkeEvent::WeakCryptoAuth),
- 6 => Some(IkeEvent::WeakCryptoNoDH),
- 7 => Some(IkeEvent::WeakCryptoNoAuth),
- 8 => Some(IkeEvent::InvalidProposal),
- 9 => Some(IkeEvent::UnknownProposal),
- 10 => Some(IkeEvent::PayloadExtraData),
- 11 => Some(IkeEvent::MultipleServerProposal),
- _ => None,
- }
- }
-}
-
pub struct IkeHeaderWrapper {
pub spi_initiator: String,
pub spi_responder: String,
return tx.events;
}
-#[no_mangle]
-pub unsafe extern "C" fn rs_ike_state_get_event_info_by_id(
- event_id: std::os::raw::c_int, event_name: *mut *const std::os::raw::c_char,
- event_type: *mut core::AppLayerEventType,
-) -> i8 {
- if let Some(e) = IkeEvent::from_i32(event_id as i32) {
- let estr = match e {
- IkeEvent::MalformedData => "malformed_data\0",
- IkeEvent::NoEncryption => "no_encryption\0",
- IkeEvent::WeakCryptoEnc => "weak_crypto_enc\0",
- IkeEvent::WeakCryptoPRF => "weak_crypto_prf\0",
- IkeEvent::WeakCryptoDH => "weak_crypto_dh\0",
- IkeEvent::WeakCryptoAuth => "weak_crypto_auth\0",
- IkeEvent::WeakCryptoNoDH => "weak_crypto_nodh\0",
- IkeEvent::WeakCryptoNoAuth => "weak_crypto_noauth\0",
- IkeEvent::InvalidProposal => "invalid_proposal\0",
- IkeEvent::UnknownProposal => "unknown_proposal\0",
- IkeEvent::PayloadExtraData => "payload_extra_data\0",
- IkeEvent::MultipleServerProposal => "multiple_server_proposal\0",
- };
- *event_name = estr.as_ptr() as *const std::os::raw::c_char;
- *event_type = core::APP_LAYER_EVENT_TYPE_TRANSACTION;
- 0
- } else {
- -1
- }
-}
-
-#[no_mangle]
-pub unsafe extern "C" fn rs_ike_state_get_event_info(
- event_name: *const std::os::raw::c_char, event_id: *mut std::os::raw::c_int,
- event_type: *mut core::AppLayerEventType,
-) -> std::os::raw::c_int {
- if event_name == std::ptr::null() {
- return -1;
- }
- let c_event_name: &CStr = CStr::from_ptr(event_name);
- let event = match c_event_name.to_str() {
- Ok(s) => {
- match s {
- "malformed_data" => IkeEvent::MalformedData as i32,
- "no_encryption" => IkeEvent::NoEncryption as i32,
- "weak_crypto_enc" => IkeEvent::WeakCryptoEnc as i32,
- "weak_crypto_prf" => IkeEvent::WeakCryptoPRF as i32,
- "weak_crypto_auth" => IkeEvent::WeakCryptoAuth as i32,
- "weak_crypto_dh" => IkeEvent::WeakCryptoDH as i32,
- "weak_crypto_nodh" => IkeEvent::WeakCryptoNoDH as i32,
- "weak_crypto_noauth" => IkeEvent::WeakCryptoNoAuth as i32,
- "invalid_proposal" => IkeEvent::InvalidProposal as i32,
- "unknown_proposal" => IkeEvent::UnknownProposal as i32,
- "payload_extra_data" => IkeEvent::PayloadExtraData as i32,
- "multiple_server_proposal" => IkeEvent::MultipleServerProposal as i32,
- _ => -1, // unknown event
- }
- }
- Err(_) => -1, // UTF-8 conversion failed
- };
- *event_type = core::APP_LAYER_EVENT_TYPE_TRANSACTION;
- *event_id = event as std::os::raw::c_int;
- 0
-}
-
static mut ALPROTO_IKE : AppProto = ALPROTO_UNKNOWN;
#[no_mangle]
get_de_state : rs_ike_tx_get_detect_state,
set_de_state : rs_ike_tx_set_detect_state,
get_events : Some(rs_ike_state_get_events),
- get_eventinfo : Some(rs_ike_state_get_event_info),
- get_eventinfo_byid : Some(rs_ike_state_get_event_info_by_id),
+ get_eventinfo : Some(IkeEvent::get_event_info),
+ get_eventinfo_byid : Some(IkeEvent::get_event_info_by_id),
localstorage_new : None,
localstorage_free : None,
get_files : None,