author | mickeyl <mickeyl> | 2004-05-02 20:08:30 (UTC) |
---|---|---|
committer | mickeyl <mickeyl> | 2004-05-02 20:08:30 (UTC) |
commit | 109ed5f2a1cdfeb3680c9ec057a1083fcf8fab95 (patch) (unidiff) | |
tree | f7484ada7bff7e4f7a91184f6a8e078af6053dca | |
parent | 8602449caa5a055bd5f033e3792d0a59a0b41bfa (diff) | |
download | opie-109ed5f2a1cdfeb3680c9ec057a1083fcf8fab95.zip opie-109ed5f2a1cdfeb3680c9ec057a1083fcf8fab95.tar.gz opie-109ed5f2a1cdfeb3680c9ec057a1083fcf8fab95.tar.bz2 |
PacketViewer improvements:
- expose buffer size through API
- improve packet viewer logic
- display time/date of capture + capture length
-rw-r--r-- | noncore/net/wellenreiter/gui/configwindow.cpp | 27 | ||||
-rw-r--r-- | noncore/net/wellenreiter/gui/configwindow.h | 2 | ||||
-rw-r--r-- | noncore/net/wellenreiter/gui/packetview.cpp | 68 | ||||
-rw-r--r-- | noncore/net/wellenreiter/gui/packetview.h | 12 | ||||
-rw-r--r-- | noncore/net/wellenreiter/gui/wellenreiter.cpp | 2 |
5 files changed, 76 insertions, 35 deletions
diff --git a/noncore/net/wellenreiter/gui/configwindow.cpp b/noncore/net/wellenreiter/gui/configwindow.cpp index 279b39c..89ed24c 100644 --- a/noncore/net/wellenreiter/gui/configwindow.cpp +++ b/noncore/net/wellenreiter/gui/configwindow.cpp | |||
@@ -1,476 +1,483 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2002-2004 Michael 'Mickey' Lauer. All rights reserved. | 2 | ** Copyright (C) 2002-2004 Michael 'Mickey' Lauer. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Wellenreiter II. | 4 | ** This file is part of Wellenreiter II. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | **********************************************************************/ | 14 | **********************************************************************/ |
15 | 15 | ||
16 | /* LOCAL */ | 16 | /* LOCAL */ |
17 | #include "configwindow.h" | 17 | #include "configwindow.h" |
18 | #include "mainwindow.h" | 18 | #include "mainwindow.h" |
19 | 19 | ||
20 | /* OPIE */ | 20 | /* OPIE */ |
21 | #include <opie2/onetwork.h> | 21 | #include <opie2/onetwork.h> |
22 | #ifdef QWS | 22 | #ifdef QWS |
23 | #include <opie2/oapplication.h> | 23 | #include <opie2/oapplication.h> |
24 | #include <opie2/oconfig.h> | 24 | #include <opie2/oconfig.h> |
25 | #include <opie2/odevice.h> | 25 | #include <opie2/odevice.h> |
26 | #include <opie2/odebug.h> | 26 | #include <opie2/odebug.h> |
27 | using namespace Opie::Core; | 27 | using namespace Opie::Core; |
28 | using namespace Opie::Net; | 28 | using namespace Opie::Net; |
29 | #endif | 29 | #endif |
30 | 30 | ||
31 | /* QT */ | 31 | /* QT */ |
32 | #include <qapplication.h> | 32 | #include <qapplication.h> |
33 | #include <qcheckbox.h> | 33 | #include <qcheckbox.h> |
34 | #include <qcombobox.h> | 34 | #include <qcombobox.h> |
35 | #include <qfile.h> | 35 | #include <qfile.h> |
36 | #include <qlineedit.h> | 36 | #include <qlineedit.h> |
37 | #include <qlayout.h> | 37 | #include <qlayout.h> |
38 | #include <qmap.h> | 38 | #include <qmap.h> |
39 | #include <qpushbutton.h> | 39 | #include <qpushbutton.h> |
40 | #include <qradiobutton.h> | ||
41 | #include <qspinbox.h> | ||
40 | #include <qtabwidget.h> | 42 | #include <qtabwidget.h> |
41 | #include <qtoolbutton.h> | 43 | #include <qtoolbutton.h> |
42 | #include <qspinbox.h> | ||
43 | #include <qtextstream.h> | 44 | #include <qtextstream.h> |
44 | 45 | ||
45 | /* STD */ | 46 | /* STD */ |
46 | #include <assert.h> | 47 | #include <assert.h> |
47 | 48 | ||
48 | WellenreiterConfigWindow* WellenreiterConfigWindow::_instance = 0; | 49 | WellenreiterConfigWindow* WellenreiterConfigWindow::_instance = 0; |
49 | 50 | ||
50 | WellenreiterConfigWindow::WellenreiterConfigWindow( QWidget * parent, const char * name, WFlags f ) | 51 | WellenreiterConfigWindow::WellenreiterConfigWindow( QWidget * parent, const char * name, WFlags f ) |
51 | :WellenreiterConfigBase( parent, name, true, f ) | 52 | :WellenreiterConfigBase( parent, name, true, f ) |
52 | { | 53 | { |
53 | _devicetype[ "cisco" ] = DEVTYPE_CISCO; | 54 | _devicetype[ "cisco" ] = DEVTYPE_CISCO; |
54 | _devicetype[ "wlan-ng" ] = DEVTYPE_WLAN_NG; | 55 | _devicetype[ "wlan-ng" ] = DEVTYPE_WLAN_NG; |
55 | _devicetype[ "hostap" ] = DEVTYPE_HOSTAP; | 56 | _devicetype[ "hostap" ] = DEVTYPE_HOSTAP; |
56 | _devicetype[ "orinoco" ] = DEVTYPE_ORINOCO; | 57 | _devicetype[ "orinoco" ] = DEVTYPE_ORINOCO; |
57 | _devicetype[ "<manual>" ] = DEVTYPE_MANUAL; | 58 | _devicetype[ "<manual>" ] = DEVTYPE_MANUAL; |
58 | _devicetype[ "<file>" ] = DEVTYPE_FILE; | 59 | _devicetype[ "<file>" ] = DEVTYPE_FILE; |
59 | 60 | ||
60 | // gather possible interface names from ONetwork | 61 | // gather possible interface names from ONetwork |
61 | ONetwork* net = ONetwork::instance(); | 62 | ONetwork* net = ONetwork::instance(); |
62 | ONetwork::InterfaceIterator it = net->iterator(); | 63 | ONetwork::InterfaceIterator it = net->iterator(); |
63 | while ( it.current() ) | 64 | while ( it.current() ) |
64 | { | 65 | { |
65 | if ( it.current()->isWireless() ) | 66 | if ( it.current()->isWireless() ) |
66 | interfaceName->insertItem( it.current()->name() ); | 67 | interfaceName->insertItem( it.current()->name() ); |
67 | ++it; | 68 | ++it; |
68 | } | 69 | } |
69 | 70 | ||
70 | load(); | 71 | load(); |
71 | 72 | ||
72 | #ifdef Q_WS_X11 // We're on X11: adding an Ok-Button for the Dialog here | 73 | #ifdef Q_WS_X11 // We're on X11: adding an Ok-Button for the Dialog here |
73 | QPushButton* okButton = new QPushButton( "ok", this ); | 74 | QPushButton* okButton = new QPushButton( "ok", this ); |
74 | okButton->show(); | 75 | okButton->show(); |
75 | WellenreiterConfigBaseLayout->addWidget( okButton, 0, 3 ); //FIXME: rename this in configbase.ui | 76 | WellenreiterConfigBaseLayout->addWidget( okButton, 0, 3 ); //FIXME: rename this in configbase.ui |
76 | connect( okButton, SIGNAL( clicked() ), this, SLOT( accept() ) ); | 77 | connect( okButton, SIGNAL( clicked() ), this, SLOT( accept() ) ); |
77 | #endif | 78 | #endif |
78 | 79 | ||
79 | WellenreiterConfigWindow::_instance = this; | 80 | WellenreiterConfigWindow::_instance = this; |
80 | 81 | ||
81 | connect( deviceType, SIGNAL( activated(int) ), this, SLOT( changedDeviceType(int) ) ); | 82 | connect( deviceType, SIGNAL( activated(int) ), this, SLOT( changedDeviceType(int) ) ); |
82 | connect( newNetworkAction, SIGNAL( activated(int) ), this, SLOT( changedNetworkAction(int) ) ); | 83 | connect( newNetworkAction, SIGNAL( activated(int) ), this, SLOT( changedNetworkAction(int) ) ); |
83 | connect( newClientAction, SIGNAL( activated(int) ), this, SLOT( changedClientAction(int) ) ); | 84 | connect( newClientAction, SIGNAL( activated(int) ), this, SLOT( changedClientAction(int) ) ); |
84 | connect( newStationAction, SIGNAL( activated(int) ), this, SLOT( changedStationAction(int) ) ); | 85 | connect( newStationAction, SIGNAL( activated(int) ), this, SLOT( changedStationAction(int) ) ); |
85 | connect( getCaptureFileName, SIGNAL( clicked() ), this, SLOT( getCaptureFileNameClicked() ) ); | 86 | connect( getCaptureFileName, SIGNAL( clicked() ), this, SLOT( getCaptureFileNameClicked() ) ); |
86 | 87 | ||
87 | // make the checkbox 'channelAll' control all other channels | 88 | // make the checkbox 'channelAll' control all other channels |
88 | connect( channelAll, SIGNAL( stateChanged(int) ), this, SLOT( channelAllClicked(int) ) ); | 89 | connect( channelAll, SIGNAL( stateChanged(int) ), this, SLOT( channelAllClicked(int) ) ); |
89 | 90 | ||
90 | connect( autodetect, SIGNAL( clicked() ), this, SLOT( performAutodetection() ) ); | 91 | connect( autodetect, SIGNAL( clicked() ), this, SLOT( performAutodetection() ) ); |
91 | 92 | ||
92 | // hide tab4 (parse) until Wellenreiter 1.2 | 93 | // hide tab4 (parse) until Wellenreiter 1.2 |
93 | tab->removePage( tab_4 ); | 94 | tab->removePage( tab_4 ); |
94 | }; | 95 | }; |
95 | 96 | ||
96 | 97 | ||
97 | void WellenreiterConfigWindow::accept() | 98 | void WellenreiterConfigWindow::accept() |
98 | { | 99 | { |
99 | save(); | 100 | save(); |
100 | QDialog::accept(); | 101 | QDialog::accept(); |
101 | } | 102 | } |
102 | 103 | ||
103 | 104 | ||
104 | WellenreiterConfigWindow::~WellenreiterConfigWindow() | 105 | WellenreiterConfigWindow::~WellenreiterConfigWindow() |
105 | { | 106 | { |
106 | } | 107 | } |
107 | 108 | ||
108 | 109 | ||
109 | void WellenreiterConfigWindow::performAutodetection() | 110 | void WellenreiterConfigWindow::performAutodetection() |
110 | { | 111 | { |
111 | //TODO: insert modal splash screen here | 112 | //TODO: insert modal splash screen here |
112 | // and sleep a second, so that it looks | 113 | // and sleep a second, so that it looks |
113 | // like we're actually doing something fancy... ;-) | 114 | // like we're actually doing something fancy... ;-) |
114 | 115 | ||
115 | odebug << "WellenreiterConfigWindow::performAutodetection()" << oendl; | 116 | odebug << "WellenreiterConfigWindow::performAutodetection()" << oendl; |
116 | 117 | ||
117 | // try to guess device type | 118 | // try to guess device type |
118 | QFile m( "/proc/modules" ); | 119 | QFile m( "/proc/modules" ); |
119 | if ( m.open( IO_ReadOnly ) ) | 120 | if ( m.open( IO_ReadOnly ) ) |
120 | { | 121 | { |
121 | int devicetype(0); | 122 | int devicetype(0); |
122 | QString line; | 123 | QString line; |
123 | QTextStream modules( &m ); | 124 | QTextStream modules( &m ); |
124 | while( !modules.atEnd() && !devicetype ) | 125 | while( !modules.atEnd() && !devicetype ) |
125 | { | 126 | { |
126 | modules >> line; | 127 | modules >> line; |
127 | if ( line.contains( "cisco" ) ) devicetype = DEVTYPE_CISCO; | 128 | if ( line.contains( "cisco" ) ) devicetype = DEVTYPE_CISCO; |
128 | else if ( line.contains( "hostap" ) ) devicetype = DEVTYPE_HOSTAP; | 129 | else if ( line.contains( "hostap" ) ) devicetype = DEVTYPE_HOSTAP; |
129 | else if ( line.contains( "prism" ) ) devicetype = DEVTYPE_WLAN_NG; | 130 | else if ( line.contains( "prism" ) ) devicetype = DEVTYPE_WLAN_NG; |
130 | else if ( line.contains( "orinoco" ) ) devicetype = DEVTYPE_ORINOCO; | 131 | else if ( line.contains( "orinoco" ) ) devicetype = DEVTYPE_ORINOCO; |
131 | } | 132 | } |
132 | if ( devicetype ) | 133 | if ( devicetype ) |
133 | { | 134 | { |
134 | deviceType->setCurrentItem( devicetype ); | 135 | deviceType->setCurrentItem( devicetype ); |
135 | _guess = devicetype; | 136 | _guess = devicetype; |
136 | odebug << "Wellenreiter: guessed device type to be #" << devicetype << "" << oendl; | 137 | odebug << "Wellenreiter: guessed device type to be #" << devicetype << "" << oendl; |
137 | } | 138 | } |
138 | } | 139 | } |
139 | } | 140 | } |
140 | 141 | ||
141 | 142 | ||
142 | int WellenreiterConfigWindow::driverType() const | 143 | int WellenreiterConfigWindow::driverType() const |
143 | { | 144 | { |
144 | QString name = deviceType->currentText(); | 145 | QString name = deviceType->currentText(); |
145 | if ( _devicetype.contains( name ) ) | 146 | if ( _devicetype.contains( name ) ) |
146 | { | 147 | { |
147 | return _devicetype[name]; | 148 | return _devicetype[name]; |
148 | } | 149 | } |
149 | else | 150 | else |
150 | { | 151 | { |
151 | return 0; | 152 | return 0; |
152 | } | 153 | } |
153 | }; | 154 | }; |
154 | 155 | ||
155 | 156 | ||
156 | int WellenreiterConfigWindow::hoppingInterval() const | 157 | int WellenreiterConfigWindow::hoppingInterval() const |
157 | { | 158 | { |
158 | return hopInterval->cleanText().toInt(); | 159 | return hopInterval->cleanText().toInt(); |
159 | } | 160 | } |
160 | 161 | ||
161 | 162 | ||
162 | bool WellenreiterConfigWindow::usePrismHeader() const | 163 | bool WellenreiterConfigWindow::usePrismHeader() const |
163 | { | 164 | { |
164 | return prismHeader->isChecked(); | 165 | return prismHeader->isChecked(); |
165 | } | 166 | } |
166 | 167 | ||
167 | 168 | ||
168 | bool WellenreiterConfigWindow::isChannelChecked( int channel ) const | 169 | bool WellenreiterConfigWindow::isChannelChecked( int channel ) const |
169 | { | 170 | { |
170 | switch ( channel ) | 171 | switch ( channel ) |
171 | { | 172 | { |
172 | case 1: return channel1->isOn(); | 173 | case 1: return channel1->isOn(); |
173 | case 2: return channel2->isOn(); | 174 | case 2: return channel2->isOn(); |
174 | case 3: return channel3->isOn(); | 175 | case 3: return channel3->isOn(); |
175 | case 4: return channel4->isOn(); | 176 | case 4: return channel4->isOn(); |
176 | case 5: return channel5->isOn(); | 177 | case 5: return channel5->isOn(); |
177 | case 6: return channel6->isOn(); | 178 | case 6: return channel6->isOn(); |
178 | case 7: return channel7->isOn(); | 179 | case 7: return channel7->isOn(); |
179 | case 8: return channel8->isOn(); | 180 | case 8: return channel8->isOn(); |
180 | case 9: return channel9->isOn(); | 181 | case 9: return channel9->isOn(); |
181 | case 10: return channel10->isOn(); | 182 | case 10: return channel10->isOn(); |
182 | case 11: return channel11->isOn(); | 183 | case 11: return channel11->isOn(); |
183 | case 12: return channel12->isOn(); | 184 | case 12: return channel12->isOn(); |
184 | case 13: return channel13->isOn(); | 185 | case 13: return channel13->isOn(); |
185 | case 14: return channel14->isOn(); | 186 | case 14: return channel14->isOn(); |
186 | } | 187 | } |
187 | } | 188 | } |
188 | 189 | ||
189 | 190 | ||
190 | void WellenreiterConfigWindow::changedDeviceType(int t) | 191 | void WellenreiterConfigWindow::changedDeviceType(int t) |
191 | { | 192 | { |
192 | if ( t != DEVTYPE_FILE ) return; | 193 | if ( t != DEVTYPE_FILE ) return; |
193 | QString name = ( (WellenreiterMainWindow*) qApp->mainWidget() )->getFileName(false); | 194 | QString name = ( (WellenreiterMainWindow*) qApp->mainWidget() )->getFileName(false); |
194 | if ( !name.isEmpty() && QFile::exists( name ) ) | 195 | if ( !name.isEmpty() && QFile::exists( name ) ) |
195 | { | 196 | { |
196 | interfaceName->insertItem( name ); | 197 | interfaceName->insertItem( name ); |
197 | interfaceName->setCurrentItem( interfaceName->count()-1 ); | 198 | interfaceName->setCurrentItem( interfaceName->count()-1 ); |
198 | } | 199 | } |
199 | else | 200 | else |
200 | { | 201 | { |
201 | deviceType->setCurrentItem( _guess ); | 202 | deviceType->setCurrentItem( _guess ); |
202 | } | 203 | } |
203 | 204 | ||
204 | } | 205 | } |
205 | 206 | ||
206 | 207 | ||
207 | void WellenreiterConfigWindow::synchronizeActionsAndScripts() | 208 | void WellenreiterConfigWindow::synchronizeActionsAndScripts() |
208 | { | 209 | { |
209 | if ( newNetworkAction->currentItem() == 4 ) newNetworkScript->show(); else newNetworkScript->hide(); | 210 | if ( newNetworkAction->currentItem() == 4 ) newNetworkScript->show(); else newNetworkScript->hide(); |
210 | if ( newClientAction->currentItem() == 4 ) newClientScript->show(); else newClientScript->hide(); | 211 | if ( newClientAction->currentItem() == 4 ) newClientScript->show(); else newClientScript->hide(); |
211 | if ( newStationAction->currentItem() == 4 ) newStationScript->show(); else newStationScript->hide(); | 212 | if ( newStationAction->currentItem() == 4 ) newStationScript->show(); else newStationScript->hide(); |
212 | 213 | ||
213 | //newNetworkScript->setEnabled( newNetworkAction->currentItem() == 4 ); | 214 | //newNetworkScript->setEnabled( newNetworkAction->currentItem() == 4 ); |
214 | //newClientScript->setEnabled( newClientAction->currentItem() == 4 ); | 215 | //newClientScript->setEnabled( newClientAction->currentItem() == 4 ); |
215 | //newStationScript->setEnabled( newStationAction->currentItem() == 4 ); | 216 | //newStationScript->setEnabled( newStationAction->currentItem() == 4 ); |
216 | } | 217 | } |
217 | 218 | ||
218 | 219 | ||
219 | void WellenreiterConfigWindow::changedNetworkAction(int t) | 220 | void WellenreiterConfigWindow::changedNetworkAction(int t) |
220 | { | 221 | { |
221 | synchronizeActionsAndScripts(); | 222 | synchronizeActionsAndScripts(); |
222 | } | 223 | } |
223 | 224 | ||
224 | 225 | ||
225 | void WellenreiterConfigWindow::changedClientAction(int t) | 226 | void WellenreiterConfigWindow::changedClientAction(int t) |
226 | { | 227 | { |
227 | synchronizeActionsAndScripts(); | 228 | synchronizeActionsAndScripts(); |
228 | } | 229 | } |
229 | 230 | ||
230 | 231 | ||
231 | void WellenreiterConfigWindow::changedStationAction(int t) | 232 | void WellenreiterConfigWindow::changedStationAction(int t) |
232 | { | 233 | { |
233 | synchronizeActionsAndScripts(); | 234 | synchronizeActionsAndScripts(); |
234 | } | 235 | } |
235 | 236 | ||
236 | 237 | ||
237 | void WellenreiterConfigWindow::getCaptureFileNameClicked() | 238 | void WellenreiterConfigWindow::getCaptureFileNameClicked() |
238 | { | 239 | { |
239 | QString name = ( (WellenreiterMainWindow*) qApp->mainWidget() )->getFileName(true); | 240 | QString name = ( (WellenreiterMainWindow*) qApp->mainWidget() )->getFileName(true); |
240 | odebug << "name = " << name << "" << oendl; | 241 | odebug << "name = " << name << "" << oendl; |
241 | if ( !name.isEmpty() ) | 242 | if ( !name.isEmpty() ) |
242 | { | 243 | { |
243 | captureFileName->setText( name ); | 244 | captureFileName->setText( name ); |
244 | } | 245 | } |
245 | } | 246 | } |
246 | 247 | ||
247 | 248 | ||
248 | void WellenreiterConfigWindow::channelAllClicked(int state) | 249 | void WellenreiterConfigWindow::channelAllClicked(int state) |
249 | { | 250 | { |
250 | bool b = state; | 251 | bool b = state; |
251 | channel1->setChecked( b ); | 252 | channel1->setChecked( b ); |
252 | channel2->setChecked( b ); | 253 | channel2->setChecked( b ); |
253 | channel3->setChecked( b ); | 254 | channel3->setChecked( b ); |
254 | channel4->setChecked( b ); | 255 | channel4->setChecked( b ); |
255 | channel5->setChecked( b ); | 256 | channel5->setChecked( b ); |
256 | channel6->setChecked( b ); | 257 | channel6->setChecked( b ); |
257 | channel7->setChecked( b ); | 258 | channel7->setChecked( b ); |
258 | channel8->setChecked( b ); | 259 | channel8->setChecked( b ); |
259 | channel9->setChecked( b ); | 260 | channel9->setChecked( b ); |
260 | channel10->setChecked( b ); | 261 | channel10->setChecked( b ); |
261 | channel11->setChecked( b ); | 262 | channel11->setChecked( b ); |
262 | channel12->setChecked( b ); | 263 | channel12->setChecked( b ); |
263 | channel13->setChecked( b ); | 264 | channel13->setChecked( b ); |
264 | channel14->setChecked( b ); | 265 | channel14->setChecked( b ); |
265 | } | 266 | } |
266 | 267 | ||
267 | 268 | ||
268 | bool WellenreiterConfigWindow::useGPS() const | 269 | bool WellenreiterConfigWindow::useGPS() const |
269 | { | 270 | { |
270 | return enableGPS->isChecked(); | 271 | return enableGPS->isChecked(); |
271 | } | 272 | } |
272 | 273 | ||
273 | 274 | ||
274 | const QString WellenreiterConfigWindow::gpsHost() const | 275 | const QString WellenreiterConfigWindow::gpsHost() const |
275 | { | 276 | { |
276 | return useGPS() ? gpsdHost->currentText() : QString::null; | 277 | return useGPS() ? gpsdHost->currentText() : QString::null; |
277 | } | 278 | } |
278 | 279 | ||
279 | 280 | ||
280 | int WellenreiterConfigWindow::gpsPort() const | 281 | int WellenreiterConfigWindow::gpsPort() const |
281 | { | 282 | { |
282 | bool ok; | 283 | bool ok; |
283 | return useGPS() ? gpsdPort->value() : -1; | 284 | return useGPS() ? gpsdPort->value() : -1; |
284 | } | 285 | } |
285 | 286 | ||
286 | 287 | ||
287 | void WellenreiterConfigWindow::performAction( const QString& type, | 288 | void WellenreiterConfigWindow::performAction( const QString& type, |
288 | const QString& essid, | 289 | const QString& essid, |
289 | const QString& mac, | 290 | const QString& mac, |
290 | bool wep, | 291 | bool wep, |
291 | int channel, | 292 | int channel, |
292 | int signal | 293 | int signal |
293 | /* , const GpsLocation& loc */ ) | 294 | /* , const GpsLocation& loc */ ) |
294 | { | 295 | { |
295 | int action; | 296 | int action; |
296 | QString script; | 297 | QString script; |
297 | 298 | ||
298 | if ( type == "network" ) | 299 | if ( type == "network" ) |
299 | { | 300 | { |
300 | action = newNetworkAction->currentItem(); | 301 | action = newNetworkAction->currentItem(); |
301 | script = newNetworkScript->text(); | 302 | script = newNetworkScript->text(); |
302 | } | 303 | } |
303 | else if ( type == "managed" || type == "adhoc" ) | 304 | else if ( type == "managed" || type == "adhoc" ) |
304 | { | 305 | { |
305 | action = newClientAction->currentItem(); | 306 | action = newClientAction->currentItem(); |
306 | script = newClientScript->text(); | 307 | script = newClientScript->text(); |
307 | } | 308 | } |
308 | else if ( type == "station" ) | 309 | else if ( type == "station" ) |
309 | { | 310 | { |
310 | action = newStationAction->currentItem(); | 311 | action = newStationAction->currentItem(); |
311 | script = newStationScript->text(); | 312 | script = newStationScript->text(); |
312 | } | 313 | } |
313 | else | 314 | else |
314 | { | 315 | { |
315 | owarn << "WellenreiterConfigWindow::performAction(): unknown type '" << type << "'" << oendl; | 316 | owarn << "WellenreiterConfigWindow::performAction(): unknown type '" << type << "'" << oendl; |
316 | return; | 317 | return; |
317 | } | 318 | } |
318 | 319 | ||
319 | odebug << "for event '" << (const char*) type << "' I'm going to perform action " << action << " (script='" << script << "')" << oendl; | 320 | odebug << "for event '" << (const char*) type << "' I'm going to perform action " << action << " (script='" << script << "')" << oendl; |
320 | 321 | ||
321 | switch( action ) | 322 | switch( action ) |
322 | { | 323 | { |
323 | case 0: /* Ignore */ return; | 324 | case 0: /* Ignore */ return; |
324 | case 1: /* Play Alarm */ ODevice::inst()->playAlarmSound(); return; | 325 | case 1: /* Play Alarm */ ODevice::inst()->playAlarmSound(); return; |
325 | case 2: /* Play Click */ ODevice::inst()->playTouchSound(); return; | 326 | case 2: /* Play Click */ ODevice::inst()->playTouchSound(); return; |
326 | case 3: /* Blink LED */ break; //FIXME: Implement this | 327 | case 3: /* Blink LED */ break; //FIXME: Implement this |
327 | case 4: /* Run Script */ | 328 | case 4: /* Run Script */ |
328 | { | 329 | { |
329 | /** | 330 | /** |
330 | * | 331 | * |
331 | * Script Substitution Information: | 332 | * Script Substitution Information: |
332 | * | 333 | * |
333 | * $SSID = SSID | 334 | * $SSID = SSID |
334 | * $MAC = MAC | 335 | * $MAC = MAC |
335 | * $WEP = Wep | 336 | * $WEP = Wep |
336 | * $CHAN = Channel | 337 | * $CHAN = Channel |
337 | * | 338 | * |
338 | **/ | 339 | **/ |
339 | script = script.replace( QRegExp( "$SSID" ), essid ); | 340 | script = script.replace( QRegExp( "$SSID" ), essid ); |
340 | script = script.replace( QRegExp( "$MAC" ), mac ); | 341 | script = script.replace( QRegExp( "$MAC" ), mac ); |
341 | script = script.replace( QRegExp( "$WEP" ), wep ? QString( "true" ) : QString( "false" ) ); | 342 | script = script.replace( QRegExp( "$WEP" ), wep ? QString( "true" ) : QString( "false" ) ); |
342 | script = script.replace( QRegExp( "$CHAN" ), QString::number( channel ) ); | 343 | script = script.replace( QRegExp( "$CHAN" ), QString::number( channel ) ); |
343 | 344 | ||
344 | odebug << "going to call script '" << script << "'" << oendl; | 345 | odebug << "going to call script '" << script << "'" << oendl; |
345 | ::system( script ); | 346 | ::system( script ); |
346 | odebug << "script returned." << oendl; | 347 | odebug << "script returned." << oendl; |
347 | return; | 348 | return; |
348 | } | 349 | } |
349 | default: assert( false ); | 350 | default: assert( false ); |
350 | } | 351 | } |
351 | } | 352 | } |
352 | 353 | ||
353 | 354 | ||
354 | void WellenreiterConfigWindow::load() | 355 | void WellenreiterConfigWindow::load() |
355 | { | 356 | { |
356 | #ifdef Q_WS_X11 | 357 | #ifdef Q_WS_X11 |
357 | #warning Persistent Configuration not yet implemented for standalone X11 build | 358 | #warning Persistent Configuration not yet implemented for standalone X11 build |
358 | performAutodetection(); | 359 | performAutodetection(); |
359 | #else | 360 | #else |
360 | odebug << "loading configuration settings..." << oendl; | 361 | odebug << "loading configuration settings..." << oendl; |
361 | 362 | ||
362 | /* This is dumb monkey typing stuff... We _need_ to do this automatically! */ | 363 | /* This is dumb monkey typing stuff... We _need_ to do this automatically! */ |
363 | 364 | ||
364 | OConfig* c = oApp->config(); | 365 | OConfig* c = oApp->config(); |
365 | 366 | ||
366 | c->setGroup( "Interface" ); | 367 | c->setGroup( "Interface" ); |
367 | 368 | ||
368 | QString interface = c->readEntry( "name", "<none>" ); | 369 | QString interface = c->readEntry( "name", "<none>" ); |
369 | if ( interface != "<none>" ) | 370 | if ( interface != "<none>" ) |
370 | { | 371 | { |
371 | #if QT_VERSION < 300 | 372 | #if QT_VERSION < 300 |
372 | interfaceName->insertItem( interface, 0 ); | 373 | interfaceName->insertItem( interface, 0 ); |
373 | interfaceName->setCurrentItem( 0 ); | 374 | interfaceName->setCurrentItem( 0 ); |
374 | #else | 375 | #else |
375 | interfaceName->setCurrentText( interface ); | 376 | interfaceName->setCurrentText( interface ); |
376 | #endif | 377 | #endif |
377 | 378 | ||
378 | QString device = c->readEntry( "type", "<select>" ); | 379 | QString device = c->readEntry( "type", "<select>" ); |
379 | #if QT_VERSION < 300 | 380 | #if QT_VERSION < 300 |
380 | for ( int i = 0; i < deviceType->count(); ++i ) | 381 | for ( int i = 0; i < deviceType->count(); ++i ) |
381 | { | 382 | { |
382 | if ( deviceType->text( i ) == device ) | 383 | if ( deviceType->text( i ) == device ) |
383 | { | 384 | { |
384 | deviceType->setCurrentItem( i ); | 385 | deviceType->setCurrentItem( i ); |
385 | break; | 386 | break; |
386 | } | 387 | } |
387 | } | 388 | } |
388 | #else | 389 | #else |
389 | deviceType->setCurrentText( device ); | 390 | deviceType->setCurrentText( device ); |
390 | #endif | 391 | #endif |
391 | } | 392 | } |
392 | else | 393 | else |
393 | { | 394 | { |
394 | performAutodetection(); | 395 | performAutodetection(); |
395 | } | 396 | } |
396 | 397 | ||
397 | prismHeader->setChecked( c->readBoolEntry( "prism", false ) ); | 398 | prismHeader->setChecked( c->readBoolEntry( "prism", false ) ); |
398 | hopChannels->setChecked( c->readBoolEntry( "hop", true ) ); | 399 | hopChannels->setChecked( c->readBoolEntry( "hop", true ) ); |
399 | hopInterval->setValue( c->readNumEntry( "interval", 250 ) ); | 400 | hopInterval->setValue( c->readNumEntry( "interval", 250 ) ); |
400 | adaptiveHopping->setChecked( c->readBoolEntry( "adaptive", true ) ); | 401 | adaptiveHopping->setChecked( c->readBoolEntry( "adaptive", true ) ); |
401 | 402 | ||
402 | c->setGroup( "Capture" ); | 403 | c->setGroup( "Capture" ); |
403 | captureFileName->setText( c->readEntry( "filename", "/tmp/capture" ) ); | 404 | captureFileName->setText( c->readEntry( "filename", "/tmp/capture" ) ); |
404 | 405 | ||
405 | c->setGroup( "UI" ); | 406 | c->setGroup( "UI" ); |
406 | lookupVendor->setChecked( c->readBoolEntry( "lookupVendor", true ) ); | 407 | lookupVendor->setChecked( c->readBoolEntry( "lookupVendor", true ) ); |
407 | openTree->setChecked( c->readBoolEntry( "openTree", true ) ); | 408 | openTree->setChecked( c->readBoolEntry( "openTree", true ) ); |
408 | disablePM->setChecked( c->readBoolEntry( "disablePM", true ) ); | 409 | disablePM->setChecked( c->readBoolEntry( "disablePM", true ) ); |
409 | newNetworkAction->setCurrentItem( c->readNumEntry( "newNetworkAction", 1 ) ); // Default: Play Alarm | 410 | newNetworkAction->setCurrentItem( c->readNumEntry( "newNetworkAction", 1 ) ); // Default: Play Alarm |
410 | newNetworkScript->setText( c->readEntry( "newNetworkScript", "" ) ); | 411 | newNetworkScript->setText( c->readEntry( "newNetworkScript", "" ) ); |
411 | newClientAction->setCurrentItem( c->readNumEntry( "newClientAction", 2 ) ); // Default: Play Click | 412 | newClientAction->setCurrentItem( c->readNumEntry( "newClientAction", 2 ) ); // Default: Play Click |
412 | newClientScript->setText( c->readEntry( "newClientScript", "" ) ); | 413 | newClientScript->setText( c->readEntry( "newClientScript", "" ) ); |
413 | newStationAction->setCurrentItem( c->readNumEntry( "newStationAction", 2 ) ); // Default: Play Click | 414 | newStationAction->setCurrentItem( c->readNumEntry( "newStationAction", 2 ) ); // Default: Play Click |
414 | newStationScript->setText( c->readEntry( "newStationScript", "" ) ); | 415 | newStationScript->setText( c->readEntry( "newStationScript", "" ) ); |
415 | synchronizeActionsAndScripts(); // needed for showing/hiding the script QLineEdit on demand | 416 | synchronizeActionsAndScripts(); // needed for showing/hiding the script QLineEdit on demand |
416 | 417 | ||
417 | c->setGroup( "GPS" ); | 418 | c->setGroup( "GPS" ); |
418 | enableGPS->setChecked( c->readBoolEntry( "use", false ) ); | 419 | enableGPS->setChecked( c->readBoolEntry( "use", false ) ); |
419 | #if QT_VERSION < 300 | 420 | #if QT_VERSION < 300 |
420 | gpsdHost->insertItem( c->readEntry( "host", "localhost" ), 0 ); | 421 | gpsdHost->insertItem( c->readEntry( "host", "localhost" ), 0 ); |
421 | gpsdHost->setCurrentItem( 0 ); | 422 | gpsdHost->setCurrentItem( 0 ); |
422 | #else | 423 | #else |
423 | gpsdHost->setCurrentText( c->readEntry( "host", "localhost" ) ); | 424 | gpsdHost->setCurrentText( c->readEntry( "host", "localhost" ) ); |
424 | #endif | 425 | #endif |
425 | gpsdPort->setValue( c->readNumEntry( "port", 2947 ) ); | 426 | gpsdPort->setValue( c->readNumEntry( "port", 2947 ) ); |
426 | startGPS->setChecked( c->readBoolEntry( "start", false ) ); | 427 | startGPS->setChecked( c->readBoolEntry( "start", false ) ); |
427 | commandGPS->setText( c->readEntry( "command", "gpsd -p /dev/ttyS3 -s 57600" ) ); | 428 | commandGPS->setText( c->readEntry( "command", "gpsd -p /dev/ttyS3 -s 57600" ) ); |
428 | 429 | ||
429 | #endif | 430 | #endif |
430 | } | 431 | } |
431 | 432 | ||
432 | 433 | ||
433 | void WellenreiterConfigWindow::save() | 434 | void WellenreiterConfigWindow::save() |
434 | { | 435 | { |
435 | #ifdef Q_WS_X11 | 436 | #ifdef Q_WS_X11 |
436 | #warning Persistent Configuration not yet implemented for standalone X11 build | 437 | #warning Persistent Configuration not yet implemented for standalone X11 build |
437 | #else | 438 | #else |
438 | odebug << "saving configuration settings..." << oendl; | 439 | odebug << "saving configuration settings..." << oendl; |
439 | 440 | ||
440 | /* This is dumb monkey typing stuff... We _need_ to do this automatically! */ | 441 | /* This is dumb monkey typing stuff... We _need_ to do this automatically! */ |
441 | 442 | ||
442 | OConfig* c = oApp->config(); | 443 | OConfig* c = oApp->config(); |
443 | 444 | ||
444 | c->setGroup( "Interface" ); | 445 | c->setGroup( "Interface" ); |
445 | c->writeEntry( "name", interfaceName->currentText() ); | 446 | c->writeEntry( "name", interfaceName->currentText() ); |
446 | c->writeEntry( "type", deviceType->currentText() ); | 447 | c->writeEntry( "type", deviceType->currentText() ); |
447 | c->writeEntry( "prism", prismHeader->isChecked() ); | 448 | c->writeEntry( "prism", prismHeader->isChecked() ); |
448 | c->writeEntry( "hop", hopChannels->isChecked() ); | 449 | c->writeEntry( "hop", hopChannels->isChecked() ); |
449 | c->writeEntry( "interval", hopInterval->value() ); | 450 | c->writeEntry( "interval", hopInterval->value() ); |
450 | c->writeEntry( "adaptive", adaptiveHopping->isChecked() ); | 451 | c->writeEntry( "adaptive", adaptiveHopping->isChecked() ); |
451 | 452 | ||
452 | c->setGroup( "Capture" ); | 453 | c->setGroup( "Capture" ); |
453 | c->writeEntry( "filename", captureFileName->text() ); | 454 | c->writeEntry( "filename", captureFileName->text() ); |
454 | 455 | ||
455 | c->setGroup( "UI" ); | 456 | c->setGroup( "UI" ); |
456 | c->writeEntry( "lookupVendor", lookupVendor->isChecked() ); | 457 | c->writeEntry( "lookupVendor", lookupVendor->isChecked() ); |
457 | c->writeEntry( "openTree", openTree->isChecked() ); | 458 | c->writeEntry( "openTree", openTree->isChecked() ); |
458 | c->writeEntry( "disablePM", disablePM->isChecked() ); | 459 | c->writeEntry( "disablePM", disablePM->isChecked() ); |
459 | c->writeEntry( "newNetworkAction", newNetworkAction->currentItem() ); | 460 | c->writeEntry( "newNetworkAction", newNetworkAction->currentItem() ); |
460 | c->writeEntry( "newNetworkScript", newNetworkScript->text() ); | 461 | c->writeEntry( "newNetworkScript", newNetworkScript->text() ); |
461 | c->writeEntry( "newClientAction", newClientAction->currentItem() ); | 462 | c->writeEntry( "newClientAction", newClientAction->currentItem() ); |
462 | c->writeEntry( "newClientScript", newClientScript->text() ); | 463 | c->writeEntry( "newClientScript", newClientScript->text() ); |
463 | c->writeEntry( "newStationAction", newStationAction->currentItem() ); | 464 | c->writeEntry( "newStationAction", newStationAction->currentItem() ); |
464 | c->writeEntry( "newStationScript", newStationScript->text() ); | 465 | c->writeEntry( "newStationScript", newStationScript->text() ); |
465 | 466 | ||
466 | c->setGroup( "GPS" ); | 467 | c->setGroup( "GPS" ); |
467 | c->writeEntry( "use", enableGPS->isChecked() ); | 468 | c->writeEntry( "use", enableGPS->isChecked() ); |
468 | c->writeEntry( "host", gpsdHost->currentText() ); | 469 | c->writeEntry( "host", gpsdHost->currentText() ); |
469 | c->writeEntry( "port", gpsdPort->value() ); | 470 | c->writeEntry( "port", gpsdPort->value() ); |
470 | c->writeEntry( "start", startGPS->isChecked() ); | 471 | c->writeEntry( "start", startGPS->isChecked() ); |
471 | c->writeEntry( "command", commandGPS->text() ); | 472 | c->writeEntry( "command", commandGPS->text() ); |
472 | 473 | ||
473 | c->write(); | 474 | c->write(); |
474 | 475 | ||
475 | #endif | 476 | #endif |
476 | } | 477 | } |
478 | |||
479 | |||
480 | int WellenreiterConfigWindow::hexViewBuffer() const | ||
481 | { | ||
482 | return hexViewBufferUnlimited->isChecked() ? -1 : hexViewBufferSize->value(); | ||
483 | } | ||
diff --git a/noncore/net/wellenreiter/gui/configwindow.h b/noncore/net/wellenreiter/gui/configwindow.h index 0a5b3bd..2d478e7 100644 --- a/noncore/net/wellenreiter/gui/configwindow.h +++ b/noncore/net/wellenreiter/gui/configwindow.h | |||
@@ -1,82 +1,84 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2002-2004 Michael 'Mickey' Lauer. All rights reserved. | 2 | ** Copyright (C) 2002-2004 Michael 'Mickey' Lauer. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Wellenreiter II. | 4 | ** This file is part of Wellenreiter II. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | **********************************************************************/ | 14 | **********************************************************************/ |
15 | 15 | ||
16 | #ifndef WELLENREITERCONFIGWINDOW_H | 16 | #ifndef WELLENREITERCONFIGWINDOW_H |
17 | #define WELLENREITERCONFIGWINDOW_H | 17 | #define WELLENREITERCONFIGWINDOW_H |
18 | 18 | ||
19 | #include "configbase.h" | 19 | #include "configbase.h" |
20 | #include "gps.h" | 20 | #include "gps.h" |
21 | 21 | ||
22 | /* QT */ | 22 | /* QT */ |
23 | #include <qmap.h> | 23 | #include <qmap.h> |
24 | #include <qcombobox.h> | 24 | #include <qcombobox.h> |
25 | #include <qstring.h> | 25 | #include <qstring.h> |
26 | 26 | ||
27 | const int DEVTYPE_SELECT = 0; | 27 | const int DEVTYPE_SELECT = 0; |
28 | const int DEVTYPE_CISCO = 1; | 28 | const int DEVTYPE_CISCO = 1; |
29 | const int DEVTYPE_WLAN_NG = 2; | 29 | const int DEVTYPE_WLAN_NG = 2; |
30 | const int DEVTYPE_HOSTAP = 3; | 30 | const int DEVTYPE_HOSTAP = 3; |
31 | const int DEVTYPE_ORINOCO = 4; | 31 | const int DEVTYPE_ORINOCO = 4; |
32 | const int DEVTYPE_MANUAL = 5; | 32 | const int DEVTYPE_MANUAL = 5; |
33 | const int DEVTYPE_FILE = 6; | 33 | const int DEVTYPE_FILE = 6; |
34 | 34 | ||
35 | class WellenreiterConfigWindow; | 35 | class WellenreiterConfigWindow; |
36 | 36 | ||
37 | class WellenreiterConfigWindow : public WellenreiterConfigBase | 37 | class WellenreiterConfigWindow : public WellenreiterConfigBase |
38 | { | 38 | { |
39 | Q_OBJECT | 39 | Q_OBJECT |
40 | 40 | ||
41 | public: | 41 | public: |
42 | WellenreiterConfigWindow( QWidget * parent = 0, const char * name = "WellenreiterConfigWindow", WFlags f = 0 ); | 42 | WellenreiterConfigWindow( QWidget * parent = 0, const char * name = "WellenreiterConfigWindow", WFlags f = 0 ); |
43 | ~WellenreiterConfigWindow(); | 43 | ~WellenreiterConfigWindow(); |
44 | 44 | ||
45 | int driverType() const; | 45 | int driverType() const; |
46 | const QString soundOnNetwork() const { return "";/*netSound->currentText();*/ }; | 46 | const QString soundOnNetwork() const { return "";/*netSound->currentText();*/ }; |
47 | const QString soundOnBeacon() const { return "";/*beaconSound->currentText();*/ }; | 47 | const QString soundOnBeacon() const { return "";/*beaconSound->currentText();*/ }; |
48 | static WellenreiterConfigWindow* instance() { return _instance; }; | 48 | static WellenreiterConfigWindow* instance() { return _instance; }; |
49 | 49 | ||
50 | int hoppingInterval() const; | 50 | int hoppingInterval() const; |
51 | bool usePrismHeader() const; | 51 | bool usePrismHeader() const; |
52 | bool isChannelChecked( int ) const; | 52 | bool isChannelChecked( int ) const; |
53 | 53 | ||
54 | bool useGPS() const; | 54 | bool useGPS() const; |
55 | const QString gpsHost() const; | 55 | const QString gpsHost() const; |
56 | int gpsPort() const; | 56 | int gpsPort() const; |
57 | 57 | ||
58 | void save(); | 58 | void save(); |
59 | void load(); | 59 | void load(); |
60 | 60 | ||
61 | int hexViewBuffer() const; | ||
62 | |||
61 | public slots: | 63 | public slots: |
62 | void changedDeviceType(int); | 64 | void changedDeviceType(int); |
63 | void changedNetworkAction(int t); | 65 | void changedNetworkAction(int t); |
64 | void changedClientAction(int t); | 66 | void changedClientAction(int t); |
65 | void changedStationAction(int t); | 67 | void changedStationAction(int t); |
66 | void getCaptureFileNameClicked(); | 68 | void getCaptureFileNameClicked(); |
67 | void performAutodetection(); | 69 | void performAutodetection(); |
68 | void channelAllClicked(int); | 70 | void channelAllClicked(int); |
69 | void performAction( const QString&, const QString&, const QString&, bool, int, int /* , const GpsLocation& */ ); | 71 | void performAction( const QString&, const QString&, const QString&, bool, int, int /* , const GpsLocation& */ ); |
70 | 72 | ||
71 | protected slots: | 73 | protected slots: |
72 | void synchronizeActionsAndScripts(); | 74 | void synchronizeActionsAndScripts(); |
73 | virtual void accept(); | 75 | virtual void accept(); |
74 | 76 | ||
75 | protected: | 77 | protected: |
76 | QMap<QString, int> _devicetype; | 78 | QMap<QString, int> _devicetype; |
77 | static WellenreiterConfigWindow* _instance; | 79 | static WellenreiterConfigWindow* _instance; |
78 | int _guess; | 80 | int _guess; |
79 | 81 | ||
80 | }; | 82 | }; |
81 | 83 | ||
82 | #endif | 84 | #endif |
diff --git a/noncore/net/wellenreiter/gui/packetview.cpp b/noncore/net/wellenreiter/gui/packetview.cpp index 4df01da..f0f16ff 100644 --- a/noncore/net/wellenreiter/gui/packetview.cpp +++ b/noncore/net/wellenreiter/gui/packetview.cpp | |||
@@ -1,121 +1,151 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2002-2004 Michael 'Mickey' Lauer. All rights reserved. | 2 | ** Copyright (C) 2002-2004 Michael 'Mickey' Lauer. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Wellenreiter II. | 4 | ** This file is part of Wellenreiter II. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | **********************************************************************/ | 14 | **********************************************************************/ |
15 | 15 | ||
16 | #include "packetview.h" | 16 | #include "packetview.h" |
17 | 17 | ||
18 | /* OPIE */ | 18 | /* OPIE */ |
19 | #include <opie2/opcap.h> | 19 | #include <opie2/opcap.h> |
20 | #include <opie2/odebug.h> | 20 | #include <opie2/odebug.h> |
21 | #include <opie2/olistview.h> | 21 | #include <opie2/olistview.h> |
22 | #include <opie2/oapplication.h> | ||
22 | 23 | ||
23 | /* QT */ | 24 | /* QT */ |
24 | #include <qfont.h> | 25 | #include <qfont.h> |
25 | #include <qlabel.h> | 26 | #include <qlabel.h> |
26 | #include <qlayout.h> | 27 | #include <qlayout.h> |
27 | #include <qlist.h> | 28 | #include <qlist.h> |
28 | #include <qlistview.h> | 29 | #include <qlistview.h> |
29 | #include <qobjectlist.h> | 30 | #include <qobjectlist.h> |
30 | #include <qspinbox.h> | 31 | #include <qspinbox.h> |
31 | #include <qtextview.h> | 32 | #include <qtextview.h> |
32 | 33 | ||
33 | using namespace Opie::Net; | 34 | using namespace Opie::Net; |
34 | using namespace Opie::Core; | 35 | using namespace Opie::Core; |
35 | using namespace Opie::Ui; | 36 | using namespace Opie::Ui; |
36 | 37 | ||
37 | PacketView::PacketView( QWidget * parent, const char * name, WFlags f ) | 38 | PacketView::PacketView( QWidget * parent, const char * name, WFlags f ) |
38 | :QFrame( parent, name, f ) | 39 | :QFrame( parent, name, f ) |
39 | { | 40 | { |
40 | _number = new QSpinBox( this ); | 41 | _number = new QSpinBox( this ); |
41 | _number->setPrefix( "Packet # " ); | 42 | _number->setPrefix( "Pkt# " ); |
42 | _label = new QLabel( this ); | 43 | _label = new QLabel( this ); |
43 | _label->setText( "eth0 2004/03/08 - 00:00:21" ); | ||
44 | |||
45 | _list = new OListView( this ); | 44 | _list = new OListView( this ); |
46 | _list->addColumn( "#" ); | 45 | _list->addColumn( "#" ); |
47 | _list->addColumn( "Packet Type" ); | 46 | _list->addColumn( "Packet Type" ); |
48 | _list->setColumnAlignment( 0, Qt::AlignCenter ); | 47 | _list->setColumnAlignment( 0, Qt::AlignCenter ); |
49 | _list->setColumnAlignment( 1, Qt::AlignLeft ); | 48 | _list->setColumnAlignment( 1, Qt::AlignLeft ); |
50 | _list->setAllColumnsShowFocus( true ); | 49 | _list->setAllColumnsShowFocus( true ); |
51 | _list->setFont( QFont( "Fixed", 8 ) ); | 50 | _list->setFont( QFont( "Fixed", 8 ) ); |
52 | 51 | ||
53 | _hex = new QTextView( this ); | 52 | _hex = new QTextView( this ); |
53 | _hex->setMargin( 0 ); | ||
54 | _hex->setFont( QFont( "Fixed", 8 ) ); | 54 | _hex->setFont( QFont( "Fixed", 8 ) ); |
55 | 55 | ||
56 | QVBoxLayout* vb = new QVBoxLayout( this, 2, 2 ); | 56 | QVBoxLayout* vb = new QVBoxLayout( this, 2, 2 ); |
57 | QHBoxLayout* hb = new QHBoxLayout( vb, 2 ); | 57 | QHBoxLayout* hb = new QHBoxLayout( vb, 2 ); |
58 | hb->addWidget( _label ); | 58 | hb->addWidget( _label, 5 ); |
59 | hb->addWidget( _number ); | 59 | hb->addWidget( _number, 2 ); |
60 | vb->addWidget( _list ); | 60 | vb->addWidget( _list, 3 ); |
61 | vb->addWidget( _hex ); | 61 | vb->addWidget( _hex, 4 ); // allow a bit (4/3) more space |
62 | 62 | ||
63 | _packets.setAutoDelete( true ); | 63 | _packets.setAutoDelete( true ); |
64 | 64 | ||
65 | connect( _number, SIGNAL( valueChanged( int ) ), this, SLOT( showPacket( int ) ) ); | 65 | connect( _number, SIGNAL( valueChanged( int ) ), this, SLOT( showPacket( int ) ) ); |
66 | connect( parent, SIGNAL( currentChanged( QWidget *) ), this, SLOT( activated( QWidget* ) ) ); | ||
67 | |||
68 | clear(); | ||
69 | |||
66 | } | 70 | } |
67 | 71 | ||
68 | void PacketView::add( const OPacket* p ) | 72 | void PacketView::add( const OPacket* p, int size ) |
69 | { | 73 | { |
70 | _packets.append( p ); | 74 | odebug << "PacketView::add() size = " << size << oendl; |
71 | // Add Circular Buffer and check for number of elements here | 75 | if ( size == -1 ) // unlimited buffer |
76 | { | ||
77 | _packets.append( p ); | ||
78 | } | ||
79 | else | ||
80 | // limited buffer, limit = size | ||
81 | if ( _packets.count() < size ) | ||
82 | { | ||
83 | _packets.append( p ); | ||
84 | } | ||
85 | |||
86 | _number->setMinValue( 1 ); | ||
87 | _number->setMaxValue( _packets.count() ); | ||
88 | _number->setValue( _packets.count() ); | ||
72 | } | 89 | } |
73 | 90 | ||
74 | void PacketView::showPacket( int number ) | 91 | void PacketView::showPacket( int number ) |
75 | { | 92 | { |
76 | _list->clear(); | 93 | _list->clear(); |
77 | _hex->setText(""); | 94 | _hex->setText(""); |
78 | const OPacket* p = _packets.at( number ); | 95 | const OPacket* p = _packets.at( number-1 ); |
79 | 96 | ||
80 | if ( p ) | 97 | if ( p ) |
81 | { | 98 | { |
82 | _doSubPackets( const_cast<QObjectList*>( p->children() ), 0 ); | 99 | _doSubPackets( const_cast<QObjectList*>( p->children() ), 0 ); |
83 | _doHexPacket( p ); | 100 | _doHexPacket( p ); |
101 | QDateTime dt; dt.setTime_t( p->timeval().tv_sec ); | ||
102 | _label->setText( dt.toString() + QString().sprintf( " Len=%d", p->len() ) ); | ||
84 | } | 103 | } |
85 | else | 104 | else |
86 | { | 105 | { |
87 | odebug << "D'oh! No packet!" << oendl; | 106 | odebug << "D'oh! No packet!" << oendl; |
107 | } | ||
108 | } | ||
109 | |||
110 | void PacketView::activated( QWidget* w ) | ||
111 | { | ||
112 | if ( ( this == w ) && _packets.count() ) | ||
113 | { | ||
114 | _number->setValue( 1 ); | ||
88 | } | 115 | } |
89 | } | 116 | } |
90 | 117 | ||
91 | void PacketView::_doSubPackets( QObjectList* l, int counter ) | 118 | void PacketView::_doSubPackets( QObjectList* l, int counter ) |
92 | { | 119 | { |
93 | if (!l) return; | 120 | if (!l) return; |
94 | QObject* o = l->first(); | 121 | QObject* o = l->first(); |
95 | while ( o ) | 122 | while ( o ) |
96 | { | 123 | { |
97 | new OListViewItem( _list, QString::number( counter++ ), o->name() ); | 124 | new OListViewItem( _list, QString::number( counter++ ), o->name() ); |
98 | _doSubPackets( const_cast<QObjectList*>( o->children() ), counter ); | 125 | _doSubPackets( const_cast<QObjectList*>( o->children() ), counter ); |
99 | o = l->next(); | 126 | o = l->next(); |
100 | } | 127 | } |
101 | } | 128 | } |
102 | 129 | ||
103 | void PacketView::_doHexPacket( const OPacket* p ) | 130 | void PacketView::_doHexPacket( const OPacket* p ) |
104 | { | 131 | { |
105 | _hex->setText( p->dump( 16 ) ); | 132 | if ( oApp->desktop()->width() > 320 ) |
133 | _hex->setText( p->dump( 16 ) ); | ||
134 | else | ||
135 | _hex->setText( p->dump( 8 ) ); | ||
106 | } | 136 | } |
107 | 137 | ||
108 | const QString PacketView::getLog() const | 138 | const QString PacketView::getLog() const |
109 | { | 139 | { |
110 | } | 140 | } |
111 | 141 | ||
112 | void PacketView::clear() | 142 | void PacketView::clear() |
113 | { | 143 | { |
114 | _packets.clear(); | 144 | _packets.clear(); |
115 | _number->setMinValue( 0 ); | 145 | _number->setMinValue( 0 ); |
116 | _number->setMaxValue( 0 ); | 146 | _number->setMaxValue( 0 ); |
117 | _label->setText( "---" ); | 147 | _label->setText( "---" ); |
118 | _list->clear(); | 148 | _list->clear(); |
119 | _hex->setText( " <i>-- no Packet available --</i> " ); | 149 | _hex->setText( " <center><i>-- no Packet available --</i></center> " ); |
120 | } | 150 | } |
121 | 151 | ||
diff --git a/noncore/net/wellenreiter/gui/packetview.h b/noncore/net/wellenreiter/gui/packetview.h index 42e8f5d..bb366c5 100644 --- a/noncore/net/wellenreiter/gui/packetview.h +++ b/noncore/net/wellenreiter/gui/packetview.h | |||
@@ -1,60 +1,62 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2002-2004 Michael 'Mickey' Lauer. All rights reserved. | 2 | ** Copyright (C) 2002-2004 Michael 'Mickey' Lauer. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Wellenreiter II. | 4 | ** This file is part of Wellenreiter II. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | **********************************************************************/ | 14 | **********************************************************************/ |
15 | 15 | ||
16 | #ifndef PACKETVIEW_H | 16 | #ifndef PACKETVIEW_H |
17 | #define PACKETVIEW_H | 17 | #define PACKETVIEW_H |
18 | 18 | ||
19 | #include <qlist.h> | 19 | #include <qlist.h> |
20 | #include <qframe.h> | 20 | #include <qframe.h> |
21 | 21 | ||
22 | #include <opie2/opcap.h> | 22 | #include <opie2/opcap.h> |
23 | 23 | ||
24 | class QWidget; | ||
24 | class QLabel; | 25 | class QLabel; |
25 | class QString; | 26 | class QString; |
26 | class QSpinBox; | 27 | class QSpinBox; |
27 | class QTextView; | 28 | class QTextView; |
28 | class QObjectList; | 29 | class QObjectList; |
29 | namespace Opie {namespace Net {class OPacket;}} | 30 | namespace Opie {namespace Net {class OPacket;}} |
30 | namespace Opie {namespace Ui {class OListView;}} | 31 | namespace Opie {namespace Ui {class OListView;}} |
31 | 32 | ||
32 | class PacketView: public QFrame | 33 | class PacketView: public QFrame |
33 | { | 34 | { |
34 | Q_OBJECT | 35 | Q_OBJECT |
35 | 36 | ||
36 | public: | 37 | public: |
37 | PacketView( QWidget * parent = 0, const char * name = "PacketView", WFlags f = 0 ); | 38 | PacketView( QWidget * parent = 0, const char * name = "PacketView", WFlags f = 0 ); |
38 | 39 | ||
39 | void add( const Opie::Net::OPacket* p ); | 40 | void add( const Opie::Net::OPacket* p, int size ); |
40 | const QString getLog() const; | 41 | const QString getLog() const; |
41 | void clear(); | 42 | void clear(); |
42 | 43 | ||
43 | public slots: | 44 | public slots: |
44 | void showPacket( int number ); | 45 | void showPacket( int number ); |
46 | void activated( QWidget* ); | ||
45 | 47 | ||
46 | protected: | 48 | protected: |
47 | QSpinBox* _number; | 49 | QSpinBox* _number; |
48 | QLabel* _label; | 50 | QLabel* _label; |
49 | Opie::Ui::OListView* _list; | 51 | Opie::Ui::OListView* _list; |
50 | QTextView* _hex; | 52 | QTextView* _hex; |
51 | QList<const Opie::Net::OPacket> _packets; | 53 | QList<const Opie::Net::OPacket> _packets; |
52 | 54 | ||
53 | protected: | 55 | protected: |
54 | void _doSubPackets( QObjectList*, int ); | 56 | void _doSubPackets( QObjectList*, int ); |
55 | void _doHexPacket( const Opie::Net::OPacket* ); | 57 | void _doHexPacket( const Opie::Net::OPacket* ); |
56 | 58 | ||
57 | }; | 59 | }; |
58 | 60 | ||
59 | #endif | 61 | #endif |
60 | 62 | ||
diff --git a/noncore/net/wellenreiter/gui/wellenreiter.cpp b/noncore/net/wellenreiter/gui/wellenreiter.cpp index 12b3978..fe8f22d 100644 --- a/noncore/net/wellenreiter/gui/wellenreiter.cpp +++ b/noncore/net/wellenreiter/gui/wellenreiter.cpp | |||
@@ -224,385 +224,385 @@ void Wellenreiter::handleManagementFrameProbeResponse( OPacket* p, OWaveLanManag | |||
224 | } | 224 | } |
225 | 225 | ||
226 | 226 | ||
227 | void Wellenreiter::handleManagementFrameBeacon( OPacket* p, OWaveLanManagementPacket* beacon ) | 227 | void Wellenreiter::handleManagementFrameBeacon( OPacket* p, OWaveLanManagementPacket* beacon ) |
228 | { | 228 | { |
229 | QString type; | 229 | QString type; |
230 | if ( beacon->canIBSS() ) | 230 | if ( beacon->canIBSS() ) |
231 | { | 231 | { |
232 | type = "adhoc"; | 232 | type = "adhoc"; |
233 | } | 233 | } |
234 | else if ( beacon->canESS() ) | 234 | else if ( beacon->canESS() ) |
235 | { | 235 | { |
236 | type = "managed"; | 236 | type = "managed"; |
237 | } | 237 | } |
238 | else | 238 | else |
239 | { | 239 | { |
240 | owarn << "Wellenreiter::invalid frame [possibly noise] detected!" << oendl; | 240 | owarn << "Wellenreiter::invalid frame [possibly noise] detected!" << oendl; |
241 | return; | 241 | return; |
242 | } | 242 | } |
243 | 243 | ||
244 | OWaveLanManagementSSID* ssid = static_cast<OWaveLanManagementSSID*>( p->child( "802.11 SSID" ) ); | 244 | OWaveLanManagementSSID* ssid = static_cast<OWaveLanManagementSSID*>( p->child( "802.11 SSID" ) ); |
245 | QString essid = ssid ? ssid->ID( true /* decloak */ ) : QString("<unknown>"); | 245 | QString essid = ssid ? ssid->ID( true /* decloak */ ) : QString("<unknown>"); |
246 | OWaveLanManagementDS* ds = static_cast<OWaveLanManagementDS*>( p->child( "802.11 DS" ) ); | 246 | OWaveLanManagementDS* ds = static_cast<OWaveLanManagementDS*>( p->child( "802.11 DS" ) ); |
247 | int channel = ds ? ds->channel() : -1; | 247 | int channel = ds ? ds->channel() : -1; |
248 | 248 | ||
249 | OWaveLanPacket* header = static_cast<OWaveLanPacket*>( p->child( "802.11" ) ); | 249 | OWaveLanPacket* header = static_cast<OWaveLanPacket*>( p->child( "802.11" ) ); |
250 | 250 | ||
251 | GpsLocation loc( -111, -111 ); | 251 | GpsLocation loc( -111, -111 ); |
252 | if ( configwindow->enableGPS->isChecked() ) | 252 | if ( configwindow->enableGPS->isChecked() ) |
253 | { | 253 | { |
254 | // TODO: add check if GPS is working!? | 254 | // TODO: add check if GPS is working!? |
255 | odebug << "Wellenreiter::gathering GPS data..." << oendl; | 255 | odebug << "Wellenreiter::gathering GPS data..." << oendl; |
256 | loc = gps->position(); | 256 | loc = gps->position(); |
257 | odebug << "Wellenreiter::GPS data received is ( " << loc.latitude() << " , " << loc.longitude() << " ) - dms string = '" << loc.dmsPosition().latin1() << "'" << oendl; | 257 | odebug << "Wellenreiter::GPS data received is ( " << loc.latitude() << " , " << loc.longitude() << " ) - dms string = '" << loc.dmsPosition().latin1() << "'" << oendl; |
258 | } | 258 | } |
259 | 259 | ||
260 | netView()->addNewItem( type, essid, header->macAddress2(), beacon->canPrivacy(), channel, 0, loc ); | 260 | netView()->addNewItem( type, essid, header->macAddress2(), beacon->canPrivacy(), channel, 0, loc ); |
261 | 261 | ||
262 | // update graph window | 262 | // update graph window |
263 | if ( ds ) | 263 | if ( ds ) |
264 | { | 264 | { |
265 | OPrismHeaderPacket* prism = static_cast<OPrismHeaderPacket*>( p->child( "Prism" ) ); | 265 | OPrismHeaderPacket* prism = static_cast<OPrismHeaderPacket*>( p->child( "Prism" ) ); |
266 | if ( prism ) | 266 | if ( prism ) |
267 | graphwindow->traffic( ds->channel(), prism->signalStrength() ); | 267 | graphwindow->traffic( ds->channel(), prism->signalStrength() ); |
268 | else | 268 | else |
269 | graphwindow->traffic( ds->channel(), 95 ); | 269 | graphwindow->traffic( ds->channel(), 95 ); |
270 | } | 270 | } |
271 | } | 271 | } |
272 | 272 | ||
273 | 273 | ||
274 | void Wellenreiter::handleControlFrame( OPacket* p, OWaveLanControlPacket* control ) | 274 | void Wellenreiter::handleControlFrame( OPacket* p, OWaveLanControlPacket* control ) |
275 | { | 275 | { |
276 | OWaveLanPacket* header = static_cast<OWaveLanPacket*>( p->child( "802.11" ) ); | 276 | OWaveLanPacket* header = static_cast<OWaveLanPacket*>( p->child( "802.11" ) ); |
277 | 277 | ||
278 | if ( control->controlType() == "Acknowledge" ) | 278 | if ( control->controlType() == "Acknowledge" ) |
279 | { | 279 | { |
280 | netView()->addNewItem( "adhoc", "<unknown>", header->macAddress1(), false, -1, 0, GpsLocation( -111, -111 ) ); | 280 | netView()->addNewItem( "adhoc", "<unknown>", header->macAddress1(), false, -1, 0, GpsLocation( -111, -111 ) ); |
281 | } | 281 | } |
282 | else | 282 | else |
283 | { | 283 | { |
284 | odebug << "Wellenreiter::handleControlFrame - please handle " << control->controlType() << " in a future version! :D" << oendl; | 284 | odebug << "Wellenreiter::handleControlFrame - please handle " << control->controlType() << " in a future version! :D" << oendl; |
285 | } | 285 | } |
286 | } | 286 | } |
287 | 287 | ||
288 | 288 | ||
289 | void Wellenreiter::handleWlanData( OPacket* p, OWaveLanDataPacket* data, OMacAddress& from, OMacAddress& to ) | 289 | void Wellenreiter::handleWlanData( OPacket* p, OWaveLanDataPacket* data, OMacAddress& from, OMacAddress& to ) |
290 | { | 290 | { |
291 | OWaveLanPacket* wlan = (OWaveLanPacket*) p->child( "802.11" ); | 291 | OWaveLanPacket* wlan = (OWaveLanPacket*) p->child( "802.11" ); |
292 | if ( wlan->fromDS() && !wlan->toDS() ) | 292 | if ( wlan->fromDS() && !wlan->toDS() ) |
293 | { | 293 | { |
294 | netView()->fromDStraffic( wlan->macAddress3(), wlan->macAddress1(), wlan->macAddress2() ); | 294 | netView()->fromDStraffic( wlan->macAddress3(), wlan->macAddress1(), wlan->macAddress2() ); |
295 | from = wlan->macAddress3(); | 295 | from = wlan->macAddress3(); |
296 | to = wlan->macAddress2(); | 296 | to = wlan->macAddress2(); |
297 | } | 297 | } |
298 | else if ( !wlan->fromDS() && wlan->toDS() ) | 298 | else if ( !wlan->fromDS() && wlan->toDS() ) |
299 | { | 299 | { |
300 | netView()->toDStraffic( wlan->macAddress2(), wlan->macAddress3(), wlan->macAddress1() ); | 300 | netView()->toDStraffic( wlan->macAddress2(), wlan->macAddress3(), wlan->macAddress1() ); |
301 | from = wlan->macAddress2(); | 301 | from = wlan->macAddress2(); |
302 | to = wlan->macAddress3(); | 302 | to = wlan->macAddress3(); |
303 | } | 303 | } |
304 | else if ( wlan->fromDS() && wlan->toDS() ) | 304 | else if ( wlan->fromDS() && wlan->toDS() ) |
305 | { | 305 | { |
306 | netView()->WDStraffic( wlan->macAddress4(), wlan->macAddress3(), wlan->macAddress1(), wlan->macAddress2() ); | 306 | netView()->WDStraffic( wlan->macAddress4(), wlan->macAddress3(), wlan->macAddress1(), wlan->macAddress2() ); |
307 | from = wlan->macAddress4(); | 307 | from = wlan->macAddress4(); |
308 | to = wlan->macAddress3(); | 308 | to = wlan->macAddress3(); |
309 | } | 309 | } |
310 | else | 310 | else |
311 | { | 311 | { |
312 | netView()->IBSStraffic( wlan->macAddress2(), wlan->macAddress1(), wlan->macAddress3() ); | 312 | netView()->IBSStraffic( wlan->macAddress2(), wlan->macAddress1(), wlan->macAddress3() ); |
313 | from = wlan->macAddress2(); | 313 | from = wlan->macAddress2(); |
314 | to = wlan->macAddress1(); | 314 | to = wlan->macAddress1(); |
315 | } | 315 | } |
316 | } | 316 | } |
317 | 317 | ||
318 | 318 | ||
319 | void Wellenreiter::handleEthernetData( OPacket* p, OEthernetPacket* data, OMacAddress& from, OMacAddress& to ) | 319 | void Wellenreiter::handleEthernetData( OPacket* p, OEthernetPacket* data, OMacAddress& from, OMacAddress& to ) |
320 | { | 320 | { |
321 | from = data->sourceAddress(); | 321 | from = data->sourceAddress(); |
322 | to = data->destinationAddress(); | 322 | to = data->destinationAddress(); |
323 | 323 | ||
324 | netView()->addNewItem( "station", "<wired>", from, false, -1, 0, GpsLocation( -111, -111 ) ); | 324 | netView()->addNewItem( "station", "<wired>", from, false, -1, 0, GpsLocation( -111, -111 ) ); |
325 | } | 325 | } |
326 | 326 | ||
327 | 327 | ||
328 | void Wellenreiter::handleARPData( OPacket* p, OARPPacket*, OMacAddress& source, OMacAddress& dest ) | 328 | void Wellenreiter::handleARPData( OPacket* p, OARPPacket*, OMacAddress& source, OMacAddress& dest ) |
329 | { | 329 | { |
330 | OARPPacket* arp = (OARPPacket*) p->child( "ARP" ); | 330 | OARPPacket* arp = (OARPPacket*) p->child( "ARP" ); |
331 | if ( arp ) | 331 | if ( arp ) |
332 | { | 332 | { |
333 | odebug << "Received ARP traffic (type '" << arp->type() << "'): " << oendl; | 333 | odebug << "Received ARP traffic (type '" << arp->type() << "'): " << oendl; |
334 | if ( arp->type() == "REQUEST" ) | 334 | if ( arp->type() == "REQUEST" ) |
335 | { | 335 | { |
336 | netView()->identify( arp->senderMacAddress(), arp->senderIPV4Address().toString() ); | 336 | netView()->identify( arp->senderMacAddress(), arp->senderIPV4Address().toString() ); |
337 | } | 337 | } |
338 | else if ( arp->type() == "REPLY" ) | 338 | else if ( arp->type() == "REPLY" ) |
339 | { | 339 | { |
340 | netView()->identify( arp->senderMacAddress(), arp->senderIPV4Address().toString() ); | 340 | netView()->identify( arp->senderMacAddress(), arp->senderIPV4Address().toString() ); |
341 | netView()->identify( arp->targetMacAddress(), arp->targetIPV4Address().toString() ); | 341 | netView()->identify( arp->targetMacAddress(), arp->targetIPV4Address().toString() ); |
342 | } | 342 | } |
343 | } | 343 | } |
344 | } | 344 | } |
345 | 345 | ||
346 | 346 | ||
347 | void Wellenreiter::handleIPData( OPacket* p, OIPPacket* ip, OMacAddress& source, OMacAddress& dest ) | 347 | void Wellenreiter::handleIPData( OPacket* p, OIPPacket* ip, OMacAddress& source, OMacAddress& dest ) |
348 | { | 348 | { |
349 | //TODO: Implement more IP based protocols | 349 | //TODO: Implement more IP based protocols |
350 | 350 | ||
351 | ODHCPPacket* dhcp = (ODHCPPacket*) p->child( "DHCP" ); | 351 | ODHCPPacket* dhcp = (ODHCPPacket*) p->child( "DHCP" ); |
352 | if ( dhcp ) | 352 | if ( dhcp ) |
353 | { | 353 | { |
354 | odebug << "Received DHCP '" << dhcp->type() << "' packet" << oendl; | 354 | odebug << "Received DHCP '" << dhcp->type() << "' packet" << oendl; |
355 | if ( dhcp->type() == "OFFER" ) | 355 | if ( dhcp->type() == "OFFER" ) |
356 | { | 356 | { |
357 | odebug << "DHCP: '" << (const char*) source.toString() << "' ('" << dhcp->serverAddress().toString() << "') seems to be a DHCP server." << oendl; | 357 | odebug << "DHCP: '" << (const char*) source.toString() << "' ('" << dhcp->serverAddress().toString() << "') seems to be a DHCP server." << oendl; |
358 | netView()->identify( source, dhcp->serverAddress().toString() ); | 358 | netView()->identify( source, dhcp->serverAddress().toString() ); |
359 | netView()->addService( "DHCP", source, dhcp->serverAddress().toString() ); | 359 | netView()->addService( "DHCP", source, dhcp->serverAddress().toString() ); |
360 | } | 360 | } |
361 | else if ( dhcp->type() == "ACK" ) | 361 | else if ( dhcp->type() == "ACK" ) |
362 | { | 362 | { |
363 | odebug << "DHCP: '" << (const char*) dhcp->clientMacAddress().toString() << "' ('" << dhcp->yourAddress().toString() << "') accepted the offered DHCP address." << oendl; | 363 | odebug << "DHCP: '" << (const char*) dhcp->clientMacAddress().toString() << "' ('" << dhcp->yourAddress().toString() << "') accepted the offered DHCP address." << oendl; |
364 | netView()->identify( dhcp->clientMacAddress(), dhcp->yourAddress().toString() ); | 364 | netView()->identify( dhcp->clientMacAddress(), dhcp->yourAddress().toString() ); |
365 | } | 365 | } |
366 | } | 366 | } |
367 | } | 367 | } |
368 | 368 | ||
369 | 369 | ||
370 | QObject* Wellenreiter::childIfToParse( OPacket* p, const QString& protocol ) | 370 | QObject* Wellenreiter::childIfToParse( OPacket* p, const QString& protocol ) |
371 | { | 371 | { |
372 | if ( configwindow->parsePackets->isProtocolChecked( protocol ) ) | 372 | if ( configwindow->parsePackets->isProtocolChecked( protocol ) ) |
373 | if ( configwindow->parsePackets->protocolAction( protocol ) == "Discard!" ) | 373 | if ( configwindow->parsePackets->protocolAction( protocol ) == "Discard!" ) |
374 | return 0; | 374 | return 0; |
375 | 375 | ||
376 | return p->child( protocol ); | 376 | return p->child( protocol ); |
377 | } | 377 | } |
378 | 378 | ||
379 | 379 | ||
380 | bool Wellenreiter::checkDumpPacket( OPacket* p ) | 380 | bool Wellenreiter::checkDumpPacket( OPacket* p ) |
381 | { | 381 | { |
382 | // go through all child packets and see if one is inside the child hierarchy for p | 382 | // go through all child packets and see if one is inside the child hierarchy for p |
383 | // if so, do what the user requested (protocolAction), e.g. pass or discard | 383 | // if so, do what the user requested (protocolAction), e.g. pass or discard |
384 | if ( !configwindow->writeCaptureFile->isChecked() ) | 384 | if ( !configwindow->writeCaptureFile->isChecked() ) |
385 | return true; // semantic change - we're logging anyway now to /tmp/wellenreiter | 385 | return true; // semantic change - we're logging anyway now to /tmp/wellenreiter |
386 | 386 | ||
387 | QObjectList* l = p->queryList(); | 387 | QObjectList* l = p->queryList(); |
388 | QObjectListIt it( *l ); | 388 | QObjectListIt it( *l ); |
389 | QObject* o; | 389 | QObject* o; |
390 | 390 | ||
391 | while ( (o = it.current()) != 0 ) | 391 | while ( (o = it.current()) != 0 ) |
392 | { | 392 | { |
393 | QString name = it.current()->name(); | 393 | QString name = it.current()->name(); |
394 | if ( configwindow->capturePackets->isProtocolChecked( name ) ) | 394 | if ( configwindow->capturePackets->isProtocolChecked( name ) ) |
395 | { | 395 | { |
396 | QString action = configwindow->capturePackets->protocolAction( name ); | 396 | QString action = configwindow->capturePackets->protocolAction( name ); |
397 | odebug << "capturePackets-action for '" << (const char*) name << "' seems to be '" << action << "'" << oendl; | 397 | odebug << "capturePackets-action for '" << (const char*) name << "' seems to be '" << action << "'" << oendl; |
398 | if ( action == "Discard" ) | 398 | if ( action == "Discard" ) |
399 | { | 399 | { |
400 | logwindow->log( QString().sprintf( "(i) dump-discarding of '%s' packet requested.", (const char*) name ) ); | 400 | logwindow->log( QString().sprintf( "(i) dump-discarding of '%s' packet requested.", (const char*) name ) ); |
401 | return false; | 401 | return false; |
402 | } | 402 | } |
403 | } | 403 | } |
404 | else | 404 | else |
405 | { | 405 | { |
406 | odebug << "protocol '" << name << "' not checked in capturePackets." << oendl; | 406 | odebug << "protocol '" << name << "' not checked in capturePackets." << oendl; |
407 | } | 407 | } |
408 | ++it; | 408 | ++it; |
409 | } | 409 | } |
410 | return true; | 410 | return true; |
411 | } | 411 | } |
412 | 412 | ||
413 | 413 | ||
414 | void Wellenreiter::receivePacket( OPacket* p ) | 414 | void Wellenreiter::receivePacket( OPacket* p ) |
415 | { | 415 | { |
416 | hexWindow()->add( p ); | 416 | hexWindow()->add( p, configwindow->hexViewBuffer() ); |
417 | 417 | ||
418 | if ( checkDumpPacket( p ) ) | 418 | if ( checkDumpPacket( p ) ) |
419 | { | 419 | { |
420 | pcap->dump( p ); | 420 | pcap->dump( p ); |
421 | } | 421 | } |
422 | 422 | ||
423 | // check for a management frame | 423 | // check for a management frame |
424 | OWaveLanManagementPacket* manage = static_cast<OWaveLanManagementPacket*>( childIfToParse( p, "802.11 Management" ) ); | 424 | OWaveLanManagementPacket* manage = static_cast<OWaveLanManagementPacket*>( childIfToParse( p, "802.11 Management" ) ); |
425 | if ( manage ) | 425 | if ( manage ) |
426 | { | 426 | { |
427 | handleManagementFrame( p, manage ); | 427 | handleManagementFrame( p, manage ); |
428 | return; | 428 | return; |
429 | } | 429 | } |
430 | 430 | ||
431 | // check for a control frame | 431 | // check for a control frame |
432 | OWaveLanControlPacket* control = static_cast<OWaveLanControlPacket*>( childIfToParse( p, "802.11 Control" ) ); | 432 | OWaveLanControlPacket* control = static_cast<OWaveLanControlPacket*>( childIfToParse( p, "802.11 Control" ) ); |
433 | if ( control ) | 433 | if ( control ) |
434 | { | 434 | { |
435 | handleControlFrame( p, control ); | 435 | handleControlFrame( p, control ); |
436 | return; | 436 | return; |
437 | } | 437 | } |
438 | 438 | ||
439 | OMacAddress source; | 439 | OMacAddress source; |
440 | OMacAddress dest; | 440 | OMacAddress dest; |
441 | 441 | ||
442 | //TODO: WEP check here | 442 | //TODO: WEP check here |
443 | 443 | ||
444 | // check for a wireless data frame | 444 | // check for a wireless data frame |
445 | OWaveLanDataPacket* wlan = static_cast<OWaveLanDataPacket*>( childIfToParse( p, "802.11 Data" ) ); | 445 | OWaveLanDataPacket* wlan = static_cast<OWaveLanDataPacket*>( childIfToParse( p, "802.11 Data" ) ); |
446 | if ( wlan ) | 446 | if ( wlan ) |
447 | { | 447 | { |
448 | handleWlanData( p, wlan, source, dest ); | 448 | handleWlanData( p, wlan, source, dest ); |
449 | } | 449 | } |
450 | 450 | ||
451 | // check for a wired data frame | 451 | // check for a wired data frame |
452 | OEthernetPacket* eth = static_cast<OEthernetPacket*>( childIfToParse( p, "Ethernet" ) ); | 452 | OEthernetPacket* eth = static_cast<OEthernetPacket*>( childIfToParse( p, "Ethernet" ) ); |
453 | if ( eth ) | 453 | if ( eth ) |
454 | { | 454 | { |
455 | handleEthernetData( p, eth, source, dest ); | 455 | handleEthernetData( p, eth, source, dest ); |
456 | } | 456 | } |
457 | 457 | ||
458 | // check for an arp frame since arp frames come in two flavours: | 458 | // check for an arp frame since arp frames come in two flavours: |
459 | // 802.11 encapsulates ARP data within IP packets while wired ethernet doesn't. | 459 | // 802.11 encapsulates ARP data within IP packets while wired ethernet doesn't. |
460 | OARPPacket* arp = static_cast<OARPPacket*>( childIfToParse( p, "ARP" ) ); | 460 | OARPPacket* arp = static_cast<OARPPacket*>( childIfToParse( p, "ARP" ) ); |
461 | if ( arp ) | 461 | if ( arp ) |
462 | { | 462 | { |
463 | handleARPData( p, arp, source, dest ); | 463 | handleARPData( p, arp, source, dest ); |
464 | } | 464 | } |
465 | 465 | ||
466 | // check for a ip frame | 466 | // check for a ip frame |
467 | OIPPacket* ip = static_cast<OIPPacket*>( childIfToParse( p, "IP" ) ); | 467 | OIPPacket* ip = static_cast<OIPPacket*>( childIfToParse( p, "IP" ) ); |
468 | if ( ip ) | 468 | if ( ip ) |
469 | { | 469 | { |
470 | handleIPData( p, ip, source, dest ); | 470 | handleIPData( p, ip, source, dest ); |
471 | } | 471 | } |
472 | 472 | ||
473 | //handleNotification( p ); | 473 | //handleNotification( p ); |
474 | 474 | ||
475 | } | 475 | } |
476 | 476 | ||
477 | 477 | ||
478 | void Wellenreiter::stopClicked() | 478 | void Wellenreiter::stopClicked() |
479 | { | 479 | { |
480 | if ( iface ) | 480 | if ( iface ) |
481 | { | 481 | { |
482 | disconnect( SIGNAL( receivedPacket(Opie::Net::OPacket*) ), this, SLOT( receivePacket(Opie::Net::OPacket*) ) ); | 482 | disconnect( SIGNAL( receivedPacket(Opie::Net::OPacket*) ), this, SLOT( receivePacket(Opie::Net::OPacket*) ) ); |
483 | disconnect( SIGNAL( hopped(int) ), this, SLOT( channelHopped(int) ) ); | 483 | disconnect( SIGNAL( hopped(int) ), this, SLOT( channelHopped(int) ) ); |
484 | iface->setChannelHopping(); // stop hopping channels | 484 | iface->setChannelHopping(); // stop hopping channels |
485 | } | 485 | } |
486 | else | 486 | else |
487 | killTimers(); | 487 | killTimers(); |
488 | 488 | ||
489 | pcap->close(); | 489 | pcap->close(); |
490 | sniffing = false; | 490 | sniffing = false; |
491 | 491 | ||
492 | if ( iface ) | 492 | if ( iface ) |
493 | { | 493 | { |
494 | // switch off monitor mode | 494 | // switch off monitor mode |
495 | iface->setMode( "managed" ); | 495 | iface->setMode( "managed" ); |
496 | // switch off promisc flag | 496 | // switch off promisc flag |
497 | iface->setPromiscuousMode( false ); | 497 | iface->setPromiscuousMode( false ); |
498 | 498 | ||
499 | system( "cardctl reset; sleep 1" ); //FIXME: Use OProcess | 499 | system( "cardctl reset; sleep 1" ); //FIXME: Use OProcess |
500 | } | 500 | } |
501 | 501 | ||
502 | logwindow->log( "(i) Stopped Scanning." ); | 502 | logwindow->log( "(i) Stopped Scanning." ); |
503 | assert( parent() ); | 503 | assert( parent() ); |
504 | ( (QMainWindow*) parent() )->setCaption( "Wellenreiter II" ); | 504 | ( (QMainWindow*) parent() )->setCaption( "Wellenreiter II" ); |
505 | 505 | ||
506 | // message the user | 506 | // message the user |
507 | QMessageBox::information( this, "Wellenreiter II", | 507 | QMessageBox::information( this, "Wellenreiter II", |
508 | tr( "Your wireless card\nshould now be usable again." ) ); | 508 | tr( "Your wireless card\nshould now be usable again." ) ); |
509 | 509 | ||
510 | sniffing = false; | 510 | sniffing = false; |
511 | emit( stoppedSniffing() ); | 511 | emit( stoppedSniffing() ); |
512 | 512 | ||
513 | #ifdef QWS | 513 | #ifdef QWS |
514 | if ( WellenreiterConfigWindow::instance()->disablePM->isChecked() ) | 514 | if ( WellenreiterConfigWindow::instance()->disablePM->isChecked() ) |
515 | { | 515 | { |
516 | QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable; | 516 | QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable; |
517 | } | 517 | } |
518 | #else | 518 | #else |
519 | #warning FIXME: setScreenSaverMode is not operational on the X11 build | 519 | #warning FIXME: setScreenSaverMode is not operational on the X11 build |
520 | #endif | 520 | #endif |
521 | 521 | ||
522 | // print out statistics | 522 | // print out statistics |
523 | for( QMap<QString,int>::ConstIterator it = pcap->statistics().begin(); it != pcap->statistics().end(); ++it ) | 523 | for( QMap<QString,int>::ConstIterator it = pcap->statistics().begin(); it != pcap->statistics().end(); ++it ) |
524 | statwindow->updateCounter( it.key(), it.data() ); | 524 | statwindow->updateCounter( it.key(), it.data() ); |
525 | } | 525 | } |
526 | 526 | ||
527 | 527 | ||
528 | void Wellenreiter::startClicked() | 528 | void Wellenreiter::startClicked() |
529 | { | 529 | { |
530 | // get configuration from config window | 530 | // get configuration from config window |
531 | 531 | ||
532 | const QString& interface = configwindow->interfaceName->currentText(); | 532 | const QString& interface = configwindow->interfaceName->currentText(); |
533 | const int cardtype = configwindow->driverType(); | 533 | const int cardtype = configwindow->driverType(); |
534 | const int interval = configwindow->hoppingInterval(); | 534 | const int interval = configwindow->hoppingInterval(); |
535 | 535 | ||
536 | if ( ( interface == "" ) || ( cardtype == 0 ) ) | 536 | if ( ( interface == "" ) || ( cardtype == 0 ) ) |
537 | { | 537 | { |
538 | QMessageBox::information( this, "Wellenreiter II", | 538 | QMessageBox::information( this, "Wellenreiter II", |
539 | tr( "No device configured.\nPlease reconfigure!" ) ); | 539 | tr( "No device configured.\nPlease reconfigure!" ) ); |
540 | return; | 540 | return; |
541 | } | 541 | } |
542 | 542 | ||
543 | // configure device | 543 | // configure device |
544 | ONetwork* net = ONetwork::instance(); | 544 | ONetwork* net = ONetwork::instance(); |
545 | 545 | ||
546 | // TODO: check if interface is wireless and support sniffing for non-wireless interfaces | 546 | // TODO: check if interface is wireless and support sniffing for non-wireless interfaces |
547 | 547 | ||
548 | if ( cardtype != DEVTYPE_FILE ) | 548 | if ( cardtype != DEVTYPE_FILE ) |
549 | { | 549 | { |
550 | 550 | ||
551 | if ( !net->isPresent( interface ) ) | 551 | if ( !net->isPresent( interface ) ) |
552 | { | 552 | { |
553 | QMessageBox::information( this, "Wellenreiter II", | 553 | QMessageBox::information( this, "Wellenreiter II", |
554 | tr( "The configured device (%1)\nis not available on this system\n. Please reconfigure!" ).arg( interface ) ); | 554 | tr( "The configured device (%1)\nis not available on this system\n. Please reconfigure!" ).arg( interface ) ); |
555 | return; | 555 | return; |
556 | } | 556 | } |
557 | 557 | ||
558 | iface = static_cast<OWirelessNetworkInterface*>(net->interface( interface )); // fails if network is not wireless! | 558 | iface = static_cast<OWirelessNetworkInterface*>(net->interface( interface )); // fails if network is not wireless! |
559 | assert( iface ); | 559 | assert( iface ); |
560 | 560 | ||
561 | // bring device UP | 561 | // bring device UP |
562 | iface->setUp( true ); | 562 | iface->setUp( true ); |
563 | if ( !iface->isUp() ) | 563 | if ( !iface->isUp() ) |
564 | { | 564 | { |
565 | QMessageBox::warning( this, "Wellenreiter II", | 565 | QMessageBox::warning( this, "Wellenreiter II", |
566 | tr( "Can't bring interface '%1' up:\n" ).arg( iface->name() ) + strerror( errno ) ); | 566 | tr( "Can't bring interface '%1' up:\n" ).arg( iface->name() ) + strerror( errno ) ); |
567 | return; | 567 | return; |
568 | } | 568 | } |
569 | 569 | ||
570 | // check if wireless extension version matches | 570 | // check if wireless extension version matches |
571 | if ( ONetwork::wirelessExtensionCompileVersion() != iface->wirelessExtensionDriverVersion() ) | 571 | if ( ONetwork::wirelessExtensionCompileVersion() != iface->wirelessExtensionDriverVersion() ) |
572 | { | 572 | { |
573 | QMessageBox::critical( this, "Wellenreiter II", tr( "<p>The Wireless Extension Versions<br>are not matching!<p>" | 573 | QMessageBox::critical( this, "Wellenreiter II", tr( "<p>The Wireless Extension Versions<br>are not matching!<p>" |
574 | " Wellenreiter II : WE V%1<br>Interface driver: WE V%2" ) | 574 | " Wellenreiter II : WE V%1<br>Interface driver: WE V%2" ) |
575 | .arg( QString::number( ONetwork::wirelessExtensionCompileVersion() ) ) | 575 | .arg( QString::number( ONetwork::wirelessExtensionCompileVersion() ) ) |
576 | .arg( QString::number( iface->wirelessExtensionDriverVersion() ) ) ); | 576 | .arg( QString::number( iface->wirelessExtensionDriverVersion() ) ) ); |
577 | return; | 577 | return; |
578 | } | 578 | } |
579 | } | 579 | } |
580 | // set monitor mode | 580 | // set monitor mode |
581 | bool usePrism = configwindow->usePrismHeader(); | 581 | bool usePrism = configwindow->usePrismHeader(); |
582 | 582 | ||
583 | switch ( cardtype ) | 583 | switch ( cardtype ) |
584 | { | 584 | { |
585 | case DEVTYPE_CISCO: iface->setMonitoring( new OCiscoMonitoringInterface( iface, usePrism ) ); break; | 585 | case DEVTYPE_CISCO: iface->setMonitoring( new OCiscoMonitoringInterface( iface, usePrism ) ); break; |
586 | case DEVTYPE_WLAN_NG: iface->setMonitoring( new OWlanNGMonitoringInterface( iface, usePrism ) ); break; | 586 | case DEVTYPE_WLAN_NG: iface->setMonitoring( new OWlanNGMonitoringInterface( iface, usePrism ) ); break; |
587 | case DEVTYPE_HOSTAP: iface->setMonitoring( new OHostAPMonitoringInterface( iface, usePrism ) ); break; | 587 | case DEVTYPE_HOSTAP: iface->setMonitoring( new OHostAPMonitoringInterface( iface, usePrism ) ); break; |
588 | case DEVTYPE_ORINOCO: iface->setMonitoring( new OOrinocoMonitoringInterface( iface, usePrism ) ); break; | 588 | case DEVTYPE_ORINOCO: iface->setMonitoring( new OOrinocoMonitoringInterface( iface, usePrism ) ); break; |
589 | case DEVTYPE_MANUAL: QMessageBox::information( this, "Wellenreiter II", tr( "Bring your device into\nmonitor mode now." ) ); break; | 589 | case DEVTYPE_MANUAL: QMessageBox::information( this, "Wellenreiter II", tr( "Bring your device into\nmonitor mode now." ) ); break; |
590 | case DEVTYPE_FILE: odebug << "Wellenreiter: Capturing from file '" << interface << "'" << oendl; break; | 590 | case DEVTYPE_FILE: odebug << "Wellenreiter: Capturing from file '" << interface << "'" << oendl; break; |
591 | default: assert( 0 ); // shouldn't reach this | 591 | default: assert( 0 ); // shouldn't reach this |
592 | } | 592 | } |
593 | 593 | ||
594 | // switch device into monitor mode | 594 | // switch device into monitor mode |
595 | if ( cardtype < DEVTYPE_FILE ) | 595 | if ( cardtype < DEVTYPE_FILE ) |
596 | { | 596 | { |
597 | if ( cardtype != DEVTYPE_MANUAL ) | 597 | if ( cardtype != DEVTYPE_MANUAL ) |
598 | iface->setMode( "monitor" ); | 598 | iface->setMode( "monitor" ); |
599 | if ( iface->mode() != "monitor" ) | 599 | if ( iface->mode() != "monitor" ) |
600 | { | 600 | { |
601 | if ( QMessageBox::warning( this, "Wellenreiter II", | 601 | if ( QMessageBox::warning( this, "Wellenreiter II", |
602 | tr( "Can't set interface '%1'\ninto monitor mode:\n" ).arg( iface->name() ) + strerror( errno ) + | 602 | tr( "Can't set interface '%1'\ninto monitor mode:\n" ).arg( iface->name() ) + strerror( errno ) + |
603 | tr( "\nContinue with limited functionality?" ), QMessageBox::Yes, QMessageBox::No ) == QMessageBox::No ) | 603 | tr( "\nContinue with limited functionality?" ), QMessageBox::Yes, QMessageBox::No ) == QMessageBox::No ) |
604 | return; | 604 | return; |
605 | } | 605 | } |
606 | } | 606 | } |
607 | 607 | ||
608 | // open GPS device | 608 | // open GPS device |