summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiecore/oglobalsettings.cpp6
-rw-r--r--libopie2/opienet/onetwork.cpp3
-rw-r--r--libopie2/opienet/onetwork.h8
3 files changed, 13 insertions, 4 deletions
diff --git a/libopie2/opiecore/oglobalsettings.cpp b/libopie2/opiecore/oglobalsettings.cpp
index 184ee69..1799529 100644
--- a/libopie2/opiecore/oglobalsettings.cpp
+++ b/libopie2/opiecore/oglobalsettings.cpp
@@ -283,265 +283,265 @@ QColor OGlobalSettings::calculateAlternateBackgroundColor(const QColor& base)
283 return base.dark(106); 283 return base.dark(106);
284 else if (base != Qt::black) 284 else if (base != Qt::black)
285 return base.light(110); 285 return base.light(110);
286 286
287 return QColor(32,32,32); 287 return QColor(32,32,32);
288 } 288 }
289} 289}
290 290
291QColor OGlobalSettings::linkColor() 291QColor OGlobalSettings::linkColor()
292{ 292{
293 initColors(); 293 initColors();
294 OConfig *c = OGlobal::config(); 294 OConfig *c = OGlobal::config();
295 OConfigGroupSaver cgs( c, QString::fromLatin1("Appearance") ); 295 OConfigGroupSaver cgs( c, QString::fromLatin1("Appearance") );
296 return c->readColorEntry( "linkColor", OpieGray ); 296 return c->readColorEntry( "linkColor", OpieGray );
297} 297}
298 298
299QColor OGlobalSettings::visitedLinkColor() 299QColor OGlobalSettings::visitedLinkColor()
300{ 300{
301 OConfig *c = OGlobal::config(); 301 OConfig *c = OGlobal::config();
302 OConfigGroupSaver cgs( c, QString::fromLatin1("Appearance") ); 302 OConfigGroupSaver cgs( c, QString::fromLatin1("Appearance") );
303 return c->readColorEntry( "visitedLinkColor", &Qt::magenta ); 303 return c->readColorEntry( "visitedLinkColor", &Qt::magenta );
304} 304}
305 305
306// FIXME: font stuff currently uses a different format in OPIE, so the 306// FIXME: font stuff currently uses a different format in OPIE, so the
307// functions below are not yet applicable. The whole font stuff for OPIE 307// functions below are not yet applicable. The whole font stuff for OPIE
308// has to be revised anyway 308// has to be revised anyway
309 309
310QFont OGlobalSettings::generalFont() 310QFont OGlobalSettings::generalFont()
311{ 311{
312 if (_generalFont) 312 if (_generalFont)
313 return *_generalFont; 313 return *_generalFont;
314 314
315 _generalFont = new QFont("helvetica", 10); 315 _generalFont = new QFont("helvetica", 10);
316 _generalFont->setPixelSize(10); 316 _generalFont->setPixelSize(10);
317 _generalFont->setStyleHint(QFont::SansSerif); 317 _generalFont->setStyleHint(QFont::SansSerif);
318 318
319 OConfig *c = OGlobal::config(); 319 OConfig *c = OGlobal::config();
320 OConfigGroupSaver cgs( c, QString::fromLatin1("Appearance") ); 320 OConfigGroupSaver cgs( c, QString::fromLatin1("Appearance") );
321 *_generalFont = c->readFontEntry("font", _generalFont); 321 *_generalFont = c->readFontEntry("font", _generalFont);
322 322
323 return *_generalFont; 323 return *_generalFont;
324} 324}
325 325
326QFont OGlobalSettings::fixedFont() 326QFont OGlobalSettings::fixedFont()
327{ 327{
328 if (_fixedFont) 328 if (_fixedFont)
329 return *_fixedFont; 329 return *_fixedFont;
330 330
331 _fixedFont = new QFont("courier", 12); 331 _fixedFont = new QFont("courier", 12);
332 _fixedFont->setPixelSize(12); 332 _fixedFont->setPixelSize(12);
333 _fixedFont->setStyleHint(QFont::TypeWriter); 333 _fixedFont->setStyleHint(QFont::TypeWriter);
334 334
335 OConfig *c = OGlobal::config(); 335 OConfig *c = OGlobal::config();
336 OConfigGroupSaver cgs( c, QString::fromLatin1("General") ); 336 OConfigGroupSaver cgs( c, QString::fromLatin1("General") );
337 *_fixedFont = c->readFontEntry("fixed", _fixedFont); 337 *_fixedFont = c->readFontEntry("fixed", _fixedFont);
338 338
339 return *_fixedFont; 339 return *_fixedFont;
340} 340}
341 341
342QFont OGlobalSettings::toolBarFont() 342QFont OGlobalSettings::toolBarFont()
343{ 343{
344 if(_toolBarFont) 344 if(_toolBarFont)
345 return *_toolBarFont; 345 return *_toolBarFont;
346 346
347 _toolBarFont = new QFont("helvetica", 10); 347 _toolBarFont = new QFont("helvetica", 10);
348 _toolBarFont->setPixelSize(10); 348 _toolBarFont->setPixelSize(10);
349 _toolBarFont->setStyleHint(QFont::SansSerif); 349 _toolBarFont->setStyleHint(QFont::SansSerif);
350 350
351 OConfig *c = OGlobal::config(); 351 OConfig *c = OGlobal::config();
352 OConfigGroupSaver cgs( c, QString::fromLatin1("General") ); 352 OConfigGroupSaver cgs( c, QString::fromLatin1("General") );
353 *_toolBarFont = c->readFontEntry("toolBarFont", _toolBarFont); 353 *_toolBarFont = c->readFontEntry("toolBarFont", _toolBarFont);
354 354
355 return *_toolBarFont; 355 return *_toolBarFont;
356} 356}
357 357
358QFont OGlobalSettings::menuFont() 358QFont OGlobalSettings::menuFont()
359{ 359{
360 if(_menuFont) 360 if(_menuFont)
361 return *_menuFont; 361 return *_menuFont;
362 362
363 _menuFont = new QFont("helvetica", 12); 363 _menuFont = new QFont("helvetica", 12);
364 _menuFont->setPixelSize(12); 364 _menuFont->setPixelSize(12);
365 _menuFont->setStyleHint(QFont::SansSerif); 365 _menuFont->setStyleHint(QFont::SansSerif);
366 366
367 OConfig *c = OGlobal::config(); 367 OConfig *c = OGlobal::config();
368 OConfigGroupSaver cgs( c, QString::fromLatin1("General") ); 368 OConfigGroupSaver cgs( c, QString::fromLatin1("General") );
369 *_menuFont = c->readFontEntry("menuFont", _menuFont); 369 *_menuFont = c->readFontEntry("menuFont", _menuFont);
370 370
371 return *_menuFont; 371 return *_menuFont;
372} 372}
373 373
374QFont OGlobalSettings::windowTitleFont() 374QFont OGlobalSettings::windowTitleFont()
375{ 375{
376 if(_windowTitleFont) 376 if(_windowTitleFont)
377 return *_windowTitleFont; 377 return *_windowTitleFont;
378 378
379 _windowTitleFont = new QFont("helvetica", 12, QFont::Bold); 379 _windowTitleFont = new QFont("helvetica", 12, QFont::Bold);
380 _windowTitleFont->setPixelSize(12); 380 _windowTitleFont->setPixelSize(12);
381 _windowTitleFont->setStyleHint(QFont::SansSerif); 381 _windowTitleFont->setStyleHint(QFont::SansSerif);
382 382
383 OConfig *c = OGlobal::config(); 383 OConfig *c = OGlobal::config();
384 OConfigGroupSaver cgs( c, QString::fromLatin1("WM") ); 384 OConfigGroupSaver cgs( c, QString::fromLatin1("WM") );
385 *_windowTitleFont = c->readFontEntry("activeFont", _windowTitleFont); // inconsistency 385 *_windowTitleFont = c->readFontEntry("activeFont", _windowTitleFont); // inconsistency
386 386
387 return *_windowTitleFont; 387 return *_windowTitleFont;
388} 388}
389 389
390QFont OGlobalSettings::taskbarFont() 390QFont OGlobalSettings::taskbarFont()
391{ 391{
392 if(_taskbarFont) 392 if(_taskbarFont)
393 return *_taskbarFont; 393 return *_taskbarFont;
394 394
395 _taskbarFont = new QFont("helvetica", 8); 395 _taskbarFont = new QFont("helvetica", 8);
396 _taskbarFont->setPixelSize(8); 396 _taskbarFont->setPixelSize(8);
397 _taskbarFont->setStyleHint(QFont::SansSerif); 397 _taskbarFont->setStyleHint(QFont::SansSerif);
398 398
399 OConfig *c = OGlobal::config(); 399 OConfig *c = OGlobal::config();
400 OConfigGroupSaver cgs( c, QString::fromLatin1("General") ); 400 OConfigGroupSaver cgs( c, QString::fromLatin1("General") );
401 *_taskbarFont = c->readFontEntry("taskbarFont", _taskbarFont); 401 *_taskbarFont = c->readFontEntry("taskbarFont", _taskbarFont);
402 402
403 return *_taskbarFont; 403 return *_taskbarFont;
404} 404}
405 405
406// FIXME: the whole path stuff has to be revised for OPIE 406// FIXME: the whole path stuff has to be revised for OPIE
407 407
408void OGlobalSettings::initStatic() // should be called initPaths(). Don't put anything else here. 408void OGlobalSettings::initStatic() // should be called initPaths(). Don't put anything else here.
409{ 409{
410 if ( s_desktopPath != 0 ) 410 if ( s_desktopPath != 0 )
411 return; 411 return;
412 412
413 s_desktopPath = new QString(); 413 s_desktopPath = new QString();
414 s_autostartPath = new QString(); 414 s_autostartPath = new QString();
415 s_trashPath = new QString(); 415 s_trashPath = new QString();
416 s_documentPath = new QString(); 416 s_documentPath = new QString();
417 417
418 OConfig *config = OGlobal::config(); 418 OConfig *config = OGlobal::config();
419 //bool dollarExpansion = config->isDollarExpansion(); 419 //bool dollarExpansion = config->isDollarExpansion();
420 //config->setDollarExpansion(true); 420 //config->setDollarExpansion(true);
421 OConfigGroupSaver cgs( config, "Paths" ); 421 OConfigGroupSaver cgs( config, "Paths" );
422 422
423 // Desktop Path 423 // Desktop Path
424 *s_desktopPath = QDir::homeDirPath() + "/" + "Desktop" + "/"; 424 *s_desktopPath = QDir::homeDirPath() + "/" + "Desktop" + "/";
425 *s_desktopPath = config->readEntry( "Desktop", *s_desktopPath); 425 *s_desktopPath = config->readEntry( "Desktop", *s_desktopPath);
426 if ( (*s_desktopPath)[0] != '/' ) 426 if ( (*s_desktopPath)[0] != '/' )
427 s_desktopPath->prepend( QDir::homeDirPath() + "/" ); 427 s_desktopPath->prepend( QDir::homeDirPath() + "/" );
428 *s_desktopPath = QDir::cleanDirPath( *s_desktopPath ); 428 *s_desktopPath = QDir::cleanDirPath( *s_desktopPath );
429 if ( s_desktopPath->right(1) != "/") 429 if ( s_desktopPath->right(1) != "/")
430 *s_desktopPath += "/"; 430 *s_desktopPath += "/";
431 431
432 // Trash Path 432 // Trash Path
433 *s_trashPath = *s_desktopPath + QObject::tr("Trash") + "/"; 433 *s_trashPath = *s_desktopPath + QObject::tr("Trash") + "/";
434 *s_trashPath = config->readEntry( "Trash" , *s_trashPath); 434 *s_trashPath = config->readEntry( "Trash" , *s_trashPath);
435 if ( (*s_trashPath)[0] != '/' ) 435 if ( (*s_trashPath)[0] != '/' )
436 s_trashPath->prepend( QDir::homeDirPath() + "/" ); 436 s_trashPath->prepend( QDir::homeDirPath() + "/" );
437 *s_trashPath = QDir::cleanDirPath( *s_trashPath ); 437 *s_trashPath = QDir::cleanDirPath( *s_trashPath );
438 if ( s_trashPath->right(1) != "/") 438 if ( s_trashPath->right(1) != "/")
439 *s_trashPath += "/"; 439 *s_trashPath += "/";
440 // We need to save it in any case, in case the language changes later on, 440 // We need to save it in any case, in case the language changes later on,
441 if ( !config->hasKey( "Trash" ) ) 441 if ( !config->hasKey( "Trash" ) )
442 { 442 {
443 //config->writePathEntry( "Trash", *s_trashPath, true, true ); 443 //config->writePathEntry( "Trash", *s_trashPath, true, true );
444 config->writeEntry( "Trash", *s_trashPath ); 444 config->writeEntry( "Trash", *s_trashPath );
445 //config->sync(); 445 //config->sync();
446 } 446 }
447 447
448/* // Autostart Path 448/* // Autostart Path
449 *s_autostartPath = OGlobal::dirs()->localkdedir() + "Autostart" + "/"; 449 *s_autostartPath = OGlobal::dirs()->localkdedir() + "Autostart" + "/";
450 *s_autostartPath = config->readEntry( "Autostart" , *s_autostartPath); 450 *s_autostartPath = config->readEntry( "Autostart" , *s_autostartPath);
451 if ( (*s_autostartPath)[0] != '/' ) 451 if ( (*s_autostartPath)[0] != '/' )
452 s_autostartPath->prepend( QDir::homeDirPath() + "/" ); 452 s_autostartPath->prepend( QDir::homeDirPath() + "/" );
453 *s_autostartPath = QDir::cleanDirPath( *s_autostartPath ); 453 *s_autostartPath = QDir::cleanDirPath( *s_autostartPath );
454 if ( s_autostartPath->right(1) != "/") 454 if ( s_autostartPath->right(1) != "/")
455 *s_autostartPath += "/"; 455 *s_autostartPath += "/";
456*/ 456*/
457 // Document Path 457 // Document Path
458 *s_documentPath = QString::null; 458 *s_documentPath = QString::null;
459 *s_documentPath = config->readEntry( "Documents" , *s_documentPath); 459 *s_documentPath = config->readEntry( "Documents" , *s_documentPath);
460 if ( (*s_documentPath)[0] != '/' ) 460 if ( (*s_documentPath)[0] != '/' )
461 s_documentPath->prepend( QDir::homeDirPath() + "/" ); 461 s_documentPath->prepend( QDir::homeDirPath() + "/" );
462 *s_documentPath = QDir::cleanDirPath( *s_documentPath ); 462 *s_documentPath = QDir::cleanDirPath( *s_documentPath );
463 if ( s_documentPath->right(1) != "/") 463 if ( s_documentPath->right(1) != "/")
464 *s_documentPath += "/"; 464 *s_documentPath += "/";
465 465
466 //config->setDollarExpansion(dollarExpansion); 466 //config->setDollarExpansion(dollarExpansion);
467 467
468 // Make sure this app gets the notifications about those paths 468 // Make sure this app gets the notifications about those paths
469 //if (kapp) 469 //if (kapp)
470 //kapp->addKipcEventMask(KIPC::SettingsChanged); 470 //kapp->addKipcEventMask(KIPC::SettingsChanged);
471} 471}
472 472
473void OGlobalSettings::initColors() 473void OGlobalSettings::initColors()
474{ 474{
475 if ( not OpieHighlight ) OpieHighlight = new QColor( 156, 118, 32 ); 475 if ( !OpieHighlight ) OpieHighlight = new QColor( 156, 118, 32 );
476 if ( not OpieAlternate ) OpieAlternate = new QColor( 238, 246, 255 ); 476 if ( !OpieAlternate ) OpieAlternate = new QColor( 238, 246, 255 );
477 if ( not OpieGray ) OpieGray = new QColor( 220, 210, 215 ); 477 if ( !OpieGray ) OpieGray = new QColor( 220, 210, 215 );
478} 478}
479 479
480void OGlobalSettings::rereadFontSettings() 480void OGlobalSettings::rereadFontSettings()
481{ 481{
482 delete _generalFont; 482 delete _generalFont;
483 _generalFont = 0L; 483 _generalFont = 0L;
484 delete _fixedFont; 484 delete _fixedFont;
485 _fixedFont = 0L; 485 _fixedFont = 0L;
486 delete _menuFont; 486 delete _menuFont;
487 _menuFont = 0L; 487 _menuFont = 0L;
488 delete _toolBarFont; 488 delete _toolBarFont;
489 _toolBarFont = 0L; 489 _toolBarFont = 0L;
490 delete _windowTitleFont; 490 delete _windowTitleFont;
491 _windowTitleFont = 0L; 491 _windowTitleFont = 0L;
492 delete _taskbarFont; 492 delete _taskbarFont;
493 _taskbarFont = 0L; 493 _taskbarFont = 0L;
494} 494}
495 495
496void OGlobalSettings::rereadPathSettings() 496void OGlobalSettings::rereadPathSettings()
497{ 497{
498 qDebug( "OGlobalSettings::rereadPathSettings" ); 498 qDebug( "OGlobalSettings::rereadPathSettings" );
499 delete s_autostartPath; 499 delete s_autostartPath;
500 s_autostartPath = 0L; 500 s_autostartPath = 0L;
501 delete s_trashPath; 501 delete s_trashPath;
502 s_trashPath = 0L; 502 s_trashPath = 0L;
503 delete s_desktopPath; 503 delete s_desktopPath;
504 s_desktopPath = 0L; 504 s_desktopPath = 0L;
505 delete s_documentPath; 505 delete s_documentPath;
506 s_documentPath = 0L; 506 s_documentPath = 0L;
507} 507}
508 508
509OGlobalSettings::OMouseSettings & OGlobalSettings::mouseSettings() 509OGlobalSettings::OMouseSettings & OGlobalSettings::mouseSettings()
510{ 510{
511 if ( ! s_mouseSettings ) 511 if ( ! s_mouseSettings )
512 { 512 {
513 s_mouseSettings = new OMouseSettings; 513 s_mouseSettings = new OMouseSettings;
514 OMouseSettings & s = *s_mouseSettings; // for convenience 514 OMouseSettings & s = *s_mouseSettings; // for convenience
515 515
516 OConfigGroupSaver cgs( OGlobal::config(), "Mouse" ); 516 OConfigGroupSaver cgs( OGlobal::config(), "Mouse" );
517 QString setting = OGlobal::config()->readEntry("MouseButtonMapping"); 517 QString setting = OGlobal::config()->readEntry("MouseButtonMapping");
518 if (setting == "RightHanded") 518 if (setting == "RightHanded")
519 s.handed = OMouseSettings::RightHanded; 519 s.handed = OMouseSettings::RightHanded;
520 else if (setting == "LeftHanded") 520 else if (setting == "LeftHanded")
521 s.handed = OMouseSettings::LeftHanded; 521 s.handed = OMouseSettings::LeftHanded;
522 else 522 else
523 { 523 {
524 524
525 // FIXME: Implement for Opie / Qt Embedded 525 // FIXME: Implement for Opie / Qt Embedded
526 526
527 } 527 }
528 } 528 }
529 return *s_mouseSettings; 529 return *s_mouseSettings;
530} 530}
531 531
532void OGlobalSettings::rereadMouseSettings() 532void OGlobalSettings::rereadMouseSettings()
533{ 533{
534 delete s_mouseSettings; 534 delete s_mouseSettings;
535 s_mouseSettings = 0L; 535 s_mouseSettings = 0L;
536} 536}
537 537
538// FIXME: This won't be necessary, or will it? :-D 538// FIXME: This won't be necessary, or will it? :-D
539 539
540bool OGlobalSettings::isMultiHead() 540bool OGlobalSettings::isMultiHead()
541{ 541{
542 QCString multiHead = getenv("OPIE_MULTIHEAD"); 542 QCString multiHead = getenv("OPIE_MULTIHEAD");
543 if (!multiHead.isEmpty()) { 543 if (!multiHead.isEmpty()) {
544 return (multiHead.lower() == "true"); 544 return (multiHead.lower() == "true");
545 } 545 }
546 return false; 546 return false;
547} 547}
diff --git a/libopie2/opienet/onetwork.cpp b/libopie2/opienet/onetwork.cpp
index 25c70e0..998b50e 100644
--- a/libopie2/opienet/onetwork.cpp
+++ b/libopie2/opienet/onetwork.cpp
@@ -1,245 +1,246 @@
1/* 1/*
2                 This file is part of the Opie Project 2                 This file is part of the Opie Project
3              Copyright (C) 2003 by the Wellenreiter team: 3              Copyright (C) 2003 by the Wellenreiter team:
4 Martin J. Muench <mjm@remote-exploit.org> 4 Martin J. Muench <mjm@remote-exploit.org>
5 Max Moser <mmo@remote-exploit.org 5 Max Moser <mmo@remote-exploit.org
6 Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> 6 Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de>
7 =. 7 =.
8 .=l. 8 .=l.
9           .>+-= 9           .>+-=
10 _;:,     .>    :=|. This program is free software; you can 10 _;:,     .>    :=|. This program is free software; you can
11.> <`_,   >  .   <= redistribute it and/or modify it under 11.> <`_,   >  .   <= redistribute it and/or modify it under
12:`=1 )Y*s>-.--   : the terms of the GNU Library General Public 12:`=1 )Y*s>-.--   : the terms of the GNU Library General Public
13.="- .-=="i,     .._ License as published by the Free Software 13.="- .-=="i,     .._ License as published by the Free Software
14 - .   .-<_>     .<> Foundation; either version 2 of the License, 14 - .   .-<_>     .<> Foundation; either version 2 of the License,
15     ._= =}       : or (at your option) any later version. 15     ._= =}       : or (at your option) any later version.
16    .%`+i>       _;_. 16    .%`+i>       _;_.
17    .i_,=:_.      -<s. This program is distributed in the hope that 17    .i_,=:_.      -<s. This program is distributed in the hope that
18     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY; 18     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY;
19    : ..    .:,     . . . without even the implied warranty of 19    : ..    .:,     . . . without even the implied warranty of
20    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A 20    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A
21  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU 21  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU
22..}^=.=       =       ; Library General Public License for more 22..}^=.=       =       ; Library General Public License for more
23++=   -.     .`     .: details. 23++=   -.     .`     .: details.
24 :     =  ...= . :.=- 24 :     =  ...= . :.=-
25 -.   .:....=;==+<; You should have received a copy of the GNU 25 -.   .:....=;==+<; You should have received a copy of the GNU
26  -_. . .   )=.  = Library General Public License along with 26  -_. . .   )=.  = Library General Public License along with
27    --        :-=` this library; see the file COPYING.LIB. 27    --        :-=` this library; see the file COPYING.LIB.
28 If not, write to the Free Software Foundation, 28 If not, write to the Free Software Foundation,
29 Inc., 59 Temple Place - Suite 330, 29 Inc., 59 Temple Place - Suite 330,
30 Boston, MA 02111-1307, USA. 30 Boston, MA 02111-1307, USA.
31 31
32*/ 32*/
33 33
34/* OPIE */ 34/* OPIE */
35 35
36#include <opie2/onetwork.h> 36#include <opie2/onetwork.h>
37 37
38/* QT */ 38/* QT */
39 39
40#include <qfile.h> 40#include <qfile.h>
41#include <qtextstream.h> 41#include <qtextstream.h>
42 42
43/* UNIX */ 43/* UNIX */
44 44
45#include <arpa/inet.h> 45#include <arpa/inet.h>
46#include <cerrno> 46#include <cerrno>
47#include <cstring> 47#include <cstring>
48#include <cstdlib> 48#include <cstdlib>
49#include <math.h> 49#include <math.h>
50#include <sys/ioctl.h> 50#include <sys/ioctl.h>
51#include <sys/socket.h> 51#include <sys/socket.h>
52#include <sys/types.h> 52#include <sys/types.h>
53#include <unistd.h> 53#include <unistd.h>
54#include <linux/sockios.h>
54#include <linux/wireless.h> 55#include <linux/wireless.h>
55 56
56using namespace std; 57using namespace std;
57 58
58/*====================================================================================== 59/*======================================================================================
59 * ONetwork 60 * ONetwork
60 *======================================================================================*/ 61 *======================================================================================*/
61 62
62ONetwork* ONetwork::_instance = 0; 63ONetwork* ONetwork::_instance = 0;
63 64
64ONetwork::ONetwork() 65ONetwork::ONetwork()
65{ 66{
66 qDebug( "ONetwork::ONetwork()" ); 67 qDebug( "ONetwork::ONetwork()" );
67 synchronize(); 68 synchronize();
68} 69}
69 70
70void ONetwork::synchronize() 71void ONetwork::synchronize()
71{ 72{
72 // gather available interfaces by inspecting /proc/net/dev 73 // gather available interfaces by inspecting /proc/net/dev
73 // we could use SIOCGIFCONF here, but we aren't interested in virtual (e.g. eth0:0) devices 74 // we could use SIOCGIFCONF here, but we aren't interested in virtual (e.g. eth0:0) devices
74 75
75 _interfaces.clear(); 76 _interfaces.clear();
76 QString str; 77 QString str;
77 QFile f( "/proc/net/dev" ); 78 QFile f( "/proc/net/dev" );
78 bool hasFile = f.open( IO_ReadOnly ); 79 bool hasFile = f.open( IO_ReadOnly );
79 if ( !hasFile ) 80 if ( !hasFile )
80 { 81 {
81 qDebug( "ONetwork: /proc/net/dev not existing. No network devices available" ); 82 qDebug( "ONetwork: /proc/net/dev not existing. No network devices available" );
82 return; 83 return;
83 } 84 }
84 QTextStream s( &f ); 85 QTextStream s( &f );
85 s.readLine(); 86 s.readLine();
86 s.readLine(); 87 s.readLine();
87 while ( !s.atEnd() ) 88 while ( !s.atEnd() )
88 { 89 {
89 s >> str; 90 s >> str;
90 str.truncate( str.find( ':' ) ); 91 str.truncate( str.find( ':' ) );
91 qDebug( "ONetwork: found interface '%s'", (const char*) str ); 92 qDebug( "ONetwork: found interface '%s'", (const char*) str );
92 ONetworkInterface* iface; 93 ONetworkInterface* iface;
93 if ( isWirelessInterface( str ) ) 94 if ( isWirelessInterface( str ) )
94 { 95 {
95 iface = new OWirelessNetworkInterface( str ); 96 iface = new OWirelessNetworkInterface( str );
96 qDebug( "ONetwork: interface '%s' has Wireless Extensions", (const char*) str ); 97 qDebug( "ONetwork: interface '%s' has Wireless Extensions", (const char*) str );
97 } 98 }
98 else 99 else
99 { 100 {
100 iface = new ONetworkInterface( str ); 101 iface = new ONetworkInterface( str );
101 } 102 }
102 _interfaces.insert( str, iface ); 103 _interfaces.insert( str, iface );
103 s.readLine(); 104 s.readLine();
104 } 105 }
105} 106}
106 107
107 108
108ONetworkInterface* ONetwork::interface( QString iface ) const 109ONetworkInterface* ONetwork::interface( QString iface ) const
109{ 110{
110 return _interfaces[iface]; 111 return _interfaces[iface];
111} 112}
112 113
113 114
114ONetwork* ONetwork::instance() 115ONetwork* ONetwork::instance()
115{ 116{
116 if ( !_instance ) _instance = new ONetwork(); 117 if ( !_instance ) _instance = new ONetwork();
117 return _instance; 118 return _instance;
118} 119}
119 120
120 121
121ONetwork::InterfaceIterator ONetwork::iterator() const 122ONetwork::InterfaceIterator ONetwork::iterator() const
122{ 123{
123 return ONetwork::InterfaceIterator( _interfaces ); 124 return ONetwork::InterfaceIterator( _interfaces );
124} 125}
125 126
126 127
127bool ONetwork::isWirelessInterface( const char* name ) const 128bool ONetwork::isWirelessInterface( const char* name ) const
128{ 129{
129 int sfd = socket( AF_INET, SOCK_DGRAM, 0 ); 130 int sfd = socket( AF_INET, SOCK_DGRAM, 0 );
130 iwreqstruct iwr; 131 iwreqstruct iwr;
131 memset( &iwr, 0, sizeof( iwreqstruct ) ); 132 memset( &iwr, 0, sizeof( iwreqstruct ) );
132 strcpy( (char*) &iwr.ifr_name, name ); 133 strcpy( (char*) &iwr.ifr_name, name );
133 int result = ::ioctl( sfd, SIOCGIWNAME, &iwr ); 134 int result = ::ioctl( sfd, SIOCGIWNAME, &iwr );
134 if ( result == -1 ) 135 if ( result == -1 )
135 qDebug( "ONetwork::ioctl(): SIOCGIWNAME failed: %d (%s)", result, strerror( errno ) ); 136 qDebug( "ONetwork::ioctl(): SIOCGIWNAME failed: %d (%s)", result, strerror( errno ) );
136 else 137 else
137 qDebug( "ONetwork::ioctl(): SIOCGIWNAME ok." ); 138 qDebug( "ONetwork::ioctl(): SIOCGIWNAME ok." );
138 return ( result != -1 ); 139 return ( result != -1 );
139} 140}
140 141
141/*====================================================================================== 142/*======================================================================================
142 * ONetworkInterface 143 * ONetworkInterface
143 *======================================================================================*/ 144 *======================================================================================*/
144 145
145ONetworkInterface::ONetworkInterface( const QString& name ) 146ONetworkInterface::ONetworkInterface( const QString& name )
146 :_name( name ), _sfd( socket( AF_INET, SOCK_DGRAM, 0 ) ), _mon( 0 ) 147 :_name( name ), _sfd( socket( AF_INET, SOCK_DGRAM, 0 ) ), _mon( 0 )
147{ 148{
148 qDebug( "ONetworkInterface::ONetworkInterface()" ); 149 qDebug( "ONetworkInterface::ONetworkInterface()" );
149 init(); 150 init();
150} 151}
151 152
152 153
153ifreqstruct& ONetworkInterface::ifr() const 154ifreqstruct& ONetworkInterface::ifr() const
154{ 155{
155 return _ifr; 156 return _ifr;
156} 157}
157 158
158 159
159void ONetworkInterface::init() 160void ONetworkInterface::init()
160{ 161{
161 qDebug( "ONetworkInterface::init()" ); 162 qDebug( "ONetworkInterface::init()" );
162 163
163 memset( &_ifr, 0, sizeof( struct ifreq ) ); 164 memset( &_ifr, 0, sizeof( struct ifreq ) );
164 165
165 if ( _sfd == -1 ) 166 if ( _sfd == -1 )
166 { 167 {
167 qDebug( "ONetworkInterface::init(): Warning - can't get socket for device '%s'", (const char*) _name ); 168 qDebug( "ONetworkInterface::init(): Warning - can't get socket for device '%s'", (const char*) _name );
168 return; 169 return;
169 } 170 }
170} 171}
171 172
172 173
173bool ONetworkInterface::ioctl( int call, ifreqstruct& ifreq ) const 174bool ONetworkInterface::ioctl( int call, ifreqstruct& ifreq ) const
174{ 175{
175 int result = ::ioctl( _sfd, call, &ifreq ); 176 int result = ::ioctl( _sfd, call, &ifreq );
176 if ( result == -1 ) 177 if ( result == -1 )
177 qDebug( "ONetworkInterface::ioctl(): Call %d - Status: Failed: %d (%s)", call, result, strerror( errno ) ); 178 qDebug( "ONetworkInterface::ioctl(): Call %d - Status: Failed: %d (%s)", call, result, strerror( errno ) );
178 else 179 else
179 qDebug( "ONetworkInterface::ioctl(): Call %d - Status: Ok.", call ); 180 qDebug( "ONetworkInterface::ioctl(): Call %d - Status: Ok.", call );
180 return ( result != -1 ); 181 return ( result != -1 );
181} 182}
182 183
183 184
184bool ONetworkInterface::ioctl( int call ) const 185bool ONetworkInterface::ioctl( int call ) const
185{ 186{
186 strcpy( _ifr.ifr_name, (const char*) _name ); 187 strcpy( _ifr.ifr_name, (const char*) _name );
187 return ioctl( call, _ifr ); 188 return ioctl( call, _ifr );
188} 189}
189 190
190 191
191bool ONetworkInterface::isLoopback() const 192bool ONetworkInterface::isLoopback() const
192{ 193{
193 ioctl( SIOCGIFFLAGS ); 194 ioctl( SIOCGIFFLAGS );
194 return _ifr.ifr_flags & IFF_LOOPBACK; 195 return _ifr.ifr_flags & IFF_LOOPBACK;
195} 196}
196 197
197 198
198bool ONetworkInterface::setUp( bool b ) 199bool ONetworkInterface::setUp( bool b )
199{ 200{
200 ioctl( SIOCGIFFLAGS ); 201 ioctl( SIOCGIFFLAGS );
201 if ( b ) _ifr.ifr_flags |= IFF_UP; 202 if ( b ) _ifr.ifr_flags |= IFF_UP;
202 else _ifr.ifr_flags &= (~IFF_UP); 203 else _ifr.ifr_flags &= (~IFF_UP);
203 return ioctl( SIOCSIFFLAGS ); 204 return ioctl( SIOCSIFFLAGS );
204} 205}
205 206
206 207
207bool ONetworkInterface::isUp() const 208bool ONetworkInterface::isUp() const
208{ 209{
209 ioctl( SIOCGIFFLAGS ); 210 ioctl( SIOCGIFFLAGS );
210 return _ifr.ifr_flags & IFF_UP; 211 return _ifr.ifr_flags & IFF_UP;
211} 212}
212 213
213 214
214QString ONetworkInterface::ipV4Address() const 215QString ONetworkInterface::ipV4Address() const
215{ 216{
216 if ( ioctl( SIOCGIFADDR ) ) 217 if ( ioctl( SIOCGIFADDR ) )
217 { 218 {
218 struct sockaddr_in *sa = (struct sockaddr_in *) &_ifr.ifr_addr; 219 struct sockaddr_in *sa = (struct sockaddr_in *) &_ifr.ifr_addr;
219 //FIXME: Use QHostAddress here 220 //FIXME: Use QHostAddress here
220 return QString( inet_ntoa( sa->sin_addr ) ); 221 return QString( inet_ntoa( sa->sin_addr ) );
221 } 222 }
222 else 223 else
223 return "<unknown>"; 224 return "<unknown>";
224} 225}
225 226
226 227
227OMacAddress ONetworkInterface::macAddress() const 228OMacAddress ONetworkInterface::macAddress() const
228{ 229{
229 if ( ioctl( SIOCGIFHWADDR ) ) 230 if ( ioctl( SIOCGIFHWADDR ) )
230 { 231 {
231 return OMacAddress( _ifr ); 232 return OMacAddress( _ifr );
232 } 233 }
233 else 234 else
234 { 235 {
235 return OMacAddress::unknown; 236 return OMacAddress::unknown;
236 } 237 }
237} 238}
238 239
239 240
240void ONetworkInterface::setMonitoring( OMonitoringInterface* m ) 241void ONetworkInterface::setMonitoring( OMonitoringInterface* m )
241{ 242{
242 _mon = m; 243 _mon = m;
243 qDebug( "ONetwork::setMonitoring(): Installed monitoring interface '%s'", (const char*) m->name() ); 244 qDebug( "ONetwork::setMonitoring(): Installed monitoring interface '%s'", (const char*) m->name() );
244} 245}
245 246
@@ -536,257 +537,257 @@ QString OWirelessNetworkInterface::SSID() const
536} 537}
537 538
538 539
539void OWirelessNetworkInterface::setSSID( const QString& ssid ) 540void OWirelessNetworkInterface::setSSID( const QString& ssid )
540{ 541{
541 _iwr.u.essid.pointer = const_cast<char*>( (const char*) ssid ); 542 _iwr.u.essid.pointer = const_cast<char*>( (const char*) ssid );
542 _iwr.u.essid.length = ssid.length(); 543 _iwr.u.essid.length = ssid.length();
543 wioctl( SIOCSIWESSID ); 544 wioctl( SIOCSIWESSID );
544} 545}
545 546
546 547
547bool OWirelessNetworkInterface::wioctl( int call, iwreqstruct& iwreq ) const 548bool OWirelessNetworkInterface::wioctl( int call, iwreqstruct& iwreq ) const
548{ 549{
549 int result = ::ioctl( _sfd, call, &iwreq ); 550 int result = ::ioctl( _sfd, call, &iwreq );
550 if ( result == -1 ) 551 if ( result == -1 )
551 qDebug( "ONetworkInterface::wioctl(): Call %d - Status: Failed: %d (%s)", call, result, strerror( errno ) ); 552 qDebug( "ONetworkInterface::wioctl(): Call %d - Status: Failed: %d (%s)", call, result, strerror( errno ) );
552 else 553 else
553 qDebug( "ONetworkInterface::wioctl(): Call %d - Status: Ok.", call ); 554 qDebug( "ONetworkInterface::wioctl(): Call %d - Status: Ok.", call );
554 return ( result != -1 ); 555 return ( result != -1 );
555} 556}
556 557
557 558
558bool OWirelessNetworkInterface::wioctl( int call ) const 559bool OWirelessNetworkInterface::wioctl( int call ) const
559{ 560{
560 strcpy( _iwr.ifr_name, (const char*) _name ); 561 strcpy( _iwr.ifr_name, (const char*) _name );
561 return wioctl( call, _iwr ); 562 return wioctl( call, _iwr );
562} 563}
563 564
564 565
565/*====================================================================================== 566/*======================================================================================
566 * OMonitoringInterface 567 * OMonitoringInterface
567 *======================================================================================*/ 568 *======================================================================================*/
568 569
569OMonitoringInterface::OMonitoringInterface( ONetworkInterface* iface ) 570OMonitoringInterface::OMonitoringInterface( ONetworkInterface* iface )
570 :_enabled( false ), _if( static_cast<OWirelessNetworkInterface*>( iface ) ) 571 :_enabled( false ), _if( static_cast<OWirelessNetworkInterface*>( iface ) )
571{ 572{
572} 573}
573 574
574 575
575OMonitoringInterface::~OMonitoringInterface() 576OMonitoringInterface::~OMonitoringInterface()
576{ 577{
577} 578}
578 579
579 580
580void OMonitoringInterface::setChannel( int c ) 581void OMonitoringInterface::setChannel( int c )
581{ 582{
582 // use standard WE channel switching protocol 583 // use standard WE channel switching protocol
583 memset( &_if->_iwr, 0, sizeof( iwreqstruct ) ); 584 memset( &_if->_iwr, 0, sizeof( iwreqstruct ) );
584 _if->_iwr.u.freq.m = c; 585 _if->_iwr.u.freq.m = c;
585 _if->_iwr.u.freq.e = 0; 586 _if->_iwr.u.freq.e = 0;
586 _if->wioctl( SIOCSIWFREQ ); 587 _if->wioctl( SIOCSIWFREQ );
587} 588}
588 589
589 590
590bool OMonitoringInterface::enabled() const 591bool OMonitoringInterface::enabled() const
591{ 592{
592 return _enabled; 593 return _enabled;
593} 594}
594 595
595void OMonitoringInterface::setEnabled( bool b ) 596void OMonitoringInterface::setEnabled( bool b )
596{ 597{
597 // open a packet capturer here or leave this to 598 // open a packet capturer here or leave this to
598 // the client code? 599 // the client code?
599 600
600 /* 601 /*
601 602
602 if ( b ) 603 if ( b )
603 { 604 {
604 OPacketCapturer* opcap = new OPacketCapturer(); 605 OPacketCapturer* opcap = new OPacketCapturer();
605 opcap->open( _if->name() ); 606 opcap->open( _if->name() );
606 } 607 }
607 */ 608 */
608 609
609 _enabled = b; 610 _enabled = b;
610 611
611} 612}
612 613
613/*====================================================================================== 614/*======================================================================================
614 * OCiscoMonitoringInterface 615 * OCiscoMonitoringInterface
615 *======================================================================================*/ 616 *======================================================================================*/
616 617
617OCiscoMonitoringInterface::OCiscoMonitoringInterface( ONetworkInterface* iface ) 618OCiscoMonitoringInterface::OCiscoMonitoringInterface( ONetworkInterface* iface )
618 :OMonitoringInterface( iface ) 619 :OMonitoringInterface( iface )
619{ 620{
620 iface->setMonitoring( this ); 621 iface->setMonitoring( this );
621} 622}
622 623
623 624
624OCiscoMonitoringInterface::~OCiscoMonitoringInterface() 625OCiscoMonitoringInterface::~OCiscoMonitoringInterface()
625{ 626{
626} 627}
627 628
628 629
629void OCiscoMonitoringInterface::setEnabled( bool b ) 630void OCiscoMonitoringInterface::setEnabled( bool b )
630{ 631{
631 QString fname; 632 QString fname;
632 fname.sprintf( "/proc/driver/aironet/%s", (const char*) _if->name() ); 633 fname.sprintf( "/proc/driver/aironet/%s", (const char*) _if->name() );
633 QFile f( fname ); 634 QFile f( fname );
634 if ( !f.exists() ) return; 635 if ( !f.exists() ) return;
635 636
636 if ( f.open( IO_WriteOnly ) ) 637 if ( f.open( IO_WriteOnly ) )
637 { 638 {
638 QTextStream s( &f ); 639 QTextStream s( &f );
639 s << "Mode: r"; 640 s << "Mode: r";
640 s << "Mode: y"; 641 s << "Mode: y";
641 s << "XmitPower: 1"; 642 s << "XmitPower: 1";
642 643
643 OMonitoringInterface::setEnabled( b ); 644 OMonitoringInterface::setEnabled( b );
644 645
645 } 646 }
646 647
647 // flushing and closing will be done automatically when f goes out of scope 648 // flushing and closing will be done automatically when f goes out of scope
648} 649}
649 650
650 651
651QString OCiscoMonitoringInterface::name() const 652QString OCiscoMonitoringInterface::name() const
652{ 653{
653 return "cisco"; 654 return "cisco";
654} 655}
655 656
656 657
657void OCiscoMonitoringInterface::setChannel( int ) 658void OCiscoMonitoringInterface::setChannel( int )
658{ 659{
659 // cisco devices automatically switch channels when in monitor mode 660 // cisco devices automatically switch channels when in monitor mode
660} 661}
661 662
662 663
663/*====================================================================================== 664/*======================================================================================
664 * OWlanNGMonitoringInterface 665 * OWlanNGMonitoringInterface
665 *======================================================================================*/ 666 *======================================================================================*/
666 667
667 668
668OWlanNGMonitoringInterface::OWlanNGMonitoringInterface( ONetworkInterface* iface ) 669OWlanNGMonitoringInterface::OWlanNGMonitoringInterface( ONetworkInterface* iface )
669 :OMonitoringInterface( iface ) 670 :OMonitoringInterface( iface )
670{ 671{
671 iface->setMonitoring( this ); 672 iface->setMonitoring( this );
672} 673}
673 674
674 675
675OWlanNGMonitoringInterface::~OWlanNGMonitoringInterface() 676OWlanNGMonitoringInterface::~OWlanNGMonitoringInterface()
676{ 677{
677} 678}
678 679
679 680
680void OWlanNGMonitoringInterface::setEnabled( bool b ) 681void OWlanNGMonitoringInterface::setEnabled( bool b )
681{ 682{
682 //FIXME: do nothing if its already in the same mode 683 //FIXME: do nothing if its already in the same mode
683 684
684 QString enable = b ? "true" : "false"; 685 QString enable = b ? "true" : "false";
685 QString cmd; 686 QString cmd;
686 cmd.sprintf( "$(which wlanctl-ng) %s lnxreq_wlansniff channel=%d enable=%s", (const char*) _if->name(), 1, (const char*) enable ); 687 cmd.sprintf( "$(which wlanctl-ng) %s lnxreq_wlansniff channel=%d enable=%s", (const char*) _if->name(), 1, (const char*) enable );
687 system( cmd ); 688 system( cmd );
688 689
689 OMonitoringInterface::setEnabled( b ); 690 OMonitoringInterface::setEnabled( b );
690} 691}
691 692
692 693
693QString OWlanNGMonitoringInterface::name() const 694QString OWlanNGMonitoringInterface::name() const
694{ 695{
695 return "wlan-ng"; 696 return "wlan-ng";
696} 697}
697 698
698 699
699void OWlanNGMonitoringInterface::setChannel( int ) 700void OWlanNGMonitoringInterface::setChannel( int )
700{ 701{
701 // wlan-ng devices automatically switch channels when in monitor mode 702 // wlan-ng devices automatically switch channels when in monitor mode
702} 703}
703 704
704 705
705/*====================================================================================== 706/*======================================================================================
706 * OHostAPMonitoringInterface 707 * OHostAPMonitoringInterface
707 *======================================================================================*/ 708 *======================================================================================*/
708 709
709OHostAPMonitoringInterface::OHostAPMonitoringInterface( ONetworkInterface* iface ) 710OHostAPMonitoringInterface::OHostAPMonitoringInterface( ONetworkInterface* iface )
710 :OMonitoringInterface( iface ) 711 :OMonitoringInterface( iface )
711{ 712{
712 iface->setMonitoring( this ); 713 iface->setMonitoring( this );
713} 714}
714 715
715OHostAPMonitoringInterface::~OHostAPMonitoringInterface() 716OHostAPMonitoringInterface::~OHostAPMonitoringInterface()
716{ 717{
717} 718}
718 719
719void OHostAPMonitoringInterface::setEnabled( bool b ) 720void OHostAPMonitoringInterface::setEnabled( bool b )
720{ 721{
721 // IW_MODE_MONITOR was introduced in Wireless Extensions Version 15 722 // IW_MODE_MONITOR was introduced in Wireless Extensions Version 15
722 // Wireless Extensions < Version 15 need iwpriv commandos for monitoring 723 // Wireless Extensions < Version 15 need iwpriv commandos for monitoring
723 724
724 #if WIRELESS_EXT > 14 725 #if WIRELESS_EXT > 14
725 _if->_iwr.u.mode = IW_MODE_MONITOR; 726 _if->_iwr.u.mode = IW_MODE_MONITOR;
726 _if->wioctl( SIOCSIWMODE ); 727 _if->wioctl( SIOCSIWMODE );
727 #else 728 #else
728 int* args = (int*) &_if._iwr.u.name; 729 int* args = (int*) &_if->_iwr.u.name;
729 args[0] = 2; 730 args[0] = 2;
730 args[1] = 0; 731 args[1] = 0;
731 _if->wioctl( SIOCDEVPRIVATE ); 732 _if->wioctl( SIOCDEVPRIVATE );
732 #endif 733 #endif
733 734
734 OMonitoringInterface::setEnabled( b ); 735 OMonitoringInterface::setEnabled( b );
735} 736}
736 737
737 738
738QString OHostAPMonitoringInterface::name() const 739QString OHostAPMonitoringInterface::name() const
739{ 740{
740 return "hostap"; 741 return "hostap";
741} 742}
742 743
743 744
744/*====================================================================================== 745/*======================================================================================
745 * OOrinocoNetworkInterface 746 * OOrinocoNetworkInterface
746 *======================================================================================*/ 747 *======================================================================================*/
747 748
748OOrinocoMonitoringInterface::OOrinocoMonitoringInterface( ONetworkInterface* iface ) 749OOrinocoMonitoringInterface::OOrinocoMonitoringInterface( ONetworkInterface* iface )
749 :OMonitoringInterface( iface ) 750 :OMonitoringInterface( iface )
750{ 751{
751 iface->setMonitoring( this ); 752 iface->setMonitoring( this );
752} 753}
753 754
754 755
755OOrinocoMonitoringInterface::~OOrinocoMonitoringInterface() 756OOrinocoMonitoringInterface::~OOrinocoMonitoringInterface()
756{ 757{
757} 758}
758 759
759 760
760void OOrinocoMonitoringInterface::setChannel( int c ) 761void OOrinocoMonitoringInterface::setChannel( int c )
761{ 762{
762 // call iwpriv <device> monitor 2 <channel> 763 // call iwpriv <device> monitor 2 <channel>
763 int* args = (int*) &_if->_iwr.u.name; 764 int* args = (int*) &_if->_iwr.u.name;
764 args[0] = 2; 765 args[0] = 2;
765 args[1] = c; 766 args[1] = c;
766 _if->wioctl( SIOCIWFIRSTPRIV + 0x8 ); 767 _if->wioctl( SIOCIWFIRSTPRIV + 0x8 );
767} 768}
768 769
769 770
770void OOrinocoMonitoringInterface::setEnabled( bool b ) 771void OOrinocoMonitoringInterface::setEnabled( bool b )
771{ 772{
772 if ( b ) 773 if ( b )
773 { 774 {
774 setChannel( 1 ); 775 setChannel( 1 );
775 } 776 }
776 else 777 else
777 { 778 {
778 // call iwpriv <device> monitor 0 0 779 // call iwpriv <device> monitor 0 0
779 int* args = (int*) &_if->_iwr.u.name; 780 int* args = (int*) &_if->_iwr.u.name;
780 args[0] = 0; 781 args[0] = 0;
781 args[1] = 0; 782 args[1] = 0;
782 _if->wioctl( SIOCIWFIRSTPRIV + 0x8 ); 783 _if->wioctl( SIOCIWFIRSTPRIV + 0x8 );
783 } 784 }
784 785
785 OMonitoringInterface::setEnabled( b ); 786 OMonitoringInterface::setEnabled( b );
786} 787}
787 788
788 789
789QString OOrinocoMonitoringInterface::name() const 790QString OOrinocoMonitoringInterface::name() const
790{ 791{
791 return "orinoco"; 792 return "orinoco";
792} 793}
diff --git a/libopie2/opienet/onetwork.h b/libopie2/opienet/onetwork.h
index 936ac85..56da5f4 100644
--- a/libopie2/opienet/onetwork.h
+++ b/libopie2/opienet/onetwork.h
@@ -1,246 +1,254 @@
1/* 1/*
2                 This file is part of the Opie Project 2                 This file is part of the Opie Project
3              Copyright (C) 2003 by the Wellenreiter team: 3              Copyright (C) 2003 by the Wellenreiter team:
4 Martin J. Muench <mjm@remote-exploit.org> 4 Martin J. Muench <mjm@remote-exploit.org>
5 Max Moser <mmo@remote-exploit.org 5 Max Moser <mmo@remote-exploit.org
6 Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> 6 Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de>
7 =. 7 =.
8 .=l. 8 .=l.
9           .>+-= 9           .>+-=
10 _;:,     .>    :=|. This program is free software; you can 10 _;:,     .>    :=|. This program is free software; you can
11.> <`_,   >  .   <= redistribute it and/or modify it under 11.> <`_,   >  .   <= redistribute it and/or modify it under
12:`=1 )Y*s>-.--   : the terms of the GNU Library General Public 12:`=1 )Y*s>-.--   : the terms of the GNU Library General Public
13.="- .-=="i,     .._ License as published by the Free Software 13.="- .-=="i,     .._ License as published by the Free Software
14 - .   .-<_>     .<> Foundation; either version 2 of the License, 14 - .   .-<_>     .<> Foundation; either version 2 of the License,
15     ._= =}       : or (at your option) any later version. 15     ._= =}       : or (at your option) any later version.
16    .%`+i>       _;_. 16    .%`+i>       _;_.
17    .i_,=:_.      -<s. This program is distributed in the hope that 17    .i_,=:_.      -<s. This program is distributed in the hope that
18     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY; 18     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY;
19    : ..    .:,     . . . without even the implied warranty of 19    : ..    .:,     . . . without even the implied warranty of
20    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A 20    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A
21  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU 21  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU
22..}^=.=       =       ; Library General Public License for more 22..}^=.=       =       ; Library General Public License for more
23++=   -.     .`     .: details. 23++=   -.     .`     .: details.
24 :     =  ...= . :.=- 24 :     =  ...= . :.=-
25 -.   .:....=;==+<; You should have received a copy of the GNU 25 -.   .:....=;==+<; You should have received a copy of the GNU
26  -_. . .   )=.  = Library General Public License along with 26  -_. . .   )=.  = Library General Public License along with
27    --        :-=` this library; see the file COPYING.LIB. 27    --        :-=` this library; see the file COPYING.LIB.
28 If not, write to the Free Software Foundation, 28 If not, write to the Free Software Foundation,
29 Inc., 59 Temple Place - Suite 330, 29 Inc., 59 Temple Place - Suite 330,
30 Boston, MA 02111-1307, USA. 30 Boston, MA 02111-1307, USA.
31 31
32*/ 32*/
33 33
34#ifndef ONETWORK_H 34#ifndef ONETWORK_H
35#define ONETWORK_H 35#define ONETWORK_H
36 36
37/* QT */ 37/* QT */
38 38
39#include <qdict.h> 39#include <qdict.h>
40#include <qmap.h> 40#include <qmap.h>
41#include <qobject.h> 41#include <qobject.h>
42#include <qhostaddress.h> 42#include <qhostaddress.h>
43 43
44/* OPIE */ 44/* OPIE */
45 45
46#include <opie2/onetutils.h> 46#include <opie2/onetutils.h>
47 47
48// ML: Yeah, I hate to include kernel headers, but it's necessary here 48// ML: Yeah, I hate to include kernel headers, but it's necessary here
49// ML: Recent RedHat and MandrakePatches to the Kernel and WE broke something 49// ML: Recent RedHat and MandrakePatches to the Kernel and WE broke something
50// ML: #include <net/if.h> e.g. conflicts with #include <linux/wireless.h> 50// ML: #include <net/if.h> e.g. conflicts with #include <linux/wireless.h>
51
52#ifndef IFNAMSIZ
51#define IFNAMSIZ 16 53#define IFNAMSIZ 16
54#endif
55
52#include <linux/wireless.h> 56#include <linux/wireless.h>
53#include <net/if.h> 57#include <net/if.h>
54 58
59#ifndef SIOCIWFIRSTPRIV
60#define SIOCIWFIRSTPRIV SIOCDEVPRIVATE
61#endif
62
55class ONetworkInterface; 63class ONetworkInterface;
56class OWirelessNetworkInterface; 64class OWirelessNetworkInterface;
57class OChannelHopper; 65class OChannelHopper;
58class OMonitoringInterface; 66class OMonitoringInterface;
59 67
60typedef struct ifreq ifreqstruct; 68typedef struct ifreq ifreqstruct;
61typedef struct iwreq iwreqstruct; 69typedef struct iwreq iwreqstruct;
62typedef struct iw_event iweventstruct; 70typedef struct iw_event iweventstruct;
63typedef struct iw_freq iwfreqstruct; 71typedef struct iw_freq iwfreqstruct;
64typedef struct iw_priv_args iwprivargsstruct; 72typedef struct iw_priv_args iwprivargsstruct;
65typedef struct iw_range iwrangestruct; 73typedef struct iw_range iwrangestruct;
66 74
67/*====================================================================================== 75/*======================================================================================
68 * ONetwork 76 * ONetwork
69 *======================================================================================*/ 77 *======================================================================================*/
70 78
71class ONetwork : public QObject 79class ONetwork : public QObject
72{ 80{
73 Q_OBJECT 81 Q_OBJECT
74 82
75 public: 83 public:
76 typedef QDict<ONetworkInterface> InterfaceMap; 84 typedef QDict<ONetworkInterface> InterfaceMap;
77 typedef QDictIterator<ONetworkInterface> InterfaceIterator; 85 typedef QDictIterator<ONetworkInterface> InterfaceIterator;
78 86
79 public: 87 public:
80 static ONetwork* instance(); 88 static ONetwork* instance();
81 InterfaceIterator iterator() const; 89 InterfaceIterator iterator() const;
82 bool isWirelessInterface( const char* ) const; 90 bool isWirelessInterface( const char* ) const;
83 ONetworkInterface* interface( QString ) const; 91 ONetworkInterface* interface( QString ) const;
84 92
85 protected: 93 protected:
86 ONetwork(); 94 ONetwork();
87 void synchronize(); 95 void synchronize();
88 96
89 private: 97 private:
90 static ONetwork* _instance; 98 static ONetwork* _instance;
91 InterfaceMap _interfaces; 99 InterfaceMap _interfaces;
92}; 100};
93 101
94 102
95/*====================================================================================== 103/*======================================================================================
96 * ONetworkInterface 104 * ONetworkInterface
97 *======================================================================================*/ 105 *======================================================================================*/
98 106
99class ONetworkInterface 107class ONetworkInterface
100{ 108{
101 friend class OMonitoringInterface; 109 friend class OMonitoringInterface;
102 friend class OCiscoMonitoringInterface; 110 friend class OCiscoMonitoringInterface;
103 friend class OWlanNGMonitoringInterface; 111 friend class OWlanNGMonitoringInterface;
104 friend class OHostAPMonitoringInterface; 112 friend class OHostAPMonitoringInterface;
105 friend class OOrinocoMonitoringInterface; 113 friend class OOrinocoMonitoringInterface;
106 114
107 public: 115 public:
108 ONetworkInterface( const QString& name ); 116 ONetworkInterface( const QString& name );
109 virtual ~ONetworkInterface(); 117 virtual ~ONetworkInterface();
110 118
111 const QString& name() const; 119 const QString& name() const;
112 void setMonitoring( OMonitoringInterface* ); 120 void setMonitoring( OMonitoringInterface* );
113 OMonitoringInterface* monitoring() const; 121 OMonitoringInterface* monitoring() const;
114 bool setPromiscuousMode( bool ); 122 bool setPromiscuousMode( bool );
115 bool promiscuousMode() const; 123 bool promiscuousMode() const;
116 bool setUp( bool ); 124 bool setUp( bool );
117 bool isUp() const; 125 bool isUp() const;
118 bool isLoopback() const; 126 bool isLoopback() const;
119 bool isWireless() const; 127 bool isWireless() const;
120 QString ipV4Address() const; 128 QString ipV4Address() const;
121 OMacAddress macAddress() const; 129 OMacAddress macAddress() const;
122 130
123 protected: 131 protected:
124 const QString _name; 132 const QString _name;
125 const int _sfd; 133 const int _sfd;
126 mutable ifreqstruct _ifr; 134 mutable ifreqstruct _ifr;
127 OMonitoringInterface* _mon; 135 OMonitoringInterface* _mon;
128 136
129 protected: 137 protected:
130 ifreqstruct& ifr() const; 138 ifreqstruct& ifr() const;
131 virtual void init(); 139 virtual void init();
132 bool ioctl( int call ) const; 140 bool ioctl( int call ) const;
133 bool ioctl( int call, ifreqstruct& ) const; 141 bool ioctl( int call, ifreqstruct& ) const;
134}; 142};
135 143
136/*====================================================================================== 144/*======================================================================================
137 * OChannelHopper 145 * OChannelHopper
138 *======================================================================================*/ 146 *======================================================================================*/
139 147
140class OChannelHopper : public QObject 148class OChannelHopper : public QObject
141{ 149{
142 public: 150 public:
143 OChannelHopper( OWirelessNetworkInterface* ); 151 OChannelHopper( OWirelessNetworkInterface* );
144 virtual ~OChannelHopper(); 152 virtual ~OChannelHopper();
145 bool isActive() const; 153 bool isActive() const;
146 int channel() const; 154 int channel() const;
147 virtual void timerEvent( QTimerEvent* ); 155 virtual void timerEvent( QTimerEvent* );
148 void setInterval( int ); 156 void setInterval( int );
149 int interval() const; 157 int interval() const;
150 158
151 private: 159 private:
152 OWirelessNetworkInterface* _iface; 160 OWirelessNetworkInterface* _iface;
153 int _interval; 161 int _interval;
154 int _channel; 162 int _channel;
155 int _tid; 163 int _tid;
156 int _maxChannel; 164 int _maxChannel;
157}; 165};
158 166
159 167
160/*====================================================================================== 168/*======================================================================================
161 * OWirelessNetworkInterface 169 * OWirelessNetworkInterface
162 *======================================================================================*/ 170 *======================================================================================*/
163 171
164class OWirelessNetworkInterface : public ONetworkInterface 172class OWirelessNetworkInterface : public ONetworkInterface
165{ 173{
166 friend class OMonitoringInterface; 174 friend class OMonitoringInterface;
167 friend class OCiscoMonitoringInterface; 175 friend class OCiscoMonitoringInterface;
168 friend class OWlanNGMonitoringInterface; 176 friend class OWlanNGMonitoringInterface;
169 friend class OHostAPMonitoringInterface; 177 friend class OHostAPMonitoringInterface;
170 friend class OOrinocoMonitoringInterface; 178 friend class OOrinocoMonitoringInterface;
171 179
172 public: 180 public:
173 enum Mode { AdHoc, Managed, Monitor }; 181 enum Mode { AdHoc, Managed, Monitor };
174 182
175 OWirelessNetworkInterface( const QString& name ); 183 OWirelessNetworkInterface( const QString& name );
176 virtual ~OWirelessNetworkInterface(); 184 virtual ~OWirelessNetworkInterface();
177 185
178 virtual void setChannel( int ) const; 186 virtual void setChannel( int ) const;
179 virtual int channel() const; 187 virtual int channel() const;
180 virtual double frequency() const; 188 virtual double frequency() const;
181 virtual int channels() const; 189 virtual int channels() const;
182 //virtual double frequency(int) const; 190 //virtual double frequency(int) const;
183 191
184 virtual void setMode( Mode ) {}; 192 virtual void setMode( Mode ) {};
185 virtual bool mode() const {}; 193 virtual bool mode() const {};
186 194
187 virtual void setMonitorMode( bool ); 195 virtual void setMonitorMode( bool );
188 virtual bool monitorMode() const; 196 virtual bool monitorMode() const;
189 197
190 virtual void setChannelHopping( int interval = 0 ); 198 virtual void setChannelHopping( int interval = 0 );
191 virtual int channelHopping() const; 199 virtual int channelHopping() const;
192 200
193 virtual void setNickName( const QString& ) {}; 201 virtual void setNickName( const QString& ) {};
194 virtual QString nickName() const; 202 virtual QString nickName() const;
195 203
196 virtual bool isAssociated() const {}; 204 virtual bool isAssociated() const {};
197 virtual QString associatedAP() const; 205 virtual QString associatedAP() const;
198 206
199 virtual void setSSID( const QString& ); 207 virtual void setSSID( const QString& );
200 virtual QString SSID() const; 208 virtual QString SSID() const;
201 209
202 protected: 210 protected:
203 mutable iwreqstruct _iwr; 211 mutable iwreqstruct _iwr;
204 QMap<int,int> _channels; 212 QMap<int,int> _channels;
205 213
206 protected: 214 protected:
207 virtual void init(); 215 virtual void init();
208 iwreqstruct& iwr() const; 216 iwreqstruct& iwr() const;
209 bool wioctl( int call ) const; 217 bool wioctl( int call ) const;
210 bool wioctl( int call, iwreqstruct& ) const; 218 bool wioctl( int call, iwreqstruct& ) const;
211 219
212 private: 220 private:
213 OChannelHopper* _hopper; 221 OChannelHopper* _hopper;
214}; 222};
215 223
216 224
217/*====================================================================================== 225/*======================================================================================
218 * OMonitoringInterface 226 * OMonitoringInterface
219 *======================================================================================*/ 227 *======================================================================================*/
220 228
221 229
222class OMonitoringInterface 230class OMonitoringInterface
223{ 231{
224 public: 232 public:
225 OMonitoringInterface(); 233 OMonitoringInterface();
226 OMonitoringInterface( ONetworkInterface* ); 234 OMonitoringInterface( ONetworkInterface* );
227 virtual ~OMonitoringInterface(); 235 virtual ~OMonitoringInterface();
228 236
229 public: 237 public:
230 virtual void setEnabled( bool ); 238 virtual void setEnabled( bool );
231 virtual bool enabled() const; 239 virtual bool enabled() const;
232 virtual void setChannel( int ); 240 virtual void setChannel( int );
233 241
234 virtual QString name() const = 0; 242 virtual QString name() const = 0;
235 243
236 protected: 244 protected:
237 bool _enabled; 245 bool _enabled;
238 const OWirelessNetworkInterface* _if; 246 const OWirelessNetworkInterface* _if;
239 247
240}; 248};
241 249
242 250
243/*====================================================================================== 251/*======================================================================================
244 * OCiscoMonitoring 252 * OCiscoMonitoring
245 *======================================================================================*/ 253 *======================================================================================*/
246 254