Attribution for pcaps

This commit is contained in:
rncwnd 2024-07-03 17:08:40 +01:00
parent 241c52a051
commit 87636b0d1e
Signed by: rncwnd
GPG key ID: 05EF307E0712FDAA
7 changed files with 40 additions and 10 deletions

1
.gitignore vendored
View file

@ -1 +1,2 @@
/target /target
/result

BIN
pcaps/bro_ssh.pcap Normal file

Binary file not shown.

BIN
pcaps/godpi_ssh.pcap Normal file

Binary file not shown.

8
pcaps/sources.md Normal file
View file

@ -0,0 +1,8 @@
- http.cap | wireshark
- http_image.cap | wireshark
- dns.cap | wireshark
- NTP_syc | wireshark
- telnet-cooked | wireshark
- SSHv2 | packetlife
- bro_ssh | try-bro
- godpi_ssh | go-dpi

View file

@ -61,7 +61,7 @@ fn main() {
stats.analyzed += 1; stats.analyzed += 1;
} }
if opt.print_analysis { if opt.print_analysis {
info!("{:?}", extracted); println!("{:?}", extracted);
} }
} }
Err(_) => stats.unknown_packets += 1, Err(_) => stats.unknown_packets += 1,

View file

@ -1,4 +1,6 @@
use dns::{DNSType, DNSValue}; use dns::{DNSType, DNSValue};
use log::info;
use ssh::SSHType;
mod dns; mod dns;
mod ssh; mod ssh;
@ -11,6 +13,7 @@ pub trait KnownProtocol {
#[derive(Debug)] #[derive(Debug)]
pub enum ProtocolType { pub enum ProtocolType {
DNS(DNSType), DNS(DNSType),
SSH,
} }
#[derive(Debug)] #[derive(Debug)]
@ -21,17 +24,22 @@ pub enum ExtractedInfo {
pub fn extract_info(ptype: ProtocolType, payload: Vec<u8>) -> Option<ExtractedInfo> { pub fn extract_info(ptype: ProtocolType, payload: Vec<u8>) -> Option<ExtractedInfo> {
match ptype { match ptype {
ProtocolType::DNS(x) => match x { ProtocolType::DNS(x) => match x {
DNSType::Query => { //DNSType::Query => Some(ExtractedInfo::DNSQuery(dns::analyse_dns_query(payload))),
return Some(ExtractedInfo::DNSQuery(dns::analyse_dns_query(payload))); DNSType::Query => Some(x.extract_info(payload)),
DNSType::Response => {
info!("DNS Response processing not handled yet!");
None
} }
DNSType::Response => return None,
}, },
ProtocolType::SSH => {
todo!()
}
} }
} }
pub fn match_protocol(payload: Vec<u8>) -> Result<ProtocolType, ()> { pub fn match_protocol(payload: Vec<u8>) -> Result<ProtocolType, ()> {
if let Ok(x) = dns::is_dns(payload) { if let Ok(x) = dns::DNSType::classify_proto(payload) {
return Ok(ProtocolType::DNS(x)); return Ok(x);
}; }
Err(()) Err(())
} }

View file

@ -1,4 +1,17 @@
pub fn is_ssh(payload: Vec<u8>) -> bool { use crate::{util::*, ExtractedInfo, KnownProtocol, ProtocolType};
// Check for ASCII "SSH"
payload[0] == 0x53 && payload[1] == 0x53 && payload[2] == 0x48 pub type SSHType = ();
impl KnownProtocol for SSHType {
fn classify_proto(payload: Vec<u8>) -> Result<ProtocolType, ()> {
if payload[0] == 0x53 && payload[1] == 0x53 && payload[2] == 0x48 {
Ok(ProtocolType::SSH)
} else {
Err(())
}
}
fn extract_info(&self, payload: Vec<u8>) -> ExtractedInfo {
todo!()
}
} }