X-Git-Url: https://hackdaworld.org/gitweb/?p=my-code%2Fhdw-sniff.git;a=blobdiff_plain;f=parse.c;h=647c1761751c895a7f56ba0c5c9eaf36b8d7f722;hp=bae6cd9c3cac35f5838ee6f42d1ac1a53f25ffd1;hb=9dbed1c13fcd9df91f6bad2654f1634d5628f72d;hpb=e0585c09c6eca4aa0af0a5a658e6e711fb76d3a5 diff --git a/parse.c b/parse.c index bae6cd9..647c176 100644 --- a/parse.c +++ b/parse.c @@ -6,7 +6,6 @@ */ #include "parse.h" -//#include "802.11b.h" #include "main.h" /* all the parsing stuff will go here @@ -18,28 +17,54 @@ void parse_package(unsigned char *ptr,const struct pcap_pkthdr *pcap_header,cons t_info *info; int i; - t_sta sniffed_sta; + t_sta new_sta; + t_frame4_hdr *f4hdr; + t_frame3_hdr *f3hdr; + t_frame2_hdr *f2hdr; + t_frame1_hdr *f1hdr; + t_beacon_fb *beacon_fb; int ret; info=(t_info *)ptr; info->count++; + memset(&new_sta,0,sizeof(t_sta)); + if(info->dump_fd!=0) { ret=write(info->dump_fd,pcap_header,sizeof(struct pcap_pkthdr)); if(ret!=sizeof(struct pcap_pkthdr)) - display_console(info->display,"warning, pcap header write failed!"); + display_console(info,"warning, pcap header write failed!"); ret=write(info->dump_fd,package,pcap_header->caplen); if(ret!=pcap_header->caplen) - display_console(info->display,"warning, package write failed!"); + display_console(info,"warning, package write failed!"); } /* maybe there is offset to the actual ieee802.11 frame, for example prism header ... */ + if(FCTL_TYPE(package[0])==FCTL_TYPE_MGMT) { + info->count_m++; + if(FCTL_STYPE(package[0])==FCTL_STYPE_BEACON) { + f3hdr=(t_frame3_hdr *)package; + beacon_fb=(t_beacon_fb *)(package+sizeof(t_frame3_hdr)); + // new_sta. + /* debug output */ + dprintf(info->log_fd,"beacon: "); + for(i=0;ilog_fd,"%02x ",*((f3hdr->addr2)+i)); + dprintf(info->log_fd," essid: (len=%x) ",beacon_fb->ssid_length); + for(i=0;issid_length;i++) + dprintf(info->log_fd,"%c ",*(u8 *)(beacon_fb->ssid+i)); + dprintf(info->log_fd,"\n"); + } + } + else if(FCTL_TYPE(package[0])==FCTL_TYPE_CTRL) { + info->count_c++; + } + else if(FCTL_TYPE(package[0])==FCTL_TYPE_DATA) { + info->count_d++; + } - /* go on parsing frame ctl header here ... */ - - return 23; + display_console(info,""); }