summaryrefslogtreecommitdiff
authormjm <mjm>2002-12-04 19:51:24 (UTC)
committer mjm <mjm>2002-12-04 19:51:24 (UTC)
commitad62016e2d341876c068bead69a40ebd0370d822 (patch) (side-by-side diff)
treef974069739d25de1ffd4107b302234b7183d145a
parentba2de7d7233c0fbbd8ef31fae7aa5a9ded70225e (diff)
downloadopie-ad62016e2d341876c068bead69a40ebd0370d822.zip
opie-ad62016e2d341876c068bead69a40ebd0370d822.tar.gz
opie-ad62016e2d341876c068bead69a40ebd0370d822.tar.bz2
implemented send_to_gui
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/wellenreiter/libwellenreiter/source/sniff.cc41
-rw-r--r--noncore/net/wellenreiter/libwellenreiter/source/sniff.hh10
2 files changed, 31 insertions, 20 deletions
diff --git a/noncore/net/wellenreiter/libwellenreiter/source/sniff.cc b/noncore/net/wellenreiter/libwellenreiter/source/sniff.cc
index fedd8fc..66299d1 100644
--- a/noncore/net/wellenreiter/libwellenreiter/source/sniff.cc
+++ b/noncore/net/wellenreiter/libwellenreiter/source/sniff.cc
@@ -10,5 +10,6 @@
#include "log.hh"
+#include "proto.hh"
/* Main function, checks packets */
-void process_packets(const struct pcap_pkthdr *pkthdr, const unsigned char *packet)
+void process_packets(const struct pcap_pkthdr *pkthdr, const unsigned char *packet, char *guihost, int guiport)
{
@@ -22,2 +23,6 @@ void process_packets(const struct pcap_pkthdr *pkthdr, const unsigned char *pack
struct packetinfo *pinfoptr;
+
+ /* wl_network_t will finally be set and send to the ui */
+ wl_network_t wl_net;
+
pinfoptr=&pinfo;
@@ -94,4 +99,5 @@ void process_packets(const struct pcap_pkthdr *pkthdr, const unsigned char *pack
if (pinfoptr->cap_ESS == 1 &&pinfoptr->cap_IBSS ==0)
- {
- printf ("\nHave found an accesspoint:");
+ {
+ wl_loginfo("Found an access point");
+ wl_net.net_type=1;
}
@@ -99,4 +105,4 @@ void process_packets(const struct pcap_pkthdr *pkthdr, const unsigned char *pack
{
- printf ("\nHave found an AD-HOC station:");
-
+ wl_loginfo("Found an ad-hoc network");
+ wl_net.net_type=2;
}
@@ -104,3 +110,3 @@ void process_packets(const struct pcap_pkthdr *pkthdr, const unsigned char *pack
{
- printf ("\n\tOn a non-broadcasting network");
+ wl_loginfo("Net is a non-broadcasting network");
}
@@ -108,10 +114,15 @@ void process_packets(const struct pcap_pkthdr *pkthdr, const unsigned char *pack
{
- printf ("\n\tOn network : %s",pinfoptr->ssid);
+ wl_loginfo("SSID is: %s", pinfoptr->ssid);
+ // wl_net.bssid=pinfoptr->ssid;
}
- printf ("\n\tLen SSID : %d",pinfoptr->ssid_len);
- printf ("\n\tOn Channel : %d",pinfoptr->channel);
- printf ("\n\tEncryption : %s", pinfoptr->cap_WEP ? "ON" : "OFF");
- printf ("\n\tMacaddress : %s",pinfoptr->sndhwaddr);
- printf ("\n\tBssid : %s",pinfoptr->bssid);
- printf ("\n\tDest : %s\n",pinfoptr->desthwaddr);
+
+ wl_net.ssid_len=pinfoptr->ssid_len;
+ wl_net.channel=pinfoptr->channel;
+ wl_net.wep=pinfoptr->cap_WEP;
+ memcpy(wl_net.mac, pinfoptr->sndhwaddr, sizeof(wl_net.mac));;
+ memcpy(wl_net.bssid, pinfoptr->ssid, sizeof(wl_net.bssid));
+
+ // printf ("\n\tDest : %s\n",pinfoptr->desthwaddr);
+ send_network_found((char *)guihost, guiport, &wl_net);
+ wl_loginfo("Sent network to GUI '%s:%d'", guihost, guiport);
}
@@ -207,5 +218,5 @@ int handle_beacon(u_int16_t fc, const u_char *p,struct packetinfo *ppinfo)
if (strcmp((char *)pbody.ssid.ssid,"")==0)
- ppinfo->ssid = NONBROADCASTING;
+ memcpy(ppinfo->ssid, NONBROADCASTING, sizeof(ppinfo->ssid));
else
- ppinfo->ssid = (char *)pbody.ssid.ssid;
+ memcpy(ppinfo->ssid, pbody.ssid.ssid, sizeof(ppinfo->ssid));
ppinfo->ssid_len = pbody.ssid.length;
diff --git a/noncore/net/wellenreiter/libwellenreiter/source/sniff.hh b/noncore/net/wellenreiter/libwellenreiter/source/sniff.hh
index fa8519b..60cdc43 100644
--- a/noncore/net/wellenreiter/libwellenreiter/source/sniff.hh
+++ b/noncore/net/wellenreiter/libwellenreiter/source/sniff.hh
@@ -29,6 +29,6 @@ struct packetinfo
int channel;
- char bssid[sizeof("00:00:00:00:00:00")];
- char desthwaddr[sizeof("00:00:00:00:00:00")];
- char sndhwaddr[sizeof("00:00:00:00:00:00")];
- char *ssid;
+ char bssid[sizeof("00:00:00:00:00:00") + 1];
+ char desthwaddr[sizeof("00:00:00:00:00:00") + 1];
+ char sndhwaddr[sizeof("00:00:00:00:00:00") + 1];
+ char ssid[128];
int ssid_len;
@@ -36,3 +36,3 @@ struct packetinfo
-void process_packets(const struct pcap_pkthdr* pkthdr,const u_char* packet);
+void process_packets(const struct pcap_pkthdr* pkthdr,const u_char* packet, char *, int);
int decode_80211b_hdr(const u_char *p,struct packetinfo *ppinfo);