author | mickeyl <mickeyl> | 2005-04-21 10:21:18 (UTC) |
---|---|---|
committer | mickeyl <mickeyl> | 2005-04-21 10:21:18 (UTC) |
commit | 945c98bd21a59f18a3ac0cdf330153163861731a (patch) (unidiff) | |
tree | e868fa29ae20923a8567d3e5c2af429e1e8cf937 | |
parent | a5044439757037640435a5800584d408a58c1bba (diff) | |
download | opie-945c98bd21a59f18a3ac0cdf330153163861731a.zip opie-945c98bd21a59f18a3ac0cdf330153163861731a.tar.gz opie-945c98bd21a59f18a3ac0cdf330153163861731a.tar.bz2 |
disable "Rescan Neighbourhood" while scanning
-rw-r--r-- | noncore/settings/networksettings/wlan/wlan.pro | 2 | ||||
-rw-r--r-- | noncore/settings/networksettings/wlan/wlanimp2.cpp | 6 |
2 files changed, 5 insertions, 3 deletions
diff --git a/noncore/settings/networksettings/wlan/wlan.pro b/noncore/settings/networksettings/wlan/wlan.pro index e975dde..eb9dd4f 100644 --- a/noncore/settings/networksettings/wlan/wlan.pro +++ b/noncore/settings/networksettings/wlan/wlan.pro | |||
@@ -1,32 +1,32 @@ | |||
1 | TEMPLATE = lib | 1 | TEMPLATE = lib |
2 | CONFIG += qt plugin warn_on | 2 | CONFIG += qt plugin warn_on |
3 | DESTDIR = $(OPIEDIR)/plugins/networksettings | 3 | DESTDIR = $(OPIEDIR)/plugins/networksettings |
4 | HEADERS = infoimp.h wlanmodule.h wextensions.h keyedit.h | 4 | HEADERS = infoimp.h wlanmodule.h wextensions.h keyedit.h |
5 | SOURCES = infoimp.cpp wlanmodule.cpp wextensions.cpp keyedit.cpp | 5 | SOURCES = infoimp.cpp wlanmodule.cpp wextensions.cpp keyedit.cpp |
6 | INCLUDEPATH+= $(OPIEDIR)/include ../ ../interfaces/ | 6 | INCLUDEPATH+= $(OPIEDIR)/include ../ ../interfaces/ |
7 | DEPENDPATH+= $(OPIEDIR)/include | 7 | DEPENDPATH+= $(OPIEDIR)/include |
8 | LIBS += -lqpe -L../interfaces/ -linterfaces -lopiecore2 -lopienet2 | 8 | LIBS += -lqpe -L../interfaces/ -linterfaces -lopiecore2 -lopienet2 |
9 | INTERFACES= wlan.ui info.ui | 9 | INTERFACES= wlan.ui info.ui |
10 | TARGET = wlan | 10 | TARGET = wlan |
11 | VERSION = 1.0.0 | 11 | VERSION = 1.0.1 |
12 | 12 | ||
13 | #CONFIG += wirelessopts | 13 | #CONFIG += wirelessopts |
14 | 14 | ||
15 | wirelessopts { | 15 | wirelessopts { |
16 | HEADERS+= wlanimp.h | 16 | HEADERS+= wlanimp.h |
17 | SOURCES+= wlanimp.cpp | 17 | SOURCES+= wlanimp.cpp |
18 | } | 18 | } |
19 | 19 | ||
20 | ! wirelessopts { | 20 | ! wirelessopts { |
21 | HEADERS+= wlanimp2.h | 21 | HEADERS+= wlanimp2.h |
22 | SOURCES += wlanimp2.cpp | 22 | SOURCES += wlanimp2.cpp |
23 | } | 23 | } |
24 | 24 | ||
25 | include( $(OPIEDIR)/include.pro ) | 25 | include( $(OPIEDIR)/include.pro ) |
26 | 26 | ||
27 | !isEmpty( LIBPCAP_INC_DIR ) { | 27 | !isEmpty( LIBPCAP_INC_DIR ) { |
28 | INCLUDEPATH = $$LIBPCAP_INC_DIR $$INCLUDEPATH | 28 | INCLUDEPATH = $$LIBPCAP_INC_DIR $$INCLUDEPATH |
29 | } | 29 | } |
30 | !isEmpty( LIBPCAP_LIB_DIR ) { | 30 | !isEmpty( LIBPCAP_LIB_DIR ) { |
31 | LIBS = -L$$LIBPCAP_LIB_DIR $$LIBS | 31 | LIBS = -L$$LIBPCAP_LIB_DIR $$LIBS |
32 | } | 32 | } |
diff --git a/noncore/settings/networksettings/wlan/wlanimp2.cpp b/noncore/settings/networksettings/wlan/wlanimp2.cpp index 5cb78cf..11dfe74 100644 --- a/noncore/settings/networksettings/wlan/wlanimp2.cpp +++ b/noncore/settings/networksettings/wlan/wlanimp2.cpp | |||
@@ -325,145 +325,147 @@ void WLANImp::rescanNeighbourhood() | |||
325 | modules >> line; | 325 | modules >> line; |
326 | if ( line.contains( "cisco" ) ) devicetype = "cisco"; | 326 | if ( line.contains( "cisco" ) ) devicetype = "cisco"; |
327 | else if ( line.contains( "hostap" ) ) devicetype = "hostap"; | 327 | else if ( line.contains( "hostap" ) ) devicetype = "hostap"; |
328 | else if ( line.contains( "prism" ) ) devicetype = "wlan-ng"; /* puke */ | 328 | else if ( line.contains( "prism" ) ) devicetype = "wlan-ng"; /* puke */ |
329 | else if ( line.contains( "orinoco" ) ) devicetype = "orinoco"; | 329 | else if ( line.contains( "orinoco" ) ) devicetype = "orinoco"; |
330 | } | 330 | } |
331 | } | 331 | } |
332 | if ( devicetype.isEmpty() ) | 332 | if ( devicetype.isEmpty() ) |
333 | { | 333 | { |
334 | owarn << "rescanNeighbourhood(): couldn't guess device type :(" << oendl; | 334 | owarn << "rescanNeighbourhood(): couldn't guess device type :(" << oendl; |
335 | return; | 335 | return; |
336 | } | 336 | } |
337 | else | 337 | else |
338 | { | 338 | { |
339 | odebug << "rescanNeighbourhood(): device type seems to be '" << devicetype << "'" << oendl; | 339 | odebug << "rescanNeighbourhood(): device type seems to be '" << devicetype << "'" << oendl; |
340 | } | 340 | } |
341 | 341 | ||
342 | // configure interface to receive 802.11 management frames | 342 | // configure interface to receive 802.11 management frames |
343 | 343 | ||
344 | wiface->setUp( true ); | 344 | wiface->setUp( true ); |
345 | wiface->setPromiscuousMode( true ); | 345 | wiface->setPromiscuousMode( true ); |
346 | 346 | ||
347 | if ( devicetype == "cisco" ) wiface->setMonitoring( new OCiscoMonitoringInterface( wiface, false ) ); | 347 | if ( devicetype == "cisco" ) wiface->setMonitoring( new OCiscoMonitoringInterface( wiface, false ) ); |
348 | else if ( devicetype == "hostap" ) wiface->setMonitoring( new OHostAPMonitoringInterface( wiface, false ) ); | 348 | else if ( devicetype == "hostap" ) wiface->setMonitoring( new OHostAPMonitoringInterface( wiface, false ) ); |
349 | else if ( devicetype == "wlan-ng" ) wiface->setMonitoring( new OWlanNGMonitoringInterface( wiface, false ) ); | 349 | else if ( devicetype == "wlan-ng" ) wiface->setMonitoring( new OWlanNGMonitoringInterface( wiface, false ) ); |
350 | else if ( devicetype == "orinoco" ) wiface->setMonitoring( new OOrinocoMonitoringInterface( wiface, false ) ); | 350 | else if ( devicetype == "orinoco" ) wiface->setMonitoring( new OOrinocoMonitoringInterface( wiface, false ) ); |
351 | else | 351 | else |
352 | { | 352 | { |
353 | odebug << "rescanNeighbourhood(): unsupported device type for monitoring :(" << oendl; | 353 | odebug << "rescanNeighbourhood(): unsupported device type for monitoring :(" << oendl; |
354 | return; | 354 | return; |
355 | } | 355 | } |
356 | 356 | ||
357 | wiface->setMode( "monitor" ); | 357 | wiface->setMode( "monitor" ); |
358 | if ( wiface->mode() != "monitor" ) | 358 | if ( wiface->mode() != "monitor" ) |
359 | { | 359 | { |
360 | owarn << "rescanNeighbourhood(): Unable to bring device into monitor mode (" << strerror( errno ) << ")." << oendl; | 360 | owarn << "rescanNeighbourhood(): Unable to bring device into monitor mode (" << strerror( errno ) << ")." << oendl; |
361 | return; | 361 | return; |
362 | } | 362 | } |
363 | 363 | ||
364 | // open a packet capturer | 364 | // open a packet capturer |
365 | OPacketCapturer* cap = new OPacketCapturer(); | 365 | OPacketCapturer* cap = new OPacketCapturer(); |
366 | cap->open( name ); | 366 | cap->open( name ); |
367 | if ( !cap->isOpen() ) | 367 | if ( !cap->isOpen() ) |
368 | { | 368 | { |
369 | owarn << "rescanNeighbourhood(): Unable to open libpcap (" << strerror( errno ) << ")." << oendl; | 369 | owarn << "rescanNeighbourhood(): Unable to open libpcap (" << strerror( errno ) << ")." << oendl; |
370 | return; | 370 | return; |
371 | } | 371 | } |
372 | 372 | ||
373 | // display splash screen | 373 | // disable button and display splash screen |
374 | rescanButton->setEnabled( false ); | ||
374 | QFrame* splash = new QFrame( this, "splash", false, WStyle_StaysOnTop | WStyle_DialogBorder | WStyle_Customize ); | 375 | QFrame* splash = new QFrame( this, "splash", false, WStyle_StaysOnTop | WStyle_DialogBorder | WStyle_Customize ); |
375 | splash->setLineWidth( 2 ); | 376 | splash->setLineWidth( 2 ); |
376 | splash->setFrameStyle( QFrame::Panel | QFrame::Raised ); | 377 | splash->setFrameStyle( QFrame::Panel | QFrame::Raised ); |
377 | QVBoxLayout* vbox = new QVBoxLayout( splash, 4, 4 ); | 378 | QVBoxLayout* vbox = new QVBoxLayout( splash, 4, 4 ); |
378 | QLabel* lab = new QLabel( "<center><b>Scanning...</b><br>Please Wait...</center>", splash ); | 379 | QLabel* lab = new QLabel( "<center><b>Scanning...</b><br>Please Wait...</center>", splash ); |
379 | QProgressBar* pb = new QProgressBar( wiface->channels(), splash ); | 380 | QProgressBar* pb = new QProgressBar( wiface->channels(), splash ); |
380 | vbox->addWidget( lab ); | 381 | vbox->addWidget( lab ); |
381 | vbox->addWidget( pb ); | 382 | vbox->addWidget( pb ); |
382 | pb->setCenterIndicator( true ); | 383 | pb->setCenterIndicator( true ); |
383 | pb->setFixedHeight( pb->sizeHint().height() ); | 384 | pb->setFixedHeight( pb->sizeHint().height() ); |
384 | QWidget* widgetDesktop = qApp->desktop(); | 385 | QWidget* widgetDesktop = qApp->desktop(); |
385 | int dw = widgetDesktop->width(); | 386 | int dw = widgetDesktop->width(); |
386 | int dh = widgetDesktop->height(); | 387 | int dh = widgetDesktop->height(); |
387 | int pw = vbox->sizeHint().width(); | 388 | int pw = vbox->sizeHint().width(); |
388 | int ph = vbox->sizeHint().height(); | 389 | int ph = vbox->sizeHint().height(); |
389 | splash->setGeometry((dw-pw)/2,(dh-ph)/2,pw,ph); | 390 | splash->setGeometry((dw-pw)/2,(dh-ph)/2,pw,ph); |
390 | splash->show(); | 391 | splash->show(); |
391 | splash->raise(); | 392 | splash->raise(); |
392 | qApp->processEvents(); | 393 | qApp->processEvents(); |
393 | 394 | ||
394 | // set capturer to non-blocking mode | 395 | // set capturer to non-blocking mode |
395 | cap->setBlocking( false ); | 396 | cap->setBlocking( false ); |
396 | 397 | ||
397 | for ( int i = 1; i <= wiface->channels(); ++i ) | 398 | for ( int i = 1; i <= wiface->channels(); ++i ) |
398 | { | 399 | { |
399 | wiface->setChannel( i ); | 400 | wiface->setChannel( i ); |
400 | pb->setProgress( i ); | 401 | pb->setProgress( i ); |
401 | qApp->processEvents(); | 402 | qApp->processEvents(); |
402 | odebug << "rescanNeighbourhood(): listening on channel " << i << "..." << oendl; | 403 | odebug << "rescanNeighbourhood(): listening on channel " << i << "..." << oendl; |
403 | OPacket* p = cap->next( 1000 ); | 404 | OPacket* p = cap->next( 1000 ); |
404 | if ( !p ) | 405 | if ( !p ) |
405 | { | 406 | { |
406 | odebug << "rescanNeighbourhood(): nothing received on channel " << i << "" << oendl; | 407 | odebug << "rescanNeighbourhood(): nothing received on channel " << i << "" << oendl; |
407 | } | 408 | } |
408 | else | 409 | else |
409 | { | 410 | { |
410 | odebug << "rescanNeighbourhood(): TADAA - something came in on channel " << i << "" << oendl; | 411 | odebug << "rescanNeighbourhood(): TADAA - something came in on channel " << i << "" << oendl; |
411 | handlePacket( p ); | 412 | handlePacket( p ); |
412 | } | 413 | } |
413 | } | 414 | } |
414 | 415 | ||
415 | cap->close(); | 416 | cap->close(); |
416 | wiface->setMode( "managed" ); // TODO: use previous mode | 417 | wiface->setMode( "managed" ); // TODO: use previous mode |
417 | wiface->setPromiscuousMode( false ); | 418 | wiface->setPromiscuousMode( false ); |
418 | 419 | ||
420 | // hide splash screen and reenable button | ||
419 | splash->hide(); | 421 | splash->hide(); |
420 | delete splash; | 422 | delete splash; |
421 | 423 | rescanButton->setEnabled( true ); | |
422 | } | 424 | } |
423 | 425 | ||
424 | void WLANImp::handlePacket( OPacket* p ) | 426 | void WLANImp::handlePacket( OPacket* p ) |
425 | { | 427 | { |
426 | 428 | ||
427 | // check if we received a beacon frame | 429 | // check if we received a beacon frame |
428 | OWaveLanManagementPacket* beacon = static_cast<OWaveLanManagementPacket*>( p->child( "802.11 Management" ) ); | 430 | OWaveLanManagementPacket* beacon = static_cast<OWaveLanManagementPacket*>( p->child( "802.11 Management" ) ); |
429 | if ( beacon && beacon->managementType() == "Beacon" ) | 431 | if ( beacon && beacon->managementType() == "Beacon" ) |
430 | { | 432 | { |
431 | 433 | ||
432 | QString type; | 434 | QString type; |
433 | if ( beacon->canIBSS() ) | 435 | if ( beacon->canIBSS() ) |
434 | { | 436 | { |
435 | type = "adhoc"; | 437 | type = "adhoc"; |
436 | } | 438 | } |
437 | else if ( beacon->canESS() ) | 439 | else if ( beacon->canESS() ) |
438 | { | 440 | { |
439 | type = "managed"; | 441 | type = "managed"; |
440 | } | 442 | } |
441 | else | 443 | else |
442 | { | 444 | { |
443 | owarn << "handlePacket(): invalid frame [possibly noise] detected!" << oendl; | 445 | owarn << "handlePacket(): invalid frame [possibly noise] detected!" << oendl; |
444 | return; | 446 | return; |
445 | } | 447 | } |
446 | 448 | ||
447 | OWaveLanManagementSSID* ssid = static_cast<OWaveLanManagementSSID*>( p->child( "802.11 SSID" ) ); | 449 | OWaveLanManagementSSID* ssid = static_cast<OWaveLanManagementSSID*>( p->child( "802.11 SSID" ) ); |
448 | QString essid = ssid ? ssid->ID() : QString("<unknown>"); | 450 | QString essid = ssid ? ssid->ID() : QString("<unknown>"); |
449 | OWaveLanManagementDS* ds = static_cast<OWaveLanManagementDS*>( p->child( "802.11 DS" ) ); | 451 | OWaveLanManagementDS* ds = static_cast<OWaveLanManagementDS*>( p->child( "802.11 DS" ) ); |
450 | int channel = ds ? ds->channel() : -1; | 452 | int channel = ds ? ds->channel() : -1; |
451 | OWaveLanPacket* header = static_cast<OWaveLanPacket*>( p->child( "802.11" ) ); | 453 | OWaveLanPacket* header = static_cast<OWaveLanPacket*>( p->child( "802.11" ) ); |
452 | displayFoundNetwork( type, channel, essid, header->macAddress2() ); | 454 | displayFoundNetwork( type, channel, essid, header->macAddress2() ); |
453 | } | 455 | } |
454 | } | 456 | } |
455 | 457 | ||
456 | 458 | ||
457 | void WLANImp::displayFoundNetwork( const QString& mode, int channel, const QString& ssid, const OMacAddress& mac ) | 459 | void WLANImp::displayFoundNetwork( const QString& mode, int channel, const QString& ssid, const OMacAddress& mac ) |
458 | { | 460 | { |
459 | 461 | ||
460 | odebug << "found network: <" << (const char*) mode << ">, chn " << channel | 462 | odebug << "found network: <" << (const char*) mode << ">, chn " << channel |
461 | << ", ssid '" << (const char*) ssid << "', mac '" << (const char*) mac.toString() << "'" << oendl; | 463 | << ", ssid '" << (const char*) ssid << "', mac '" << (const char*) mac.toString() << "'" << oendl; |
462 | 464 | ||
463 | QListViewItemIterator it( netView ); | 465 | QListViewItemIterator it( netView ); |
464 | while ( it.current() && it.current()->text( col_ssid ) != ssid ) ++it; | 466 | while ( it.current() && it.current()->text( col_ssid ) != ssid ) ++it; |
465 | if ( !it.current() ) // ssid didn't show up yet | 467 | if ( !it.current() ) // ssid didn't show up yet |
466 | { | 468 | { |
467 | QListViewItem* item = new QListViewItem( netView, mode.left( 1 ).upper(), ssid, QString::number( channel ), mac.toString() ); | 469 | QListViewItem* item = new QListViewItem( netView, mode.left( 1 ).upper(), ssid, QString::number( channel ), mac.toString() ); |
468 | QString name; | 470 | QString name; |
469 | name.sprintf( "networksettings/%s", (const char*) mode ); | 471 | name.sprintf( "networksettings/%s", (const char*) mode ); |