summaryrefslogtreecommitdiff
authorbenmeyer <benmeyer>2002-10-22 21:04:58 (UTC)
committer benmeyer <benmeyer>2002-10-22 21:04:58 (UTC)
commitc306ba7e1c73ec200b1621d224fc77f45e798e13 (patch) (unidiff)
tree1eb110c64b99c2e6ea2f8ab44c053f1e65f320f3
parent1e1b3e398d6b978a9c2bbd85d8f6b7aafbf72b2f (diff)
downloadopie-c306ba7e1c73ec200b1621d224fc77f45e798e13.zip
opie-c306ba7e1c73ec200b1621d224fc77f45e798e13.tar.gz
opie-c306ba7e1c73ec200b1621d224fc77f45e798e13.tar.bz2
Fix segfault
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/networksetup/TODO6
-rw-r--r--noncore/net/networksetup/interface.cpp4
-rw-r--r--noncore/net/networksetup/mainwindowimp.cpp2
-rw-r--r--noncore/net/networksetup/wlan/wextensions.cpp2
-rw-r--r--noncore/net/networksetup/wlan/wlanimp.cpp2
-rw-r--r--noncore/net/networksetup/wlan/wlanmodule.cpp20
-rw-r--r--noncore/settings/networksettings/TODO6
-rw-r--r--noncore/settings/networksettings/interface.cpp4
-rw-r--r--noncore/settings/networksettings/mainwindowimp.cpp2
-rw-r--r--noncore/settings/networksettings/wlan/wextensions.cpp2
-rw-r--r--noncore/settings/networksettings/wlan/wlanimp.cpp2
-rw-r--r--noncore/settings/networksettings/wlan/wlanmodule.cpp20
12 files changed, 36 insertions, 36 deletions
diff --git a/noncore/net/networksetup/TODO b/noncore/net/networksetup/TODO
index 7a71142..d61c510 100644
--- a/noncore/net/networksetup/TODO
+++ b/noncore/net/networksetup/TODO
@@ -1,11 +1,9 @@
1WLAN needs to be re-written to not use Config 1WLAN needs to be re-written to not use Config
2-remove WLAN Config item 2WHERE Is DHCP info stored???
3-sub class out the wlan info
4-check if an interface supports wireless extensions before config.
5 3
6PPP module needs to be written 4PPP module needs to be written
7 5
8Write a class that parses /proc and not ifconfig 6Write a class that parses /proc and not ifconfig
9 7
10Possible other modules: ipsec, bluetooth 8Possible other modules: ipsec, bluetooth, ipchains
11 9
diff --git a/noncore/net/networksetup/interface.cpp b/noncore/net/networksetup/interface.cpp
index a84b91f..929b3a1 100644
--- a/noncore/net/networksetup/interface.cpp
+++ b/noncore/net/networksetup/interface.cpp
@@ -1,287 +1,287 @@
1#include "interface.h" 1#include "interface.h"
2#include <qdatetime.h> 2#include <qdatetime.h>
3#include <qfile.h> 3#include <qfile.h>
4#include <qdir.h> 4#include <qdir.h>
5#include <qfileinfo.h> 5#include <qfileinfo.h>
6#include <qtextstream.h> 6#include <qtextstream.h>
7 7
8#define IFCONFIG "/sbin/ifconfig" 8#define IFCONFIG "/sbin/ifconfig"
9#define HDCP_INFO_DIR "/etc/dhcpc" 9#define DHCP_INFO_DIR "/etc/dhcpc"
10 10
11#include <stdio.h> 11#include <stdio.h>
12#include <stdlib.h> 12#include <stdlib.h>
13 13
14Interface::Interface(QObject * parent, const char * name, bool newSatus): QObject(parent, name), status(newSatus), attached(false), hardwareName("Unknown"), moduleOwner(NULL), macAddress(""), ip("0.0.0.0"), broadcast(""), subnetMask("0.0.0.0"), dhcp(false){ 14Interface::Interface(QObject * parent, const char * name, bool newSatus): QObject(parent, name), status(newSatus), attached(false), hardwareName("Unknown"), moduleOwner(NULL), macAddress(""), ip("0.0.0.0"), broadcast(""), subnetMask("0.0.0.0"), dhcp(false){
15 refresh(); 15 refresh();
16} 16}
17 17
18/** 18/**
19 * Set status 19 * Set status
20 * @param newStatus - the new status 20 * @param newStatus - the new status
21 * emit updateInterface 21 * emit updateInterface
22 */ 22 */
23void Interface::setStatus(bool newStatus){ 23void Interface::setStatus(bool newStatus){
24 if(status != newStatus){ 24 if(status != newStatus){
25 status = newStatus; 25 status = newStatus;
26 refresh(); 26 refresh();
27 } 27 }
28}; 28};
29 29
30/** 30/**
31 * Set if attached or not (802.11 card pulled out for example) 31 * Set if attached or not (802.11 card pulled out for example)
32 * @param isAttached - if attached 32 * @param isAttached - if attached
33 * emit updateInterface 33 * emit updateInterface
34 */ 34 */
35void Interface::setAttached(bool isAttached){ 35void Interface::setAttached(bool isAttached){
36 attached = isAttached; 36 attached = isAttached;
37 emit(updateInterface(this)); 37 emit(updateInterface(this));
38}; 38};
39 39
40/** 40/**
41 * Set Hardware name 41 * Set Hardware name
42 * @param name - the new name 42 * @param name - the new name
43 * emit updateInterface 43 * emit updateInterface
44 */ 44 */
45void Interface::setHardwareName(QString name){ 45void Interface::setHardwareName(QString name){
46 hardwareName = name; 46 hardwareName = name;
47 emit(updateInterface(this)); 47 emit(updateInterface(this));
48}; 48};
49 49
50/** 50/**
51 * Set Module owner 51 * Set Module owner
52 * @param owner - the new owner 52 * @param owner - the new owner
53 * emit updateInterface 53 * emit updateInterface
54 */ 54 */
55void Interface::setModuleOwner(Module *owner){ 55void Interface::setModuleOwner(Module *owner){
56 moduleOwner = owner; 56 moduleOwner = owner;
57 emit(updateInterface(this)); 57 emit(updateInterface(this));
58}; 58};
59 59
60 60
61/** 61/**
62 * Try to start the interface. 62 * Try to start the interface.
63 */ 63 */
64void Interface::start(){ 64void Interface::start(){
65 // check to see if we are already running. 65 // check to see if we are already running.
66 if(true == status) 66 if(true == status)
67 return; 67 return;
68 68
69 int ret = system(QString("%1 %2 up").arg(IFCONFIG).arg(this->name()).latin1()); 69 int ret = system(QString("%1 %2 up").arg(IFCONFIG).arg(this->name()).latin1());
70 // See if it was successfull... 70 // See if it was successfull...
71 if(ret != 0) 71 if(ret != 0)
72 return; 72 return;
73 73
74 status = true; 74 status = true;
75 refresh(); 75 refresh();
76} 76}
77 77
78/** 78/**
79 * Try to stop the interface. 79 * Try to stop the interface.
80 */ 80 */
81void Interface::stop(){ 81void Interface::stop(){
82 // check to see if we are already stopped. 82 // check to see if we are already stopped.
83 if(false == status) 83 if(false == status)
84 return; 84 return;
85 85
86 int ret = system(QString("%1 %2 down").arg(IFCONFIG).arg(this->name()).latin1()); 86 int ret = system(QString("%1 %2 down").arg(IFCONFIG).arg(this->name()).latin1());
87 if(ret != 0) 87 if(ret != 0)
88 return; 88 return;
89 89
90 status = true; 90 status = true;
91 refresh(); 91 refresh();
92} 92}
93 93
94/** 94/**
95 * Try to restart the interface. 95 * Try to restart the interface.
96 */ 96 */
97void Interface::restart(){ 97void Interface::restart(){
98 stop(); 98 stop();
99 start(); 99 start();
100} 100}
101 101
102/** 102/**
103 * Try to refresh the information about the interface. 103 * Try to refresh the information about the interface.
104 * First call ifconfig, then check the dhcp-info file 104 * First call ifconfig, then check the dhcp-info file
105 * @return bool true if successfull. 105 * @return bool true if successfull.
106 */ 106 */
107bool Interface::refresh(){ 107bool Interface::refresh(){
108 // See if we are up. 108 // See if we are up.
109 if(status == false){ 109 if(status == false){
110 macAddress = ""; 110 macAddress = "";
111 ip = "0.0.0.0"; 111 ip = "0.0.0.0";
112 subnetMask = "0.0.0.0"; 112 subnetMask = "0.0.0.0";
113 broadcast = ""; 113 broadcast = "";
114 dhcp = false; 114 dhcp = false;
115 dhcpServerIp = ""; 115 dhcpServerIp = "";
116 leaseObtained = ""; 116 leaseObtained = "";
117 leaseExpires = ""; 117 leaseExpires = "";
118 emit(updateInterface(this)); 118 emit(updateInterface(this));
119 return true; 119 return true;
120 } 120 }
121 121
122 QString fileName = QString("/tmp/%1_ifconfig_info").arg(this->name()); 122 QString fileName = QString("/tmp/%1_ifconfig_info").arg(this->name());
123 int ret = system(QString("%1 %2 > %3").arg(IFCONFIG).arg(this->name()).arg(fileName).latin1()); 123 int ret = system(QString("%1 %2 > %3").arg(IFCONFIG).arg(this->name()).arg(fileName).latin1());
124 if(ret != 0){ 124 if(ret != 0){
125 qDebug(QString("Interface: Ifconfig return value: %1, is not 0").arg(ret).latin1()); 125 qDebug(QString("Interface: Ifconfig return value: %1, is not 0").arg(ret).latin1());
126 return false; 126 return false;
127 } 127 }
128 128
129 QFile file(fileName); 129 QFile file(fileName);
130 if (!file.open(IO_ReadOnly)){ 130 if (!file.open(IO_ReadOnly)){
131 qDebug(QString("Interface: Can't open file: %1").arg(fileName).latin1()); 131 qDebug(QString("Interface: Can't open file: %1").arg(fileName).latin1());
132 return false; 132 return false;
133 } 133 }
134 134
135 // Set to the defaults 135 // Set to the defaults
136 macAddress = ""; 136 macAddress = "";
137 ip = "0.0.0.0"; 137 ip = "0.0.0.0";
138 subnetMask = "0.0.0.0"; 138 subnetMask = "0.0.0.0";
139 broadcast = ""; 139 broadcast = "";
140 140
141 QTextStream stream( &file ); 141 QTextStream stream( &file );
142 QString line; 142 QString line;
143 while ( !stream.eof() ) { 143 while ( !stream.eof() ) {
144 line = stream.readLine(); 144 line = stream.readLine();
145 if(line.contains("HWaddr")){ 145 if(line.contains("HWaddr")){
146 int mac = line.find("HWaddr"); 146 int mac = line.find("HWaddr");
147 macAddress = line.mid(mac+7, line.length()); 147 macAddress = line.mid(mac+7, line.length());
148 } 148 }
149 if(line.contains("inet addr")){ 149 if(line.contains("inet addr")){
150 int ipl = line.find("inet addr"); 150 int ipl = line.find("inet addr");
151 int space = line.find(" ", ipl+10); 151 int space = line.find(" ", ipl+10);
152 ip = line.mid(ipl+10, space-ipl-10); 152 ip = line.mid(ipl+10, space-ipl-10);
153 } 153 }
154 if(line.contains("Mask")){ 154 if(line.contains("Mask")){
155 int mask = line.find("Mask"); 155 int mask = line.find("Mask");
156 subnetMask = line.mid(mask+5, line.length()); 156 subnetMask = line.mid(mask+5, line.length());
157 } 157 }
158 if(line.contains("Bcast")){ 158 if(line.contains("Bcast")){
159 int mask = line.find("Bcast"); 159 int mask = line.find("Bcast");
160 int space = line.find(" ", mask+6); 160 int space = line.find(" ", mask+6);
161 broadcast = line.mid(mask+6, space-mask-6); 161 broadcast = line.mid(mask+6, space-mask-6);
162 } 162 }
163 } 163 }
164 file.close(); 164 file.close();
165 QFile::remove(fileName); 165 QFile::remove(fileName);
166 166
167 // DHCP TESTING 167 // DHCP TESTING
168 // reset DHCP info 168 // reset DHCP info
169 dhcpServerIp = ""; 169 dhcpServerIp = "";
170 leaseObtained = ""; 170 leaseObtained = "";
171 leaseExpires = ""; 171 leaseExpires = "";
172 dhcp = false; 172 dhcp = false;
173 173
174 QString dhcpDirectory(HDCP_INFO_DIR); 174 QString dhcpDirectory(DHCP_INFO_DIR);
175 QDir d(dhcpDirectory); 175 QDir d(dhcpDirectory);
176 if(!d.exists(dhcpDirectory)) 176 if(!d.exists(dhcpDirectory))
177 dhcpDirectory = "/var/run"; 177 dhcpDirectory = "/var/run";
178 178
179 // See if we have 179 // See if we have
180 QString dhcpFile(QString(dhcpDirectory+"/dhcpcd-%1.info").arg(this->name())); 180 QString dhcpFile(QString(dhcpDirectory+"/dhcpcd-%1.info").arg(this->name()));
181 // If there is no DHCP information then exit now with no errors. 181 // If there is no DHCP information then exit now with no errors.
182 if(!QFile::exists(dhcpFile)){ 182 if(!QFile::exists(dhcpFile)){
183 emit(updateInterface(this)); 183 emit(updateInterface(this));
184 return true; 184 return true;
185 } 185 }
186 186
187 file.setName(dhcpFile); 187 file.setName(dhcpFile);
188 if (!file.open(IO_ReadOnly)){ 188 if (!file.open(IO_ReadOnly)){
189 qDebug(QString("Interface: Can't open file: %1").arg(dhcpFile).latin1()); 189 qDebug(QString("Interface: Can't open file: %1").arg(dhcpFile).latin1());
190 return false; 190 return false;
191 } 191 }
192 192
193 // leaseTime and renewalTime and used if pid and deamon exe can be accessed. 193 // leaseTime and renewalTime and used if pid and deamon exe can be accessed.
194 int leaseTime = 0; 194 int leaseTime = 0;
195 int renewalTime = 0; 195 int renewalTime = 0;
196 196
197 stream.setDevice( &file ); 197 stream.setDevice( &file );
198 while ( !stream.eof() ) { 198 while ( !stream.eof() ) {
199 line = stream.readLine(); 199 line = stream.readLine();
200 if(line.contains("DHCPSIADDR=")) 200 if(line.contains("DHCPSIADDR="))
201 dhcpServerIp = line.mid(11, line.length()); 201 dhcpServerIp = line.mid(11, line.length());
202 if(line.contains("LEASETIME=")) 202 if(line.contains("LEASETIME="))
203 leaseTime = line.mid(10, line.length()).toInt(); 203 leaseTime = line.mid(10, line.length()).toInt();
204 if(line.contains("RENEWALTIME=")) 204 if(line.contains("RENEWALTIME="))
205 renewalTime = line.mid(12, line.length()).toInt(); 205 renewalTime = line.mid(12, line.length()).toInt();
206 } 206 }
207 file.close(); 207 file.close();
208 //qDebug(QString("Interface: leaseTime: %1").arg(leaseTime).latin1()); 208 //qDebug(QString("Interface: leaseTime: %1").arg(leaseTime).latin1());
209 //qDebug(QString("Interface: renewalTime: %1").arg(renewalTime).latin1()); 209 //qDebug(QString("Interface: renewalTime: %1").arg(renewalTime).latin1());
210 210
211 // Get the pid of the deamond 211 // Get the pid of the deamond
212 dhcpFile = (QString(dhcpDirectory+"/dhcpcd-%1.pid").arg(this->name())); 212 dhcpFile = (QString(dhcpDirectory+"/dhcpcd-%1.pid").arg(this->name()));
213 file.setName(dhcpFile); 213 file.setName(dhcpFile);
214 if (!file.open(IO_ReadOnly)){ 214 if (!file.open(IO_ReadOnly)){
215 qDebug(QString("Interface: Can't open file: %1").arg(dhcpFile).latin1()); 215 qDebug(QString("Interface: Can't open file: %1").arg(dhcpFile).latin1());
216 return false; 216 return false;
217 } 217 }
218 218
219 int pid = -1; 219 int pid = -1;
220 stream.setDevice( &file ); 220 stream.setDevice( &file );
221 while ( !stream.eof() ) { 221 while ( !stream.eof() ) {
222 line = stream.readLine(); 222 line = stream.readLine();
223 pid = line.toInt(); 223 pid = line.toInt();
224 } 224 }
225 file.close(); 225 file.close();
226 226
227 if( pid == -1){ 227 if( pid == -1){
228 qDebug("Interface: Could not get pid of dhcpc deamon."); 228 qDebug("Interface: Could not get pid of dhcpc deamon.");
229 return false; 229 return false;
230 } 230 }
231 231
232 // Get the start running time of the deamon 232 // Get the start running time of the deamon
233 fileName = (QString("/proc/%1/stat").arg(pid)); 233 fileName = (QString("/proc/%1/stat").arg(pid));
234 file.setName(fileName); 234 file.setName(fileName);
235 stream.setDevice( &file ); 235 stream.setDevice( &file );
236 if (!file.open(IO_ReadOnly)){ 236 if (!file.open(IO_ReadOnly)){
237 qDebug(QString("Interface: Can't open file: %1").arg(fileName).latin1()); 237 qDebug(QString("Interface: Can't open file: %1").arg(fileName).latin1());
238 return false; 238 return false;
239 } 239 }
240 while ( !stream.eof() ) { 240 while ( !stream.eof() ) {
241 line = stream.readLine(); 241 line = stream.readLine();
242 } 242 }
243 file.close(); 243 file.close();
244 long time = 0; 244 long time = 0;
245 // Grab the start time 245 // Grab the start time
246 // pid com state ppid pgrp session tty_nr tpgid flags 246 // pid com state ppid pgrp session tty_nr tpgid flags
247 sscanf(line.latin1(), "%*d %*s %*c %*d %*d %*d %*d %*d %*u " 247 sscanf(line.latin1(), "%*d %*s %*c %*d %*d %*d %*d %*d %*u "
248 // minflt cminflt majflt cmajflt utime stime cutime cstime priority 248 // minflt cminflt majflt cmajflt utime stime cutime cstime priority
249 "%*u %*u %*u %*u %*u %*u %*d %*d %*d " 249 "%*u %*u %*u %*u %*u %*u %*d %*d %*d "
250 // nice 0 itrealvalue starttime 250 // nice 0 itrealvalue starttime
251 "%*d %*d %*d %lu", (long*) &time); 251 "%*d %*d %*d %lu", (long*) &time);
252 time = time/100; 252 time = time/100;
253 253
254 QDateTime datetime(QDateTime::currentDateTime()); 254 QDateTime datetime(QDateTime::currentDateTime());
255 255
256 // Get the uptime of the computer. 256 // Get the uptime of the computer.
257 QFile f("/proc/uptime"); 257 QFile f("/proc/uptime");
258 if ( f.open(IO_ReadOnly) ) { // file opened successfully 258 if ( f.open(IO_ReadOnly) ) { // file opened successfully
259 QTextStream t( &f ); // use a text stream 259 QTextStream t( &f ); // use a text stream
260 int sec = 0; 260 int sec = 0;
261 t >> sec; 261 t >> sec;
262 datetime = datetime.addSecs((-1*sec)); 262 datetime = datetime.addSecs((-1*sec));
263 f.close(); 263 f.close();
264 } 264 }
265 else{ 265 else{
266 qDebug("Interface: Can't open /proc/uptime to retrive uptime."); 266 qDebug("Interface: Can't open /proc/uptime to retrive uptime.");
267 return false; 267 return false;
268 } 268 }
269 269
270 datetime = datetime.addSecs(time); 270 datetime = datetime.addSecs(time);
271 //qDebug(QString("Interface: %1 %2").arg(datetime.toString()).arg(pid).latin1()); 271 //qDebug(QString("Interface: %1 %2").arg(datetime.toString()).arg(pid).latin1());
272 272
273 // Calculate the start and renew times 273 // Calculate the start and renew times
274 leaseObtained= datetime.toString(); 274 leaseObtained= datetime.toString();
275 275
276 // Calculate the start and renew times 276 // Calculate the start and renew times
277 datetime = datetime.addSecs(leaseTime); 277 datetime = datetime.addSecs(leaseTime);
278 leaseExpires = datetime.toString(); 278 leaseExpires = datetime.toString();
279 279
280 dhcp = true; 280 dhcp = true;
281 281
282 emit(updateInterface(this)); 282 emit(updateInterface(this));
283 return true; 283 return true;
284} 284}
285 285
286// interface.cpp 286// interface.cpp
287 287
diff --git a/noncore/net/networksetup/mainwindowimp.cpp b/noncore/net/networksetup/mainwindowimp.cpp
index 9d81ab1..c86acdc 100644
--- a/noncore/net/networksetup/mainwindowimp.cpp
+++ b/noncore/net/networksetup/mainwindowimp.cpp
@@ -1,558 +1,560 @@
1#include "mainwindowimp.h" 1#include "mainwindowimp.h"
2#include "addconnectionimp.h" 2#include "addconnectionimp.h"
3#include "interfaceinformationimp.h" 3#include "interfaceinformationimp.h"
4#include "interfacesetupimp.h" 4#include "interfacesetupimp.h"
5#include "interfaces.h" 5#include "interfaces.h"
6 6
7#include "module.h" 7#include "module.h"
8 8
9#include "kprocess.h" 9#include "kprocess.h"
10 10
11#include <qpushbutton.h> 11#include <qpushbutton.h>
12#include <qtabwidget.h> 12#include <qtabwidget.h>
13#include <qlistbox.h> 13#include <qlistbox.h>
14#include <qlineedit.h> 14#include <qlineedit.h>
15#include <qlistview.h> 15#include <qlistview.h>
16#include <qheader.h> 16#include <qheader.h>
17#include <qlabel.h> 17#include <qlabel.h>
18 18
19#include <qmainwindow.h> 19#include <qmainwindow.h>
20#include <qmessagebox.h> 20#include <qmessagebox.h>
21 21
22#include <qpe/config.h> 22#include <qpe/config.h>
23#include <qpe/qlibrary.h> 23#include <qpe/qlibrary.h>
24#include <qpe/resource.h> 24#include <qpe/resource.h>
25#include <qpe/qpeapplication.h> 25#include <qpe/qpeapplication.h>
26 26
27#include <qlist.h> 27#include <qlist.h>
28#include <qdir.h> 28#include <qdir.h>
29#include <qfile.h> 29#include <qfile.h>
30#include <qtextstream.h> 30#include <qtextstream.h>
31 31
32#define TEMP_ALL "/tmp/ifconfig-a" 32#define TEMP_ALL "/tmp/ifconfig-a"
33#define TEMP_UP "/tmp/ifconfig" 33#define TEMP_UP "/tmp/ifconfig"
34 34
35#define DEFAULT_SCHEME "/var/lib/pcmcia/scheme" 35#define DEFAULT_SCHEME "/var/lib/pcmcia/scheme"
36 36
37MainWindowImp::MainWindowImp(QWidget *parent, const char *name) : MainWindow(parent, name, true), advancedUserMode(false){ 37MainWindowImp::MainWindowImp(QWidget *parent, const char *name) : MainWindow(parent, name, true), advancedUserMode(false){
38 connect(addConnectionButton, SIGNAL(clicked()), this, SLOT(addClicked())); 38 connect(addConnectionButton, SIGNAL(clicked()), this, SLOT(addClicked()));
39 connect(removeConnectionButton, SIGNAL(clicked()), this, SLOT(removeClicked())); 39 connect(removeConnectionButton, SIGNAL(clicked()), this, SLOT(removeClicked()));
40 connect(informationConnectionButton, SIGNAL(clicked()), this, SLOT(informationClicked())); 40 connect(informationConnectionButton, SIGNAL(clicked()), this, SLOT(informationClicked()));
41 connect(configureConnectionButton, SIGNAL(clicked()), this, SLOT(configureClicked())); 41 connect(configureConnectionButton, SIGNAL(clicked()), this, SLOT(configureClicked()));
42 42
43 connect(newProfileButton, SIGNAL(clicked()), this, SLOT(addProfile())); 43 connect(newProfileButton, SIGNAL(clicked()), this, SLOT(addProfile()));
44 connect(removeProfileButton, SIGNAL(clicked()), this, SLOT(removeProfile())); 44 connect(removeProfileButton, SIGNAL(clicked()), this, SLOT(removeProfile()));
45 connect(setCurrentProfileButton, SIGNAL(clicked()), this, SLOT(changeProfile())); 45 connect(setCurrentProfileButton, SIGNAL(clicked()), this, SLOT(changeProfile()));
46 46
47 connect(newProfile, SIGNAL(textChanged(const QString&)), this, SLOT(newProfileChanged(const QString&))); 47 connect(newProfile, SIGNAL(textChanged(const QString&)), this, SLOT(newProfileChanged(const QString&)));
48 // Load connections. 48 // Load connections.
49 loadModules(QPEApplication::qpeDir() + "/plugins/networksetup"); 49 loadModules(QPEApplication::qpeDir() + "/plugins/networksetup");
50 getInterfaceList(); 50 getInterfaceList();
51 connectionList->header()->hide(); 51 connectionList->header()->hide();
52 52
53 53
54 Config cfg("NetworkSetup"); 54 Config cfg("NetworkSetup");
55 profiles = QStringList::split(" ", cfg.readEntry("Profiles", "All")); 55 profiles = QStringList::split(" ", cfg.readEntry("Profiles", "All"));
56 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it) 56 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it)
57 profilesList->insertItem((*it)); 57 profilesList->insertItem((*it));
58 currentProfileLabel->setText(cfg.readEntry("CurrentProfile", "All")); 58 currentProfileLabel->setText(cfg.readEntry("CurrentProfile", "All"));
59 advancedUserMode = cfg.readBoolEntry("AdvancedUserMode", false); 59 advancedUserMode = cfg.readBoolEntry("AdvancedUserMode", false);
60 scheme = cfg.readEntry("SchemeFile", DEFAULT_SCHEME); 60 scheme = cfg.readEntry("SchemeFile", DEFAULT_SCHEME);
61 61
62 QFile file(scheme); 62 QFile file(scheme);
63 if ( file.open(IO_ReadOnly) ) { // file opened successfully 63 if ( file.open(IO_ReadOnly) ) { // file opened successfully
64 QTextStream stream( &file ); // use a text stream 64 QTextStream stream( &file ); // use a text stream
65 while ( !stream.eof() ) { // until end of file... 65 while ( !stream.eof() ) { // until end of file...
66 QString line = stream.readLine(); // line of text excluding '\n' 66 QString line = stream.readLine(); // line of text excluding '\n'
67 if(line.contains("SCHEME")){ 67 if(line.contains("SCHEME")){
68 line = line.mid(7, line.length()); 68 line = line.mid(7, line.length());
69 currentProfileLabel->setText(line); 69 currentProfileLabel->setText(line);
70 break; 70 break;
71 } 71 }
72 } 72 }
73 file.close(); 73 file.close();
74 } 74 }
75} 75}
76 76
77/** 77/**
78 * Deconstructor. Save profiles. Delete loaded libraries. 78 * Deconstructor. Save profiles. Delete loaded libraries.
79 */ 79 */
80MainWindowImp::~MainWindowImp(){ 80MainWindowImp::~MainWindowImp(){
81 qDebug("start Saving mainwindow");
81 // Save profiles. 82 // Save profiles.
82 Config cfg("NetworkSetup"); 83 Config cfg("NetworkSetup");
83 cfg.setGroup("General"); 84 cfg.setGroup("General");
84 cfg.writeEntry("Profiles", profiles.join(" ")); 85 cfg.writeEntry("Profiles", profiles.join(" "));
85 86
86 // Delete all interfaces that don't have owners. 87 // Delete all interfaces that don't have owners.
87 QMap<Interface*, QListViewItem*>::Iterator iIt; 88 QMap<Interface*, QListViewItem*>::Iterator iIt;
88 for( iIt = items.begin(); iIt != items.end(); ++iIt ){ 89 for( iIt = items.begin(); iIt != items.end(); ++iIt ){
89 if(iIt.key()->getModuleOwner() == NULL) 90 if(iIt.key()->getModuleOwner() == NULL)
90 delete iIt.key(); 91 delete iIt.key();
91 } 92 }
92 93
93 // Delete Modules and Libraries 94 // Delete Modules and Libraries
94 QMap<Module*, QLibrary*>::Iterator it; 95 QMap<Module*, QLibrary*>::Iterator it;
95 for( it = libraries.begin(); it != libraries.end(); ++it ){ 96 for( it = libraries.begin(); it != libraries.end(); ++it ){
96 delete it.key(); 97 delete it.key();
97 delete it.data(); 98 delete it.data();
98 } 99 }
100 qDebug("done Saving mainwindow");
99} 101}
100 102
101/** 103/**
102 * Load all modules that are found in the path 104 * Load all modules that are found in the path
103 * @param path a directory that is scaned for any plugins that can be loaded 105 * @param path a directory that is scaned for any plugins that can be loaded
104 * and attempts to load them 106 * and attempts to load them
105 */ 107 */
106void MainWindowImp::loadModules(QString path){ 108void MainWindowImp::loadModules(QString path){
107 //qDebug(path.latin1()); 109 //qDebug(path.latin1());
108 QDir d(path); 110 QDir d(path);
109 if(!d.exists()) 111 if(!d.exists())
110 return; 112 return;
111 113
112 // Don't want sym links 114 // Don't want sym links
113 d.setFilter( QDir::Files | QDir::NoSymLinks ); 115 d.setFilter( QDir::Files | QDir::NoSymLinks );
114 const QFileInfoList *list = d.entryInfoList(); 116 const QFileInfoList *list = d.entryInfoList();
115 QFileInfoListIterator it( *list ); 117 QFileInfoListIterator it( *list );
116 QFileInfo *fi; 118 QFileInfo *fi;
117 while ( (fi=it.current()) ) { 119 while ( (fi=it.current()) ) {
118 if(fi->fileName().contains(".so")){ 120 if(fi->fileName().contains(".so")){
119 loadPlugin(path + "/" + fi->fileName()); 121 loadPlugin(path + "/" + fi->fileName());
120 } 122 }
121 ++it; 123 ++it;
122 } 124 }
123} 125}
124 126
125/** 127/**
126 * Attempt to load a function and resolve a function. 128 * Attempt to load a function and resolve a function.
127 * @param pluginFileName - the name of the file in which to attempt to load 129 * @param pluginFileName - the name of the file in which to attempt to load
128 * @param resolveString - function pointer to resolve 130 * @param resolveString - function pointer to resolve
129 * @return pointer to the function with name resolveString or NULL 131 * @return pointer to the function with name resolveString or NULL
130 */ 132 */
131Module* MainWindowImp::loadPlugin(QString pluginFileName, QString resolveString){ 133Module* MainWindowImp::loadPlugin(QString pluginFileName, QString resolveString){
132 //qDebug(QString("MainWindowImp::loadPlugin: %1").arg(pluginFileName).latin1()); 134 //qDebug(QString("MainWindowImp::loadPlugin: %1").arg(pluginFileName).latin1());
133 QLibrary *lib = new QLibrary(pluginFileName); 135 QLibrary *lib = new QLibrary(pluginFileName);
134 void *functionPointer = lib->resolve(resolveString); 136 void *functionPointer = lib->resolve(resolveString);
135 if( !functionPointer ){ 137 if( !functionPointer ){
136 qDebug(QString("MainWindowImp: File: %1 is not a plugin, but though was.").arg(pluginFileName).latin1()); 138 qDebug(QString("MainWindowImp: File: %1 is not a plugin, but though was.").arg(pluginFileName).latin1());
137 delete lib; 139 delete lib;
138 return NULL; 140 return NULL;
139 } 141 }
140 142
141 // Try to get an object. 143 // Try to get an object.
142 Module *object = ((Module* (*)()) functionPointer)(); 144 Module *object = ((Module* (*)()) functionPointer)();
143 if(object == NULL){ 145 if(object == NULL){
144 qDebug("MainWindowImp: Couldn't create object, but did load library!"); 146 qDebug("MainWindowImp: Couldn't create object, but did load library!");
145 delete lib; 147 delete lib;
146 return NULL; 148 return NULL;
147 } 149 }
148 150
149 // Store for deletion later 151 // Store for deletion later
150 libraries.insert(object, lib); 152 libraries.insert(object, lib);
151 return object; 153 return object;
152} 154}
153 155
154/** 156/**
155 * The Add button was clicked. Bring up the add dialog and if OK is hit 157 * The Add button was clicked. Bring up the add dialog and if OK is hit
156 * load the plugin and append it to the list 158 * load the plugin and append it to the list
157 */ 159 */
158void MainWindowImp::addClicked(){ 160void MainWindowImp::addClicked(){
159 QMap<Module*, QLibrary*>::Iterator it; 161 QMap<Module*, QLibrary*>::Iterator it;
160 QMap<QString, QString> list; 162 QMap<QString, QString> list;
161 QMap<QString, Module*> newInterfaceOwners; 163 QMap<QString, Module*> newInterfaceOwners;
162 list.insert("USB (PPP) / (ADD_TEST)", "A dialup connection over the USB port"); 164 list.insert("USB (PPP) / (ADD_TEST)", "A dialup connection over the USB port");
163 list.insert("IrDa (PPP) / (ADD_TEST)", "A dialup connection over the IdDa port"); 165 list.insert("IrDa (PPP) / (ADD_TEST)", "A dialup connection over the IdDa port");
164 for( it = libraries.begin(); it != libraries.end(); ++it ){ 166 for( it = libraries.begin(); it != libraries.end(); ++it ){
165 if(it.key()){ 167 if(it.key()){
166 (it.key())->possibleNewInterfaces(list); 168 (it.key())->possibleNewInterfaces(list);
167 } 169 }
168 } 170 }
169 // See if the list has anything that we can add. 171 // See if the list has anything that we can add.
170 if(list.count() == 0){ 172 if(list.count() == 0){
171 QMessageBox::information(this, "Sorry", "Nothing to add.", "Ok"); 173 QMessageBox::information(this, "Sorry", "Nothing to add.", "Ok");
172 return; 174 return;
173 } 175 }
174 AddConnectionImp addNewConnection(this, "AddConnectionImp", true); 176 AddConnectionImp addNewConnection(this, "AddConnectionImp", true);
175 addNewConnection.addConnections(list); 177 addNewConnection.addConnections(list);
176 addNewConnection.showMaximized(); 178 addNewConnection.showMaximized();
177 if(QDialog::Accepted == addNewConnection.exec()){ 179 if(QDialog::Accepted == addNewConnection.exec()){
178 QListViewItem *item = addNewConnection.registeredServicesList->currentItem(); 180 QListViewItem *item = addNewConnection.registeredServicesList->currentItem();
179 if(!item) 181 if(!item)
180 return; 182 return;
181 183
182 for( it = libraries.begin(); it != libraries.end(); ++it ){ 184 for( it = libraries.begin(); it != libraries.end(); ++it ){
183 if(it.key()){ 185 if(it.key()){
184 Interface *i = (it.key())->addNewInterface(item->text(0)); 186 Interface *i = (it.key())->addNewInterface(item->text(0));
185 if(i){ 187 if(i){
186 interfaceNames.insert(i->getInterfaceName(), i); 188 interfaceNames.insert(i->getInterfaceName(), i);
187 updateInterface(i); 189 updateInterface(i);
188 } 190 }
189 } 191 }
190 } 192 }
191 } 193 }
192} 194}
193 195
194/** 196/**
195 * Prompt the user to see if they really want to do this. 197 * Prompt the user to see if they really want to do this.
196 * If they do then remove from the list and unload. 198 * If they do then remove from the list and unload.
197 */ 199 */
198void MainWindowImp::removeClicked(){ 200void MainWindowImp::removeClicked(){
199 QListViewItem *item = connectionList->currentItem(); 201 QListViewItem *item = connectionList->currentItem();
200 if(!item) { 202 if(!item) {
201 QMessageBox::information(this, "Sorry","Please select an interface First.", "Ok"); 203 QMessageBox::information(this, "Sorry","Please select an interface First.", "Ok");
202 return; 204 return;
203 } 205 }
204 206
205 Interface *i = interfaceItems[item]; 207 Interface *i = interfaceItems[item];
206 if(i->getModuleOwner() == NULL){ 208 if(i->getModuleOwner() == NULL){
207 QMessageBox::information(this, "Can't remove interface.", "Interface is built in.", "Ok"); 209 QMessageBox::information(this, "Can't remove interface.", "Interface is built in.", "Ok");
208 } 210 }
209 else{ 211 else{
210 if(!i->getModuleOwner()->remove(i)) 212 if(!i->getModuleOwner()->remove(i))
211 QMessageBox::information(this, "Error", "Unable to remove.", "Ok"); 213 QMessageBox::information(this, "Error", "Unable to remove.", "Ok");
212 else{ 214 else{
213 QMessageBox::information(this, "Success", "Interface was removed.", "Ok"); 215 QMessageBox::information(this, "Success", "Interface was removed.", "Ok");
214 // TODO memory managment.... 216 // TODO memory managment....
215 // who deletes the interface? 217 // who deletes the interface?
216 } 218 }
217 } 219 }
218} 220}
219 221
220/** 222/**
221 * Pull up the configure about the currently selected interface. 223 * Pull up the configure about the currently selected interface.
222 * Report an error if no interface is selected. 224 * Report an error if no interface is selected.
223 * If the interface has a module owner then request its configure with a empty 225 * If the interface has a module owner then request its configure with a empty
224 * tab. If tab is !NULL then append the interfaces setup widget to it. 226 * tab. If tab is !NULL then append the interfaces setup widget to it.
225 */ 227 */
226void MainWindowImp::configureClicked(){ 228void MainWindowImp::configureClicked(){
227 QListViewItem *item = connectionList->currentItem(); 229 QListViewItem *item = connectionList->currentItem();
228 if(!item){ 230 if(!item){
229 QMessageBox::information(this, "Sorry","Please select an interface first.", QMessageBox::Ok); 231 QMessageBox::information(this, "Sorry","Please select an interface first.", QMessageBox::Ok);
230 return; 232 return;
231 } 233 }
232 234
233 QString currentProfile = currentProfileLabel->text(); 235 QString currentProfile = currentProfileLabel->text();
234 if(profilesList->count() <= 1 || currentProfile == "All"){ 236 if(profilesList->count() <= 1 || currentProfile == "All"){
235 currentProfile = ""; 237 currentProfile = "";
236 } 238 }
237 239
238 Interface *i = interfaceItems[item]; 240 Interface *i = interfaceItems[item];
239 if(i->getModuleOwner()){ 241 if(i->getModuleOwner()){
240 i->getModuleOwner()->setProfile(currentProfile); 242 i->getModuleOwner()->setProfile(currentProfile);
241 QTabWidget *tabWidget = NULL; 243 QTabWidget *tabWidget = NULL;
242 QWidget *moduleConfigure = i->getModuleOwner()->configure(i, &tabWidget); 244 QWidget *moduleConfigure = i->getModuleOwner()->configure(i, &tabWidget);
243 if(moduleConfigure != NULL){ 245 if(moduleConfigure != NULL){
244 if(tabWidget != NULL){ 246 if(tabWidget != NULL){
245 InterfaceSetupImp *configure = new InterfaceSetupImp(tabWidget, "InterfaceSetupImp", i, true); 247 InterfaceSetupImp *configure = new InterfaceSetupImp(tabWidget, "InterfaceSetupImp", i, true);
246 configure->setProfile(currentProfile); 248 configure->setProfile(currentProfile);
247 tabWidget->insertTab(configure, "TCP/IP"); 249 tabWidget->insertTab(configure, "TCP/IP");
248 250
249 } 251 }
250 moduleConfigure->showMaximized(); 252 moduleConfigure->showMaximized();
251 moduleConfigure->show(); 253 moduleConfigure->show();
252 return; 254 return;
253 } 255 }
254 } 256 }
255 257
256 InterfaceSetupImp *configure = new InterfaceSetupImp(0, "InterfaceSetupImp", i, true); 258 InterfaceSetupImp *configure = new InterfaceSetupImp(0, "InterfaceSetupImp", i, true);
257 configure->setProfile(currentProfile); 259 configure->setProfile(currentProfile);
258 configure->showMaximized(); 260 configure->showMaximized();
259 configure->show(); 261 configure->show();
260} 262}
261 263
262/** 264/**
263 * Pull up the information about the currently selected interface. 265 * Pull up the information about the currently selected interface.
264 * Report an error if no interface is selected. 266 * Report an error if no interface is selected.
265 * If the interface has a module owner then request its configure with a empty 267 * If the interface has a module owner then request its configure with a empty
266 * tab. If tab is !NULL then append the interfaces setup widget to it. 268 * tab. If tab is !NULL then append the interfaces setup widget to it.
267 */ 269 */
268void MainWindowImp::informationClicked(){ 270void MainWindowImp::informationClicked(){
269 QListViewItem *item = connectionList->currentItem(); 271 QListViewItem *item = connectionList->currentItem();
270 if(!item){ 272 if(!item){
271 QMessageBox::information(this, "Sorry","Please select an interface First.", QMessageBox::Ok); 273 QMessageBox::information(this, "Sorry","Please select an interface First.", QMessageBox::Ok);
272 return; 274 return;
273 } 275 }
274 276
275 Interface *i = interfaceItems[item]; 277 Interface *i = interfaceItems[item];
276 if(!i->isAttached()){ 278 if(!i->isAttached()){
277 QMessageBox::information(this, "Sorry","No information about\na disconnected interface.", QMessageBox::Ok); 279 QMessageBox::information(this, "Sorry","No information about\na disconnected interface.", QMessageBox::Ok);
278 return; 280 return;
279 } 281 }
280 282
281 QStringList list; 283 QStringList list;
282 for(uint i = 0; i < profilesList->count(); i++){ 284 for(uint i = 0; i < profilesList->count(); i++){
283 list.append(profilesList->text(i)); 285 list.append(profilesList->text(i));
284 } 286 }
285 287
286 if(i->getModuleOwner()){ 288 if(i->getModuleOwner()){
287 QTabWidget *tabWidget = NULL; 289 QTabWidget *tabWidget = NULL;
288 QWidget *moduleInformation = i->getModuleOwner()->information(i, &tabWidget); 290 QWidget *moduleInformation = i->getModuleOwner()->information(i, &tabWidget);
289 if(moduleInformation != NULL){ 291 if(moduleInformation != NULL){
290 if(tabWidget != NULL){ 292 if(tabWidget != NULL){
291 InterfaceInformationImp *information = new InterfaceInformationImp(tabWidget, "InterfaceSetupImp", i, true); 293 InterfaceInformationImp *information = new InterfaceInformationImp(tabWidget, "InterfaceSetupImp", i, true);
292 tabWidget->insertTab(information, "TCP/IP"); 294 tabWidget->insertTab(information, "TCP/IP");
293 } 295 }
294 moduleInformation->showMaximized(); 296 moduleInformation->showMaximized();
295 moduleInformation->show(); 297 moduleInformation->show();
296 return; 298 return;
297 } 299 }
298 } 300 }
299 301
300 InterfaceInformationImp *information = new InterfaceInformationImp(0, "InterfaceSetupImp", i, true); 302 InterfaceInformationImp *information = new InterfaceInformationImp(0, "InterfaceSetupImp", i, true);
301 information->showMaximized(); 303 information->showMaximized();
302 information->show(); 304 information->show();
303} 305}
304 306
305/** 307/**
306 * Aquire the list of active interfaces from ifconfig 308 * Aquire the list of active interfaces from ifconfig
307 * Call ifconfig and ifconfig -a 309 * Call ifconfig and ifconfig -a
308 */ 310 */
309void MainWindowImp::getInterfaceList(){ 311void MainWindowImp::getInterfaceList(){
310 KShellProcess *processAll = new KShellProcess(); 312 KShellProcess *processAll = new KShellProcess();
311 *processAll << "/sbin/ifconfig" << "-a" << " > " TEMP_ALL; 313 *processAll << "/sbin/ifconfig" << "-a" << " > " TEMP_ALL;
312 connect(processAll, SIGNAL(processExited(KProcess *)), 314 connect(processAll, SIGNAL(processExited(KProcess *)),
313 this, SLOT(jobDone(KProcess *))); 315 this, SLOT(jobDone(KProcess *)));
314 threads.insert(processAll, TEMP_ALL); 316 threads.insert(processAll, TEMP_ALL);
315 317
316 KShellProcess *process = new KShellProcess(); 318 KShellProcess *process = new KShellProcess();
317 *process << "/sbin/ifconfig" << " > " TEMP_UP; 319 *process << "/sbin/ifconfig" << " > " TEMP_UP;
318 connect(process, SIGNAL(processExited(KProcess *)), 320 connect(process, SIGNAL(processExited(KProcess *)),
319 this, SLOT(jobDone(KProcess *))); 321 this, SLOT(jobDone(KProcess *)));
320 threads.insert(process, TEMP_UP); 322 threads.insert(process, TEMP_UP);
321 323
322 processAll->start(KShellProcess::NotifyOnExit); 324 processAll->start(KShellProcess::NotifyOnExit);
323 process->start(KShellProcess::NotifyOnExit); 325 process->start(KShellProcess::NotifyOnExit);
324} 326}
325 327
326void MainWindowImp::jobDone(KProcess *process){ 328void MainWindowImp::jobDone(KProcess *process){
327 QString fileName = threads[process]; 329 QString fileName = threads[process];
328 threads.remove(process); 330 threads.remove(process);
329 delete process; 331 delete process;
330 332
331 QFile file(fileName); 333 QFile file(fileName);
332 if (!file.open(IO_ReadOnly)){ 334 if (!file.open(IO_ReadOnly)){
333 qDebug(QString("MainWindowImp: Can't open file: %1").arg(fileName).latin1()); 335 qDebug(QString("MainWindowImp: Can't open file: %1").arg(fileName).latin1());
334 return; 336 return;
335 } 337 }
336 338
337 QTextStream stream( &file ); 339 QTextStream stream( &file );
338 QString line; 340 QString line;
339 while ( !stream.eof() ) { 341 while ( !stream.eof() ) {
340 line = stream.readLine(); 342 line = stream.readLine();
341 int space = line.find(" "); 343 int space = line.find(" ");
342 if(space > 1){ 344 if(space > 1){
343 // We have found an interface 345 // We have found an interface
344 QString interfaceName = line.mid(0, space); 346 QString interfaceName = line.mid(0, space);
345 Interface *i; 347 Interface *i;
346 // We have found an interface 348 // We have found an interface
347 //qDebug(QString("MainWindowImp: Found Interface: %1").arg(line).latin1()); 349 //qDebug(QString("MainWindowImp: Found Interface: %1").arg(line).latin1());
348 // See if we already have it 350 // See if we already have it
349 if(interfaceNames.find(interfaceName) == interfaceNames.end()){ 351 if(interfaceNames.find(interfaceName) == interfaceNames.end()){
350 if(fileName == TEMP_ALL) 352 if(fileName == TEMP_ALL)
351 i = new Interface(this, interfaceName, false); 353 i = new Interface(this, interfaceName, false);
352 else 354 else
353 i = new Interface(this, interfaceName, true); 355 i = new Interface(this, interfaceName, true);
354 i->setAttached(true); 356 i->setAttached(true);
355 357
356 QString hardName = "Ethernet"; 358 QString hardName = "Ethernet";
357 int hardwareName = line.find("Link encap:"); 359 int hardwareName = line.find("Link encap:");
358 int macAddress = line.find("HWaddr"); 360 int macAddress = line.find("HWaddr");
359 if(macAddress == -1) 361 if(macAddress == -1)
360 macAddress = line.length(); 362 macAddress = line.length();
361 if(hardwareName != -1) 363 if(hardwareName != -1)
362 i->setHardwareName(line.mid(hardwareName+11, macAddress-(hardwareName+11)) ); 364 i->setHardwareName(line.mid(hardwareName+11, macAddress-(hardwareName+11)) );
363 365
364 interfaceNames.insert(i->getInterfaceName(), i); 366 interfaceNames.insert(i->getInterfaceName(), i);
365 updateInterface(i); 367 updateInterface(i);
366 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *))); 368 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *)));
367 } 369 }
368 // It was an interface we already had. 370 // It was an interface we already had.
369 else{ 371 else{
370 if(fileName != TEMP_ALL) 372 if(fileName != TEMP_ALL)
371 (interfaceNames[interfaceName])->setStatus(true); 373 (interfaceNames[interfaceName])->setStatus(true);
372 } 374 }
373 } 375 }
374 } 376 }
375 file.close(); 377 file.close();
376 QFile::remove(fileName); 378 QFile::remove(fileName);
377 379
378 if(threads.count() == 0){ 380 if(threads.count() == 0){
379 Interfaces i; 381 Interfaces i;
380 QStringList list = i.getInterfaceList(); 382 QStringList list = i.getInterfaceList();
381 QMap<QString, Interface*>::Iterator it; 383 QMap<QString, Interface*>::Iterator it;
382 for ( QStringList::Iterator ni = list.begin(); ni != list.end(); ++ni ) { 384 for ( QStringList::Iterator ni = list.begin(); ni != list.end(); ++ni ) {
383 bool found = false; 385 bool found = false;
384 for( it = interfaceNames.begin(); it != interfaceNames.end(); ++it ){ 386 for( it = interfaceNames.begin(); it != interfaceNames.end(); ++it ){
385 if(it.key() == (*ni)) 387 if(it.key() == (*ni))
386 found = true; 388 found = true;
387 } 389 }
388 if(!found){ 390 if(!found){
389 if(!(*ni).contains("_")){ 391 if(!(*ni).contains("_")){
390 Interface *i = new Interface(this, *ni, false); 392 Interface *i = new Interface(this, *ni, false);
391 i->setAttached(false); 393 i->setAttached(false);
392 i->setHardwareName("Disconnected"); 394 i->setHardwareName("Disconnected");
393 interfaceNames.insert(i->getInterfaceName(), i); 395 interfaceNames.insert(i->getInterfaceName(), i);
394 updateInterface(i); 396 updateInterface(i);
395 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *))); 397 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *)));
396 } 398 }
397 } 399 }
398 } 400 }
399 } 401 }
400} 402}
401 403
402/** 404/**
403 * Update this interface. If no QListViewItem exists create one. 405 * Update this interface. If no QListViewItem exists create one.
404 * @param Interface* pointer to the interface that needs to be updated. 406 * @param Interface* pointer to the interface that needs to be updated.
405 */ 407 */
406void MainWindowImp::updateInterface(Interface *i){ 408void MainWindowImp::updateInterface(Interface *i){
407 if(!advancedUserMode){ 409 if(!advancedUserMode){
408 if(i->getInterfaceName() == "lo") 410 if(i->getInterfaceName() == "lo")
409 return; 411 return;
410 } 412 }
411 413
412 QListViewItem *item = NULL; 414 QListViewItem *item = NULL;
413 415
414 // Find the interface, making it if needed. 416 // Find the interface, making it if needed.
415 if(items.find(i) == items.end()){ 417 if(items.find(i) == items.end()){
416 item = new QListViewItem(connectionList, "", "", ""); 418 item = new QListViewItem(connectionList, "", "", "");
417 // See if you can't find a module owner for this interface 419 // See if you can't find a module owner for this interface
418 QMap<Module*, QLibrary*>::Iterator it; 420 QMap<Module*, QLibrary*>::Iterator it;
419 for( it = libraries.begin(); it != libraries.end(); ++it ){ 421 for( it = libraries.begin(); it != libraries.end(); ++it ){
420 if(it.key()->isOwner(i)) 422 if(it.key()->isOwner(i))
421 i->setModuleOwner(it.key()); 423 i->setModuleOwner(it.key());
422 } 424 }
423 items.insert(i, item); 425 items.insert(i, item);
424 interfaceItems.insert(item, i); 426 interfaceItems.insert(item, i);
425 } 427 }
426 else 428 else
427 item = items[i]; 429 item = items[i];
428 430
429 // Update the icons and information 431 // Update the icons and information
430 item->setPixmap(0, (Resource::loadPixmap(i->getStatus() ? "up": "down"))); 432 item->setPixmap(0, (Resource::loadPixmap(i->getStatus() ? "up": "down")));
431 433
432 QString typeName = "lan"; 434 QString typeName = "lan";
433 if(i->getHardwareName().contains("Local Loopback")) 435 if(i->getHardwareName().contains("Local Loopback"))
434 typeName = "lo"; 436 typeName = "lo";
435 if(i->getInterfaceName().contains("irda")) 437 if(i->getInterfaceName().contains("irda"))
436 typeName = "irda"; 438 typeName = "irda";
437 if(i->getInterfaceName().contains("wlan")) 439 if(i->getInterfaceName().contains("wlan"))
438 typeName = "wlan"; 440 typeName = "wlan";
439 if(i->getInterfaceName().contains("usb")) 441 if(i->getInterfaceName().contains("usb"))
440 typeName = "usb"; 442 typeName = "usb";
441 443
442 if(!i->isAttached()) 444 if(!i->isAttached())
443 typeName = "connect_no"; 445 typeName = "connect_no";
444 // Actually try to use the Module 446 // Actually try to use the Module
445 if(i->getModuleOwner() != NULL) 447 if(i->getModuleOwner() != NULL)
446 typeName = i->getModuleOwner()->getPixmapName(i); 448 typeName = i->getModuleOwner()->getPixmapName(i);
447 449
448 item->setPixmap(1, (Resource::loadPixmap(typeName))); 450 item->setPixmap(1, (Resource::loadPixmap(typeName)));
449 item->setText(2, i->getHardwareName()); 451 item->setText(2, i->getHardwareName());
450 item->setText(3, QString("(%1)").arg(i->getInterfaceName())); 452 item->setText(3, QString("(%1)").arg(i->getInterfaceName()));
451 item->setText(4, (i->getStatus()) ? i->getIp() : QString("")); 453 item->setText(4, (i->getStatus()) ? i->getIp() : QString(""));
452} 454}
453 455
454void MainWindowImp::newProfileChanged(const QString& newText){ 456void MainWindowImp::newProfileChanged(const QString& newText){
455 if(newText.length() > 0) 457 if(newText.length() > 0)
456 newProfileButton->setEnabled(true); 458 newProfileButton->setEnabled(true);
457 else 459 else
458 newProfileButton->setEnabled(false); 460 newProfileButton->setEnabled(false);
459} 461}
460 462
461/** 463/**
462 * Adds a new profile to the list of profiles. 464 * Adds a new profile to the list of profiles.
463 * Don't add profiles that already exists. 465 * Don't add profiles that already exists.
464 * Appends to the list and QStringList 466 * Appends to the list and QStringList
465 */ 467 */
466void MainWindowImp::addProfile(){ 468void MainWindowImp::addProfile(){
467 QString newProfileName = newProfile->text(); 469 QString newProfileName = newProfile->text();
468 if(profiles.grep(newProfileName).count() > 0){ 470 if(profiles.grep(newProfileName).count() > 0){
469 QMessageBox::information(this, "Can't Add","Profile already exists.", "Ok"); 471 QMessageBox::information(this, "Can't Add","Profile already exists.", "Ok");
470 return; 472 return;
471 } 473 }
472 profiles.append(newProfileName); 474 profiles.append(newProfileName);
473 profilesList->insertItem(newProfileName); 475 profilesList->insertItem(newProfileName);
474} 476}
475 477
476/** 478/**
477 * Removes the currently selected profile in the combo. 479 * Removes the currently selected profile in the combo.
478 * Doesn't delete if there are less then 2 profiles. 480 * Doesn't delete if there are less then 2 profiles.
479 */ 481 */
480void MainWindowImp::removeProfile(){ 482void MainWindowImp::removeProfile(){
481 if(profilesList->count() <= 1){ 483 if(profilesList->count() <= 1){
482 QMessageBox::information(this, "Can't remove.","At least one profile\nis needed.", "Ok"); 484 QMessageBox::information(this, "Can't remove.","At least one profile\nis needed.", "Ok");
483 return; 485 return;
484 } 486 }
485 QString profileToRemove = profilesList->currentText(); 487 QString profileToRemove = profilesList->currentText();
486 if(profileToRemove == "All"){ 488 if(profileToRemove == "All"){
487 QMessageBox::information(this, "Can't remove.","Can't remove default.", "Ok"); 489 QMessageBox::information(this, "Can't remove.","Can't remove default.", "Ok");
488 return; 490 return;
489 } 491 }
490 // Can't remove the curent profile 492 // Can't remove the curent profile
491 if(profileToRemove == currentProfileLabel->text()){ 493 if(profileToRemove == currentProfileLabel->text()){
492 QMessageBox::information(this, "Can't remove.",QString("%1 is the current profile.").arg(profileToRemove), "Ok"); 494 QMessageBox::information(this, "Can't remove.",QString("%1 is the current profile.").arg(profileToRemove), "Ok");
493 return; 495 return;
494 496
495 } 497 }
496 498
497 if(QMessageBox::information(this, "Question",QString("Remove profile: %1").arg(profileToRemove), QMessageBox::Ok, QMessageBox::Cancel) == QMessageBox::Ok){ 499 if(QMessageBox::information(this, "Question",QString("Remove profile: %1").arg(profileToRemove), QMessageBox::Ok, QMessageBox::Cancel) == QMessageBox::Ok){
498 profiles = QStringList::split(" ", profiles.join(" ").replace(QRegExp(profileToRemove), "")); 500 profiles = QStringList::split(" ", profiles.join(" ").replace(QRegExp(profileToRemove), ""));
499 profilesList->clear(); 501 profilesList->clear();
500 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it) 502 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it)
501 profilesList->insertItem((*it)); 503 profilesList->insertItem((*it));
502 504
503 // Remove any interface settings and mappings. 505 // Remove any interface settings and mappings.
504 Interfaces interfaces; 506 Interfaces interfaces;
505 // Go through them one by one 507 // Go through them one by one
506 QMap<Interface*, QListViewItem*>::Iterator it; 508 QMap<Interface*, QListViewItem*>::Iterator it;
507 for( it = items.begin(); it != items.end(); ++it ){ 509 for( it = items.begin(); it != items.end(); ++it ){
508 QString interfaceName = it.key()->getInterfaceName(); 510 QString interfaceName = it.key()->getInterfaceName();
509 qDebug(interfaceName.latin1()); 511 qDebug(interfaceName.latin1());
510 if(interfaces.setInterface(interfaceName + "_" + profileToRemove)){ 512 if(interfaces.setInterface(interfaceName + "_" + profileToRemove)){
511 interfaces.removeInterface(); 513 interfaces.removeInterface();
512 if(interfaces.setMapping(interfaceName)){ 514 if(interfaces.setMapping(interfaceName)){
513 if(profilesList->count() == 1) 515 if(profilesList->count() == 1)
514 interfaces.removeMapping(); 516 interfaces.removeMapping();
515 else{ 517 else{
516 interfaces.removeMap("map", interfaceName + "_" + profileToRemove); 518 interfaces.removeMap("map", interfaceName + "_" + profileToRemove);
517 } 519 }
518 } 520 }
519 interfaces.write(); 521 interfaces.write();
520 break; 522 break;
521 } 523 }
522 } 524 }
523 } 525 }
524} 526}
525 527
526/** 528/**
527 * A new profile has been selected, change. 529 * A new profile has been selected, change.
528 * @param newProfile the new profile. 530 * @param newProfile the new profile.
529 */ 531 */
530void MainWindowImp::changeProfile(){ 532void MainWindowImp::changeProfile(){
531 if(profilesList->currentItem() == -1){ 533 if(profilesList->currentItem() == -1){
532 QMessageBox::information(this, "Can't Change.","Please select a profile.", "Ok"); 534 QMessageBox::information(this, "Can't Change.","Please select a profile.", "Ok");
533 return; 535 return;
534 } 536 }
535 QString newProfile = profilesList->text(profilesList->currentItem()); 537 QString newProfile = profilesList->text(profilesList->currentItem());
536 if(newProfile != currentProfileLabel->text()){ 538 if(newProfile != currentProfileLabel->text()){
537 currentProfileLabel->setText(newProfile); 539 currentProfileLabel->setText(newProfile);
538 QFile::remove(scheme); 540 QFile::remove(scheme);
539 QFile file(scheme); 541 QFile file(scheme);
540 if ( file.open(IO_ReadWrite) ) { 542 if ( file.open(IO_ReadWrite) ) {
541 QTextStream stream( &file ); 543 QTextStream stream( &file );
542 stream << QString("SCHEME=%1").arg(newProfile); 544 stream << QString("SCHEME=%1").arg(newProfile);
543 file.close(); 545 file.close();
544 } 546 }
545 // restart all up devices? 547 // restart all up devices?
546 if(QMessageBox::information(this, "Question","Restart all running interfaces?", QMessageBox::Ok, QMessageBox::No) == QMessageBox::Ok){ 548 if(QMessageBox::information(this, "Question","Restart all running interfaces?", QMessageBox::Ok, QMessageBox::No) == QMessageBox::Ok){
547 // Go through them one by one 549 // Go through them one by one
548 QMap<Interface*, QListViewItem*>::Iterator it; 550 QMap<Interface*, QListViewItem*>::Iterator it;
549 for( it = items.begin(); it != items.end(); ++it ){ 551 for( it = items.begin(); it != items.end(); ++it ){
550 if(it.key()->getStatus() == true) 552 if(it.key()->getStatus() == true)
551 it.key()->restart(); 553 it.key()->restart();
552 } 554 }
553 } 555 }
554 } 556 }
555} 557}
556 558
557// mainwindowimp.cpp 559// mainwindowimp.cpp
558 560
diff --git a/noncore/net/networksetup/wlan/wextensions.cpp b/noncore/net/networksetup/wlan/wextensions.cpp
index ef4ba8f..e545bd1 100644
--- a/noncore/net/networksetup/wlan/wextensions.cpp
+++ b/noncore/net/networksetup/wlan/wextensions.cpp
@@ -1,175 +1,175 @@
1#include "wextensions.h" 1#include "wextensions.h"
2 2
3#include <qfile.h> 3#include <qfile.h>
4#include <qtextstream.h> 4#include <qtextstream.h>
5 5
6#include <arpa/inet.h> 6#include <arpa/inet.h>
7#include <sys/socket.h> 7#include <sys/socket.h>
8#include <sys/ioctl.h> 8#include <sys/ioctl.h>
9 9
10#include <math.h> 10#include <math.h>
11 11
12#define PROCNETWIRELESS "/proc/net/wireless" 12#define PROCNETWIRELESS "/proc/net/wireless"
13#define IW_LOWER 0 13#define IW_LOWER 0
14#define IW_UPPER 256 14#define IW_UPPER 256
15 15
16/** 16/**
17 * Constructor. Sets hasWirelessExtensions 17 * Constructor. Sets hasWirelessExtensions
18 */ 18 */
19WExtensions::WExtensions(QString interfaceName){ 19WExtensions::WExtensions(QString interfaceName){
20 interface = interfaceName; 20 interface = interfaceName;
21 fd = socket( AF_INET, SOCK_DGRAM, 0 ); 21 fd = socket( AF_INET, SOCK_DGRAM, 0 );
22 22
23 const char* buffer[200]; 23 const char* buffer[200];
24 memset( &iwr, 0, sizeof( iwr ) ); 24 memset( &iwr, 0, sizeof( iwr ) );
25 iwr.u.essid.pointer = (caddr_t) buffer; 25 iwr.u.essid.pointer = (caddr_t) buffer;
26 iwr.u.essid.length = IW_ESSID_MAX_SIZE; 26 iwr.u.essid.length = IW_ESSID_MAX_SIZE;
27 iwr.u.essid.flags = 0; 27 iwr.u.essid.flags = 0;
28 28
29 // check if it is an IEEE 802.11 standard conform 29 // check if it is an IEEE 802.11 standard conform
30 // wireless device by sending SIOCGIWESSID 30 // wireless device by sending SIOCGIWESSID
31 // which also gives back the Extended Service Set ID 31 // which also gives back the Extended Service Set ID
32 // (see IEEE 802.11 for more information) 32 // (see IEEE 802.11 for more information)
33 33
34 const char* iname = interface.latin1(); 34 const char* iname = interface.latin1();
35 strcpy( iwr.ifr_ifrn.ifrn_name, (const char *)iname ); 35 strcpy( iwr.ifr_ifrn.ifrn_name, (const char *)iname );
36 if ( 0 == ioctl( fd, SIOCGIWESSID, &iwr ) ) 36 if ( 0 == ioctl( fd, SIOCGIWESSID, &iwr ) )
37 hasWirelessExtensions = true; 37 hasWirelessExtensions = true;
38 else 38 else
39 hasWirelessExtensions = false; 39 hasWirelessExtensions = false;
40} 40}
41 41
42/** 42/**
43 * @return QString the station name of the access point. 43 * @return QString the station name of the access point.
44 */ 44 */
45QString WExtensions::station(){ 45QString WExtensions::station(){
46 if(!hasWirelessExtensions) 46 if(!hasWirelessExtensions)
47 return QString(); 47 return QString();
48 const char* buffer[200]; 48 const char* buffer[200];
49 iwr.u.data.pointer = (caddr_t) buffer; 49 iwr.u.data.pointer = (caddr_t) buffer;
50 iwr.u.data.length = IW_ESSID_MAX_SIZE; 50 iwr.u.data.length = IW_ESSID_MAX_SIZE;
51 iwr.u.data.flags = 0; 51 iwr.u.data.flags = 0;
52 if ( 0 == ioctl( fd, SIOCGIWNICKN, &iwr )){ 52 if ( 0 == ioctl( fd, SIOCGIWNICKN, &iwr )){
53 iwr.u.data.pointer[(unsigned int) iwr.u.data.length-1] = '\0'; 53 iwr.u.data.pointer[(unsigned int) iwr.u.data.length-1] = '\0';
54 return QString(iwr.u.data.pointer); 54 return QString(iwr.u.data.pointer);
55 } 55 }
56 return QString(); 56 return QString();
57} 57}
58 58
59/** 59/**
60 * @return QString the essid of the host 802.11 access point. 60 * @return QString the essid of the host 802.11 access point.
61 */ 61 */
62QString WExtensions::essid(){ 62QString WExtensions::essid(){
63 if(!hasWirelessExtensions) 63 if(!hasWirelessExtensions)
64 return QString(); 64 return QString();
65 if ( 0 == ioctl( fd, SIOCGIWESSID, &iwr )){ 65 if ( 0 == ioctl( fd, SIOCGIWESSID, &iwr )){
66 iwr.u.essid.pointer[(unsigned int) iwr.u.essid.length-1] = '\0'; 66 iwr.u.essid.pointer[(unsigned int) iwr.u.essid.length-1] = '\0';
67 return QString(iwr.u.essid.pointer); 67 return QString(iwr.u.essid.pointer);
68 } 68 }
69 return QString(); 69 return QString();
70} 70}
71 71
72/** 72/**
73 * @return QString the mode of interface 73 * @return QString the mode of interface
74 */ 74 */
75QString WExtensions::mode(){ 75QString WExtensions::mode(){
76 if(!hasWirelessExtensions) 76 if(!hasWirelessExtensions)
77 return QString(); 77 return QString();
78 if ( 0 == ioctl( fd, SIOCGIWMODE, &iwr ) ) 78 if ( 0 == ioctl( fd, SIOCGIWMODE, &iwr ) )
79 return QString("%1").arg(iwr.u.mode == IW_MODE_ADHOC ? "Ad-Hoc" : "Managed"); 79 return QString("%1").arg(iwr.u.mode == IW_MODE_ADHOC ? "Ad-Hoc" : "Managed");
80 return QString(); 80 return QString();
81} 81}
82 82
83/** 83/**
84 * Get the frequency that the interface is running at. 84 * Get the frequency that the interface is running at.
85 * @return int the frequency that the interfacae is running at. 85 * @return int the frequency that the interfacae is running at.
86 */ 86 */
87double WExtensions::frequency(){ 87double WExtensions::frequency(){
88 if(!hasWirelessExtensions) 88 if(!hasWirelessExtensions)
89 return 0; 89 return 0;
90 if ( 0 == ioctl( fd, SIOCGIWFREQ, &iwr )) 90 if ( 0 == ioctl( fd, SIOCGIWFREQ, &iwr ))
91 return (double( iwr.u.freq.m ) * pow( 10, iwr.u.freq.e ) / 1000000000); 91 return (double( iwr.u.freq.m ) * pow( 10, iwr.u.freq.e ) / 1000000000);
92 return 0; 92 return 0;
93} 93}
94 94
95/*** 95/***
96 * Get the current rate that the card is transmiting at. 96 * Get the current rate that the card is transmiting at.
97 */ 97 */
98double WExtensions::rate(){ 98double WExtensions::rate(){
99 if(!hasWirelessExtensions) 99 if(!hasWirelessExtensions)
100 return 0; 100 return 0;
101 if(0 == ioctl(fd, SIOCGIWRATE, &iwr)){ 101 if(0 == ioctl(fd, SIOCGIWRATE, &iwr)){
102 return ((double)iwr.u.bitrate.value)/1000000; 102 return ((double)iwr.u.bitrate.value)/1000000;
103 } 103 }
104 return 0; 104 return 0;
105} 105}
106 106
107 107
108/** 108/**
109 * @return QString the AccessPoint that the interface is connected to. 109 * @return QString the AccessPoint that the interface is connected to.
110 */ 110 */
111QString WExtensions::ap(){ 111QString WExtensions::ap(){
112 if(!hasWirelessExtensions) 112 if(!hasWirelessExtensions)
113 return QString(); 113 return QString();
114 if ( 0 == ioctl( fd, SIOCGIWAP, &iwr )){ 114 if ( 0 == ioctl( fd, SIOCGIWAP, &iwr )){
115 QString ap; 115 QString ap;
116 ap = ap.sprintf( "%.2X:%.2X:%.2X:%.2X:%.2X:%.2X", 116 ap = ap.sprintf( "%.2X:%.2X:%.2X:%.2X:%.2X:%.2X",
117 iwr.u.ap_addr.sa_data[0]&0xff, 117 iwr.u.ap_addr.sa_data[0]&0xff,
118 iwr.u.ap_addr.sa_data[1]&0xff, 118 iwr.u.ap_addr.sa_data[1]&0xff,
119 iwr.u.ap_addr.sa_data[2]&0xff, 119 iwr.u.ap_addr.sa_data[2]&0xff,
120 iwr.u.ap_addr.sa_data[3]&0xff, 120 iwr.u.ap_addr.sa_data[3]&0xff,
121 iwr.u.ap_addr.sa_data[4]&0xff, 121 iwr.u.ap_addr.sa_data[4]&0xff,
122 iwr.u.ap_addr.sa_data[5]&0xff ); 122 iwr.u.ap_addr.sa_data[5]&0xff );
123 return ap; 123 return ap;
124 } 124 }
125 else return QString(); 125 else return QString();
126} 126}
127 127
128/** 128/**
129 * Get the stats for interfaces 129 * Get the stats for interfaces
130 * @param signal the signal strength of interface 130 * @param signal the signal strength of interface
131 * @param noise the noise level of the interface 131 * @param noise the noise level of the interface
132 * @param quality the quality level of the interface 132 * @param quality the quality level of the interface
133 * @return bool true if successfull 133 * @return bool true if successfull
134 */ 134 */
135bool WExtensions::stats(int &signal, int &noise, int &quality){ 135bool WExtensions::stats(int &signal, int &noise, int &quality){
136 // gather link quality from /proc/net/wireless 136 // gather link quality from /proc/net/wireless
137 if(!QFile::exists(PROCNETWIRELESS)) 137 if(!QFile::exists(PROCNETWIRELESS))
138 return false; 138 return false;
139 139
140 char c; 140 char c;
141 QString status; 141 QString status;
142 QString name; 142 QString name;
143 143
144 QFile wfile( PROCNETWIRELESS ); 144 QFile wfile( PROCNETWIRELESS );
145 if(!wfile.open( IO_ReadOnly )) 145 if(!wfile.open( IO_ReadOnly ))
146 return false; 146 return false;
147 147
148 QTextStream wstream( &wfile ); 148 QTextStream wstream( &wfile );
149 wstream.readLine(); // skip the first two lines 149 wstream.readLine(); // skip the first two lines
150 wstream.readLine(); // because they only contain headers 150 wstream.readLine(); // because they only contain headers
151 while(!wstream.atEnd()){ 151 while(!wstream.atEnd()){
152 wstream >> name >> status >> quality >> c >> signal >> c >> noise; 152 wstream >> name >> status >> quality >> c >> signal >> c >> noise;
153 if(name == QString("%1:").arg(interface)){ 153 if(name == QString("%1:").arg(interface)){
154 if ( quality > 92 ) 154 if ( quality > 92 )
155 qDebug( "WIFIAPPLET: D'oh! Quality %d > estimated max!\n", quality ); 155 qDebug( "WIFIAPPLET: D'oh! Quality %d > estimated max!\n", quality );
156 if ( ( signal > IW_UPPER ) || ( signal < IW_LOWER ) ) 156 if ( ( signal > IW_UPPER ) || ( signal < IW_LOWER ) )
157 qDebug( "WIFIAPPLET: Doh! Strength %d > estimated max!\n", signal ); 157 qDebug( "WIFIAPPLET: Doh! Strength %d > estimated max!\n", signal );
158 if ( ( noise > IW_UPPER ) || ( noise < IW_LOWER ) ) 158 if ( ( noise > IW_UPPER ) || ( noise < IW_LOWER ) )
159 qDebug( "WIFIAPPLET: Doh! Noise %d > estimated max!\n", noise ); 159 qDebug( "WIFIAPPLET: Doh! Noise %d > estimated max!\n", noise );
160 qDebug(QString("q:%1, s:%2, n:%3").arg(quality).arg(signal).arg(noise).latin1()); 160 //qDebug(QString("q:%1, s:%2, n:%3").arg(quality).arg(signal).arg(noise).latin1());
161 signal = ( ( signal-IW_LOWER ) * 100 ) / IW_UPPER; 161 signal = ( ( signal-IW_LOWER ) * 100 ) / IW_UPPER;
162 noise = ( ( noise-IW_LOWER ) * 100 ) / IW_UPPER; 162 noise = ( ( noise-IW_LOWER ) * 100 ) / IW_UPPER;
163 quality = ( quality*100 ) / 92; 163 quality = ( quality*100 ) / 92;
164 return true; 164 return true;
165 } 165 }
166 } 166 }
167 167
168 qDebug("WExtensions::statsCard no longer present."); 168 qDebug("WExtensions::statsCard no longer present.");
169 quality = -1; 169 quality = -1;
170 signal = IW_LOWER; 170 signal = IW_LOWER;
171 noise = IW_LOWER; 171 noise = IW_LOWER;
172 return false; 172 return false;
173} 173}
174 174
175// wextensions.cpp 175// wextensions.cpp
diff --git a/noncore/net/networksetup/wlan/wlanimp.cpp b/noncore/net/networksetup/wlan/wlanimp.cpp
index ea19207..94c7518 100644
--- a/noncore/net/networksetup/wlan/wlanimp.cpp
+++ b/noncore/net/networksetup/wlan/wlanimp.cpp
@@ -1,239 +1,239 @@
1#include "wlanimp.h" 1#include "wlanimp.h"
2 2
3/* Config class */ 3/* Config class */
4#include <qpe/config.h> 4#include <qpe/config.h>
5/* Global namespace */ 5/* Global namespace */
6#include <qpe/global.h> 6#include <qpe/global.h>
7/* system() */ 7/* system() */
8#include <stdlib.h> 8#include <stdlib.h>
9#include <qfile.h> 9#include <qfile.h>
10#include <qdir.h> 10#include <qdir.h>
11#include <qtextstream.h> 11#include <qtextstream.h>
12#include <qmessagebox.h> 12#include <qmessagebox.h>
13#include <qlineedit.h> 13#include <qlineedit.h>
14#include <qspinbox.h> 14#include <qspinbox.h>
15#include <qradiobutton.h> 15#include <qradiobutton.h>
16#include <qcheckbox.h> 16#include <qcheckbox.h>
17#include <qregexp.h> 17#include <qregexp.h>
18 18
19WLANImp::WLANImp( QWidget* parent, const char* name):WLAN(parent, name){ 19WLANImp::WLANImp( QWidget* parent, const char* name):WLAN(parent, name, Qt::WDestructiveClose){
20 config = new Config("wireless"); 20 config = new Config("wireless");
21 readConfig(); 21 readConfig();
22} 22}
23 23
24WLANImp::~WLANImp( ){ 24WLANImp::~WLANImp( ){
25 delete config; 25 delete config;
26} 26}
27 27
28void WLANImp::readConfig() 28void WLANImp::readConfig()
29{ 29{
30 qWarning( "WLANImp::readConfig() called." ); 30 qWarning( "WLANImp::readConfig() called." );
31 config->setGroup( "Properties" ); 31 config->setGroup( "Properties" );
32 QString ssid = config->readEntry( "SSID", "any" ); 32 QString ssid = config->readEntry( "SSID", "any" );
33 if( ssid == "any" || ssid == "ANY" ){ 33 if( ssid == "any" || ssid == "ANY" ){
34 essNon->setChecked( true ); 34 essNon->setChecked( true );
35 } else { 35 } else {
36 essSpecific->setChecked( true ); 36 essSpecific->setChecked( true );
37 essSpecificLineEdit->setText( ssid ); 37 essSpecificLineEdit->setText( ssid );
38 } 38 }
39 QString mode = config->readEntry( "Mode", "Managed" ); 39 QString mode = config->readEntry( "Mode", "Managed" );
40 if( mode == "adhoc" ) { 40 if( mode == "adhoc" ) {
41 network802->setChecked( true ); 41 network802->setChecked( true );
42 } else { 42 } else {
43 networkInfrastructure->setChecked( true ); 43 networkInfrastructure->setChecked( true );
44 } 44 }
45 networkChannel->setValue( config->readNumEntry( "CHANNEL", 1 ) ); 45 networkChannel->setValue( config->readNumEntry( "CHANNEL", 1 ) );
46// config->readEntry( "RATE", "auto" ); 46// config->readEntry( "RATE", "auto" );
47 config->readEntry( "dot11PrivacyInvoked" ) == "true" ? wepEnabled->setChecked( true ) : wepEnabled->setChecked( false ); 47 config->readEntry( "dot11PrivacyInvoked" ) == "true" ? wepEnabled->setChecked( true ) : wepEnabled->setChecked( false );
48 config->readEntry( "AuthType", "opensystem" ); 48 config->readEntry( "AuthType", "opensystem" );
49 config->readEntry( "PRIV_KEY128", "false" ) == "false" ? key40->setChecked( true ) : key128->setChecked( true ); 49 config->readEntry( "PRIV_KEY128", "false" ) == "false" ? key40->setChecked( true ) : key128->setChecked( true );
50 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 ); 50 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 );
51 switch( defaultkey ){ 51 switch( defaultkey ){
52 case 0: 52 case 0:
53 keyRadio0->setChecked( true ); 53 keyRadio0->setChecked( true );
54 break; 54 break;
55 case 1: 55 case 1:
56 keyRadio1->setChecked( true ); 56 keyRadio1->setChecked( true );
57 break; 57 break;
58 case 2: 58 case 2:
59 keyRadio2->setChecked( true ); 59 keyRadio2->setChecked( true );
60 break; 60 break;
61 case 3: 61 case 3:
62 keyRadio3->setChecked( true ); 62 keyRadio3->setChecked( true );
63 break; 63 break;
64 } 64 }
65 keyLineEdit0->setText(config->readEntry( "dot11WEPDefaultKey0" )); 65 keyLineEdit0->setText(config->readEntry( "dot11WEPDefaultKey0" ));
66 keyLineEdit1->setText(config->readEntry( "dot11WEPDefaultKey1" )); 66 keyLineEdit1->setText(config->readEntry( "dot11WEPDefaultKey1" ));
67 keyLineEdit2->setText(config->readEntry( "dot11WEPDefaultKey2" )); 67 keyLineEdit2->setText(config->readEntry( "dot11WEPDefaultKey2" ));
68 keyLineEdit3->setText(config->readEntry( "dot11WEPDefaultKey3" )); 68 keyLineEdit3->setText(config->readEntry( "dot11WEPDefaultKey3" ));
69 return; 69 return;
70} 70}
71 71
72bool WLANImp::writeConfig() 72bool WLANImp::writeConfig()
73{ 73{
74 qWarning( "WLANImp::writeConfig() called." ); 74 qWarning( "WLANImp::writeConfig() called." );
75 config->setGroup( "Properties" ); 75 config->setGroup( "Properties" );
76 if( essNon->isChecked() ) { 76 if( essNon->isChecked() ) {
77 config->writeEntry( "SSID", "any" ); 77 config->writeEntry( "SSID", "any" );
78 } else { 78 } else {
79 config->writeEntry( "SSID", essSpecificLineEdit->text() ); 79 config->writeEntry( "SSID", essSpecificLineEdit->text() );
80 } 80 }
81 if( networkInfrastructure->isChecked() ){ 81 if( networkInfrastructure->isChecked() ){
82 config->writeEntry( "Mode", "Managed" ); 82 config->writeEntry( "Mode", "Managed" );
83 } else if( network802->isChecked() ){ 83 } else if( network802->isChecked() ){
84 config->writeEntry( "Mode", "adhoc" ); 84 config->writeEntry( "Mode", "adhoc" );
85 } 85 }
86 config->writeEntry( "CHANNEL", networkChannel->value() ); 86 config->writeEntry( "CHANNEL", networkChannel->value() );
87// config->readEntry( "RATE", "auto" ); 87// config->readEntry( "RATE", "auto" );
88 wepEnabled->isChecked() ? config->writeEntry( "dot11PrivacyInvoked", "true" ) : config->writeEntry( "dot11PrivacyInvoked", "false" ); 88 wepEnabled->isChecked() ? config->writeEntry( "dot11PrivacyInvoked", "true" ) : config->writeEntry( "dot11PrivacyInvoked", "false" );
89 authOpen->isChecked() ? config->writeEntry( "AuthType", "opensystem" ) : config->writeEntry( "AuthType", "sharedkey" ); 89 authOpen->isChecked() ? config->writeEntry( "AuthType", "opensystem" ) : config->writeEntry( "AuthType", "sharedkey" );
90 key40->isChecked() ? config->writeEntry( "PRIV_KEY128", "false" ) : config->writeEntry( "PRIV_KEY128", "true" ); 90 key40->isChecked() ? config->writeEntry( "PRIV_KEY128", "false" ) : config->writeEntry( "PRIV_KEY128", "true" );
91 if( keyRadio0->isChecked() ){ 91 if( keyRadio0->isChecked() ){
92 config->writeEntry( "dot11WEPDefaultKeyID", 0 ); 92 config->writeEntry( "dot11WEPDefaultKeyID", 0 );
93 } else if( keyRadio1->isChecked() ){ 93 } else if( keyRadio1->isChecked() ){
94 config->writeEntry( "dot11WEPDefaultKeyID", 1 ); 94 config->writeEntry( "dot11WEPDefaultKeyID", 1 );
95 } else if( keyRadio2->isChecked() ){ 95 } else if( keyRadio2->isChecked() ){
96 config->writeEntry( "dot11WEPDefaultKeyID", 2 ); 96 config->writeEntry( "dot11WEPDefaultKeyID", 2 );
97 } else if( keyRadio3->isChecked() ){ 97 } else if( keyRadio3->isChecked() ){
98 config->writeEntry( "dot11WEPDefaultKeyID", 3 ); 98 config->writeEntry( "dot11WEPDefaultKeyID", 3 );
99 } 99 }
100 config->writeEntry( "dot11WEPDefaultKey0", keyLineEdit0->text() ); 100 config->writeEntry( "dot11WEPDefaultKey0", keyLineEdit0->text() );
101 config->writeEntry( "dot11WEPDefaultKey1", keyLineEdit1->text() ); 101 config->writeEntry( "dot11WEPDefaultKey1", keyLineEdit1->text() );
102 config->writeEntry( "dot11WEPDefaultKey2", keyLineEdit2->text() ); 102 config->writeEntry( "dot11WEPDefaultKey2", keyLineEdit2->text() );
103 config->writeEntry( "dot11WEPDefaultKey3", keyLineEdit3->text() ); 103 config->writeEntry( "dot11WEPDefaultKey3", keyLineEdit3->text() );
104 return writeWirelessOpts( ); 104 return writeWirelessOpts( );
105} 105}
106 106
107/** 107/**
108 */ 108 */
109void WLANImp::accept() 109void WLANImp::accept()
110{ 110{
111 if ( writeConfig() ) 111 if ( writeConfig() )
112 QDialog::accept(); 112 QDialog::accept();
113} 113}
114 114
115void WLANImp::done ( int r ) 115void WLANImp::done ( int r )
116{ 116{
117 QDialog::done ( r ); 117 QDialog::done ( r );
118 close ( ); 118 close ( );
119} 119}
120 120
121bool WLANImp::writeWirelessOpts( QString scheme ) 121bool WLANImp::writeWirelessOpts( QString scheme )
122{ 122{
123 qWarning( "WLANImp::writeWirelessOpts entered." ); 123 qWarning( "WLANImp::writeWirelessOpts entered." );
124 QString prev = "/etc/pcmcia/wireless.opts"; 124 QString prev = "/etc/pcmcia/wireless.opts";
125 QFile prevFile(prev); 125 QFile prevFile(prev);
126 if ( !prevFile.open( IO_ReadOnly ) ) 126 if ( !prevFile.open( IO_ReadOnly ) )
127 return false; 127 return false;
128 128
129 QString tmp = "/etc/pcmcia/wireless.opts-qpe-new"; 129 QString tmp = "/etc/pcmcia/wireless.opts-qpe-new";
130 QFile tmpFile(tmp); 130 QFile tmpFile(tmp);
131 if ( !tmpFile.open( IO_WriteOnly ) ) 131 if ( !tmpFile.open( IO_WriteOnly ) )
132 return false; 132 return false;
133 133
134 bool retval = true; 134 bool retval = true;
135 135
136 QTextStream in( &prevFile ); 136 QTextStream in( &prevFile );
137 QTextStream out( &tmpFile ); 137 QTextStream out( &tmpFile );
138 138
139 config->setGroup("Properties"); 139 config->setGroup("Properties");
140 140
141 QString line; 141 QString line;
142 bool found=false; 142 bool found=false;
143 bool done=false; 143 bool done=false;
144 while ( !in.atEnd() ) { 144 while ( !in.atEnd() ) {
145 QString line = in.readLine(); 145 QString line = in.readLine();
146 QString wline = line.simplifyWhiteSpace(); 146 QString wline = line.simplifyWhiteSpace();
147 if ( !done ) { 147 if ( !done ) {
148 if ( found ) { 148 if ( found ) {
149 // skip existing entry for this scheme, and write our own. 149 // skip existing entry for this scheme, and write our own.
150 if ( wline == ";;" ) { 150 if ( wline == ";;" ) {
151 found = false; 151 found = false;
152 continue; 152 continue;
153 } else { 153 } else {
154 continue; 154 continue;
155 } 155 }
156 } else { 156 } else {
157 if ( wline.left(scheme.length()+7) == scheme + ",*,*,*)" ) { 157 if ( wline.left(scheme.length()+7) == scheme + ",*,*,*)" ) {
158 found=true; 158 found=true;
159 continue; // skip this line 159 continue; // skip this line
160 } else if ( wline == "esac" || wline == "*,*,*,*)" ) { 160 } else if ( wline == "esac" || wline == "*,*,*,*)" ) {
161 // end - add new entry 161 // end - add new entry
162 // Not all fields have a GUI, but all are supported 162 // Not all fields have a GUI, but all are supported
163 // in the letwork configuration files. 163 // in the letwork configuration files.
164 static const char* txtfields[] = { 164 static const char* txtfields[] = {
165 0 165 0
166 }; 166 };
167 QString readmode = config->readEntry( "Mode", "Managed" ); 167 QString readmode = config->readEntry( "Mode", "Managed" );
168 QString mode; 168 QString mode;
169 if( readmode == "Managed" ){ 169 if( readmode == "Managed" ){
170 mode = readmode; 170 mode = readmode;
171 } else if( readmode == "adhoc" ){ 171 } else if( readmode == "adhoc" ){
172 mode = "Ad-Hoc"; 172 mode = "Ad-Hoc";
173 } 173 }
174 QString key; 174 QString key;
175 if( wepEnabled->isChecked() ){ 175 if( wepEnabled->isChecked() ){
176 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 ); 176 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 );
177 switch( defaultkey ){ 177 switch( defaultkey ){
178 case 0: 178 case 0:
179 key += keyLineEdit0->text(); 179 key += keyLineEdit0->text();
180 break; 180 break;
181 case 1: 181 case 1:
182 key += keyLineEdit1->text(); 182 key += keyLineEdit1->text();
183 break; 183 break;
184 case 2: 184 case 2:
185 key += keyLineEdit2->text(); 185 key += keyLineEdit2->text();
186 break; 186 break;
187 case 3: 187 case 3:
188 key += keyLineEdit3->text(); 188 key += keyLineEdit3->text();
189 break; 189 break;
190 } 190 }
191 if( config->readEntry( "AuthType", "opensystem" ) == "opensystem") 191 if( config->readEntry( "AuthType", "opensystem" ) == "opensystem")
192 key += " open"; 192 key += " open";
193 } 193 }
194 out << scheme << ",*,*,*)" << "\n" 194 out << scheme << ",*,*,*)" << "\n"
195 << " ESSID=" << Global::shellQuote( config->readEntry( "SSID", "any" ) ) << "\n" 195 << " ESSID=" << Global::shellQuote( config->readEntry( "SSID", "any" ) ) << "\n"
196 << " MODE=" << mode << "\n" 196 << " MODE=" << mode << "\n"
197 << " KEY=" << Global::shellQuote( key ) << "\n" 197 << " KEY=" << Global::shellQuote( key ) << "\n"
198 << " RATE=" << "auto" << "\n" 198 << " RATE=" << "auto" << "\n"
199 ; 199 ;
200 if( mode != "Managed" ) 200 if( mode != "Managed" )
201 out << " CHANNEL=" << config->readNumEntry( "CHANNEL", 1 ) << "\n"; 201 out << " CHANNEL=" << config->readNumEntry( "CHANNEL", 1 ) << "\n";
202 const char** f = txtfields; 202 const char** f = txtfields;
203 while (*f) { 203 while (*f) {
204 out << " " << *f << "=" << config->readEntry(*f,"") << "\n"; 204 out << " " << *f << "=" << config->readEntry(*f,"") << "\n";
205 ++f; 205 ++f;
206 } 206 }
207 out << " ;;\n"; 207 out << " ;;\n";
208 done = true; 208 done = true;
209 } 209 }
210 } 210 }
211 } 211 }
212 out << line << "\n"; 212 out << line << "\n";
213 } 213 }
214 214
215 prevFile.close(); 215 prevFile.close();
216 tmpFile.close(); 216 tmpFile.close();
217 QString initpath; 217 QString initpath;
218 //system("cardctl suspend"); 218 //system("cardctl suspend");
219 if( QDir("/etc/rc.d/init.d").exists() ){ 219 if( QDir("/etc/rc.d/init.d").exists() ){
220 initpath = "/etc/rc.d/init.d"; 220 initpath = "/etc/rc.d/init.d";
221 } else if( QDir("/etc/init.d").exists() ){ 221 } else if( QDir("/etc/init.d").exists() ){
222 initpath = "/etc/init.d"; 222 initpath = "/etc/init.d";
223 } 223 }
224 if( initpath ) 224 if( initpath )
225 system(QString("%1/pcmcia stop").arg(initpath)); 225 system(QString("%1/pcmcia stop").arg(initpath));
226 226
227 if( system( "mv " + tmp + " " + prev ) ) 227 if( system( "mv " + tmp + " " + prev ) )
228 retval = false; 228 retval = false;
229//#ifdef USE_SCHEMES 229//#ifdef USE_SCHEMES
230// if ( retval ) 230// if ( retval )
231 //SchemeChanger::changeScheme(scheme); 231 //SchemeChanger::changeScheme(scheme);
232//#endif 232//#endif
233 233
234 //system("cardctl resume"); 234 //system("cardctl resume");
235 if( initpath ) 235 if( initpath )
236 system(QString("%1/pcmcia start").arg(initpath)); 236 system(QString("%1/pcmcia start").arg(initpath));
237 237
238 return retval; 238 return retval;
239} 239}
diff --git a/noncore/net/networksetup/wlan/wlanmodule.cpp b/noncore/net/networksetup/wlan/wlanmodule.cpp
index 73e753c..7507c54 100644
--- a/noncore/net/networksetup/wlan/wlanmodule.cpp
+++ b/noncore/net/networksetup/wlan/wlanmodule.cpp
@@ -1,129 +1,129 @@
1#include "wlanmodule.h" 1#include "wlanmodule.h"
2#include "wlanimp.h" 2#include "wlanimp.h"
3#include "info.h" 3#include "info.h"
4#include "wextensions.h" 4#include "wextensions.h"
5 5
6#include <qlabel.h> 6#include <qlabel.h>
7#include <qprogressbar.h> 7#include <qprogressbar.h>
8 8
9/** 9/**
10 * Constructor, find all of the possible interfaces 10 * Constructor, find all of the possible interfaces
11 */ 11 */
12WLANModule::WLANModule() : Module() { 12WLANModule::WLANModule() : Module() {
13 // get output from iwconfig
14} 13}
15 14
16/** 15/**
17 */ 16 */
18WLANModule::~WLANModule(){ 17WLANModule::~WLANModule(){
19 Interface *i; 18 Interface *i;
20 for ( i=list.first(); i != 0; i=list.next() ) 19 for ( i=list.first(); i != 0; i=list.next() )
21 delete i; 20 delete i;
22} 21}
23 22
24/** 23/**
25 * Change the current profile 24 * Change the current profile
26 */ 25 */
27void WLANModule::setProfile(QString newProfile){ 26void WLANModule::setProfile(QString newProfile){
28 profile = newProfile; 27 profile = newProfile;
29} 28}
30 29
31/** 30/**
32 * get the icon name for this device. 31 * get the icon name for this device.
33 * @param Interface* can be used in determining the icon. 32 * @param Interface* can be used in determining the icon.
34 * @return QString the icon name (minus .png, .gif etc) 33 * @return QString the icon name (minus .png, .gif etc)
35 */ 34 */
36QString WLANModule::getPixmapName(Interface* ){ 35QString WLANModule::getPixmapName(Interface* ){
37 return "wlan"; 36 return "wlan";
38} 37}
39 38
40/** 39/**
41 * Check to see if the interface i is owned by this module. 40 * Check to see if the interface i is owned by this module.
42 * @param Interface* interface to check against 41 * @param Interface* interface to check against
43 * @return bool true if i is owned by this module, false otherwise. 42 * @return bool true if i is owned by this module, false otherwise.
44 */ 43 */
45bool WLANModule::isOwner(Interface *i){ 44bool WLANModule::isOwner(Interface *i){
46 WExtensions we(i->getInterfaceName()); 45 WExtensions we(i->getInterfaceName());
47 if(!we.doesHaveWirelessExtensions()) 46 if(!we.doesHaveWirelessExtensions())
48 return false; 47 return false;
49 48
50 //if(i->getInterfaceName() == "eth0" || i->getInterfaceName() == "wlan0"){ 49 i->setHardwareName("802.11b");
51 i->setHardwareName("802.11b"); 50 list.append(i);
52 list.append(i); 51 return true;
53 return true;
54 //}
55 //return false;
56} 52}
57 53
58/** 54/**
59 * Create, set tabWiget and return the WLANConfigure Module 55 * Create, set tabWiget and return the WLANConfigure Module
60 * @param tabWidget a pointer to the tab widget that this configure has. 56 * @param tabWidget a pointer to the tab widget that this configure has.
61 * @return QWidget* pointer to the tab widget in this modules configure. 57 * @return QWidget* pointer to the tab widget in this modules configure.
62 */ 58 */
63QWidget *WLANModule::configure(Interface *, QTabWidget **tabWidget){ 59QWidget *WLANModule::configure(Interface *, QTabWidget **tabWidget){
64 WLANImp *wlanconfig = new WLANImp(0, "WlanConfig"); 60 WLANImp *wlanconfig = new WLANImp(0, "WlanConfig");
65 (*tabWidget) = wlanconfig->tabWidget; 61 (*tabWidget) = wlanconfig->tabWidget;
66 return wlanconfig; 62 return wlanconfig;
67} 63}
68 64
69/** 65/**
70 * Create, set tabWiget and return the Information Module 66 * Create, set tabWiget and return the Information Module
71 * @param tabWidget a pointer to the tab widget that this information has. 67 * @param tabWidget a pointer to the tab widget that this information has.
72 * @return QWidget* pointer to the tab widget in this modules info. 68 * @return QWidget* pointer to the tab widget in this modules info.
73 */ 69 */
74QWidget *WLANModule::information(Interface *i, QTabWidget **tabWidget){ 70QWidget *WLANModule::information(Interface *i, QTabWidget **tabWidget){
75 WExtensions we(i->getInterfaceName()); 71 WExtensions we(i->getInterfaceName());
76 if(!we.doesHaveWirelessExtensions()) 72 if(!we.doesHaveWirelessExtensions())
77 return NULL; 73 return NULL;
78 74
79 WlanInfo *info = new WlanInfo(0, "wireless info"); 75 WlanInfo *info = new WlanInfo(0, "wireless info", Qt::WDestructiveClose);
80 (*tabWidget) = info->tabWidget; 76 (*tabWidget) = info->tabWidget;
81 77
82 info->essidLabel->setText(we.essid()); 78 info->essidLabel->setText(we.essid());
83 info->apLabel->setText(we.ap()); 79 info->apLabel->setText(we.ap());
84 info->stationLabel->setText(we.station()); 80 info->stationLabel->setText(we.station());
85 info->modeLabel->setText(we.mode()); 81 info->modeLabel->setText(we.mode());
86 info->freqLabel->setText(QString("%1 GHz").arg(we.frequency())); 82 info->freqLabel->setText(QString("%1 GHz").arg(we.frequency()));
87 int signal = 0; 83 int signal = 0;
88 int noise = 0; 84 int noise = 0;
89 int quality = 0; 85 int quality = 0;
90 we.stats(signal, noise, quality); 86 we.stats(signal, noise, quality);
91 info->signalProgressBar->setProgress(signal); 87 info->signalProgressBar->setProgress(signal);
92 info->noiseProgressBar->setProgress(noise); 88 info->noiseProgressBar->setProgress(noise);
93 info->qualityProgressBar->setProgress(quality); 89 info->qualityProgressBar->setProgress(quality);
94 info->rateLabel->setText(QString("%1 Mb/s").arg(we.rate())); 90 info->rateLabel->setText(QString("%1 Mb/s").arg(we.rate()));
91 //WlanInfo info (0, "wireless info", true);
92 //info.show();
93 //return NULL;
94
95 return info; 95 return info;
96} 96}
97 97
98/** 98/**
99 * Get all active (up or down) interfaces 99 * Get all active (up or down) interfaces
100 * @return QList<Interface> A list of interfaces that exsist that havn't 100 * @return QList<Interface> A list of interfaces that exsist that havn't
101 * been called by isOwner() 101 * been called by isOwner()
102 */ 102 */
103QList<Interface> WLANModule::getInterfaces(){ 103QList<Interface> WLANModule::getInterfaces(){
104 return list; 104 return list;
105} 105}
106 106
107/** 107/**
108 * Attempt to add a new interface as defined by name 108 * Attempt to add a new interface as defined by name
109 * @param name the name of the type of interface that should be created given 109 * @param name the name of the type of interface that should be created given
110 * by possibleNewInterfaces(); 110 * by possibleNewInterfaces();
111 * @return Interface* NULL if it was unable to be created. 111 * @return Interface* NULL if it was unable to be created.
112 */ 112 */
113Interface *WLANModule::addNewInterface(QString ){ 113Interface *WLANModule::addNewInterface(QString ){
114 // We can't add a 802.11 interface, either the hardware will be there 114 // We can't add a 802.11 interface, either the hardware will be there
115 // or it wont. 115 // or it wont.
116 return NULL; 116 return NULL;
117} 117}
118 118
119/** 119/**
120 * Attempts to remove the interface, doesn't delete i 120 * Attempts to remove the interface, doesn't delete i
121 * @return bool true if successfull, false otherwise. 121 * @return bool true if successfull, false otherwise.
122 */ 122 */
123bool WLANModule::remove(Interface*){ 123bool WLANModule::remove(Interface*){
124 // Can't remove a hardware device, you can stop it though. 124 // Can't remove a hardware device, you can stop it though.
125 return false; 125 return false;
126} 126}
127 127
128// wlanmodule.cpp 128// wlanmodule.cpp
129 129
diff --git a/noncore/settings/networksettings/TODO b/noncore/settings/networksettings/TODO
index 7a71142..d61c510 100644
--- a/noncore/settings/networksettings/TODO
+++ b/noncore/settings/networksettings/TODO
@@ -1,11 +1,9 @@
1WLAN needs to be re-written to not use Config 1WLAN needs to be re-written to not use Config
2-remove WLAN Config item 2WHERE Is DHCP info stored???
3-sub class out the wlan info
4-check if an interface supports wireless extensions before config.
5 3
6PPP module needs to be written 4PPP module needs to be written
7 5
8Write a class that parses /proc and not ifconfig 6Write a class that parses /proc and not ifconfig
9 7
10Possible other modules: ipsec, bluetooth 8Possible other modules: ipsec, bluetooth, ipchains
11 9
diff --git a/noncore/settings/networksettings/interface.cpp b/noncore/settings/networksettings/interface.cpp
index a84b91f..929b3a1 100644
--- a/noncore/settings/networksettings/interface.cpp
+++ b/noncore/settings/networksettings/interface.cpp
@@ -1,287 +1,287 @@
1#include "interface.h" 1#include "interface.h"
2#include <qdatetime.h> 2#include <qdatetime.h>
3#include <qfile.h> 3#include <qfile.h>
4#include <qdir.h> 4#include <qdir.h>
5#include <qfileinfo.h> 5#include <qfileinfo.h>
6#include <qtextstream.h> 6#include <qtextstream.h>
7 7
8#define IFCONFIG "/sbin/ifconfig" 8#define IFCONFIG "/sbin/ifconfig"
9#define HDCP_INFO_DIR "/etc/dhcpc" 9#define DHCP_INFO_DIR "/etc/dhcpc"
10 10
11#include <stdio.h> 11#include <stdio.h>
12#include <stdlib.h> 12#include <stdlib.h>
13 13
14Interface::Interface(QObject * parent, const char * name, bool newSatus): QObject(parent, name), status(newSatus), attached(false), hardwareName("Unknown"), moduleOwner(NULL), macAddress(""), ip("0.0.0.0"), broadcast(""), subnetMask("0.0.0.0"), dhcp(false){ 14Interface::Interface(QObject * parent, const char * name, bool newSatus): QObject(parent, name), status(newSatus), attached(false), hardwareName("Unknown"), moduleOwner(NULL), macAddress(""), ip("0.0.0.0"), broadcast(""), subnetMask("0.0.0.0"), dhcp(false){
15 refresh(); 15 refresh();
16} 16}
17 17
18/** 18/**
19 * Set status 19 * Set status
20 * @param newStatus - the new status 20 * @param newStatus - the new status
21 * emit updateInterface 21 * emit updateInterface
22 */ 22 */
23void Interface::setStatus(bool newStatus){ 23void Interface::setStatus(bool newStatus){
24 if(status != newStatus){ 24 if(status != newStatus){
25 status = newStatus; 25 status = newStatus;
26 refresh(); 26 refresh();
27 } 27 }
28}; 28};
29 29
30/** 30/**
31 * Set if attached or not (802.11 card pulled out for example) 31 * Set if attached or not (802.11 card pulled out for example)
32 * @param isAttached - if attached 32 * @param isAttached - if attached
33 * emit updateInterface 33 * emit updateInterface
34 */ 34 */
35void Interface::setAttached(bool isAttached){ 35void Interface::setAttached(bool isAttached){
36 attached = isAttached; 36 attached = isAttached;
37 emit(updateInterface(this)); 37 emit(updateInterface(this));
38}; 38};
39 39
40/** 40/**
41 * Set Hardware name 41 * Set Hardware name
42 * @param name - the new name 42 * @param name - the new name
43 * emit updateInterface 43 * emit updateInterface
44 */ 44 */
45void Interface::setHardwareName(QString name){ 45void Interface::setHardwareName(QString name){
46 hardwareName = name; 46 hardwareName = name;
47 emit(updateInterface(this)); 47 emit(updateInterface(this));
48}; 48};
49 49
50/** 50/**
51 * Set Module owner 51 * Set Module owner
52 * @param owner - the new owner 52 * @param owner - the new owner
53 * emit updateInterface 53 * emit updateInterface
54 */ 54 */
55void Interface::setModuleOwner(Module *owner){ 55void Interface::setModuleOwner(Module *owner){
56 moduleOwner = owner; 56 moduleOwner = owner;
57 emit(updateInterface(this)); 57 emit(updateInterface(this));
58}; 58};
59 59
60 60
61/** 61/**
62 * Try to start the interface. 62 * Try to start the interface.
63 */ 63 */
64void Interface::start(){ 64void Interface::start(){
65 // check to see if we are already running. 65 // check to see if we are already running.
66 if(true == status) 66 if(true == status)
67 return; 67 return;
68 68
69 int ret = system(QString("%1 %2 up").arg(IFCONFIG).arg(this->name()).latin1()); 69 int ret = system(QString("%1 %2 up").arg(IFCONFIG).arg(this->name()).latin1());
70 // See if it was successfull... 70 // See if it was successfull...
71 if(ret != 0) 71 if(ret != 0)
72 return; 72 return;
73 73
74 status = true; 74 status = true;
75 refresh(); 75 refresh();
76} 76}
77 77
78/** 78/**
79 * Try to stop the interface. 79 * Try to stop the interface.
80 */ 80 */
81void Interface::stop(){ 81void Interface::stop(){
82 // check to see if we are already stopped. 82 // check to see if we are already stopped.
83 if(false == status) 83 if(false == status)
84 return; 84 return;
85 85
86 int ret = system(QString("%1 %2 down").arg(IFCONFIG).arg(this->name()).latin1()); 86 int ret = system(QString("%1 %2 down").arg(IFCONFIG).arg(this->name()).latin1());
87 if(ret != 0) 87 if(ret != 0)
88 return; 88 return;
89 89
90 status = true; 90 status = true;
91 refresh(); 91 refresh();
92} 92}
93 93
94/** 94/**
95 * Try to restart the interface. 95 * Try to restart the interface.
96 */ 96 */
97void Interface::restart(){ 97void Interface::restart(){
98 stop(); 98 stop();
99 start(); 99 start();
100} 100}
101 101
102/** 102/**
103 * Try to refresh the information about the interface. 103 * Try to refresh the information about the interface.
104 * First call ifconfig, then check the dhcp-info file 104 * First call ifconfig, then check the dhcp-info file
105 * @return bool true if successfull. 105 * @return bool true if successfull.
106 */ 106 */
107bool Interface::refresh(){ 107bool Interface::refresh(){
108 // See if we are up. 108 // See if we are up.
109 if(status == false){ 109 if(status == false){
110 macAddress = ""; 110 macAddress = "";
111 ip = "0.0.0.0"; 111 ip = "0.0.0.0";
112 subnetMask = "0.0.0.0"; 112 subnetMask = "0.0.0.0";
113 broadcast = ""; 113 broadcast = "";
114 dhcp = false; 114 dhcp = false;
115 dhcpServerIp = ""; 115 dhcpServerIp = "";
116 leaseObtained = ""; 116 leaseObtained = "";
117 leaseExpires = ""; 117 leaseExpires = "";
118 emit(updateInterface(this)); 118 emit(updateInterface(this));
119 return true; 119 return true;
120 } 120 }
121 121
122 QString fileName = QString("/tmp/%1_ifconfig_info").arg(this->name()); 122 QString fileName = QString("/tmp/%1_ifconfig_info").arg(this->name());
123 int ret = system(QString("%1 %2 > %3").arg(IFCONFIG).arg(this->name()).arg(fileName).latin1()); 123 int ret = system(QString("%1 %2 > %3").arg(IFCONFIG).arg(this->name()).arg(fileName).latin1());
124 if(ret != 0){ 124 if(ret != 0){
125 qDebug(QString("Interface: Ifconfig return value: %1, is not 0").arg(ret).latin1()); 125 qDebug(QString("Interface: Ifconfig return value: %1, is not 0").arg(ret).latin1());
126 return false; 126 return false;
127 } 127 }
128 128
129 QFile file(fileName); 129 QFile file(fileName);
130 if (!file.open(IO_ReadOnly)){ 130 if (!file.open(IO_ReadOnly)){
131 qDebug(QString("Interface: Can't open file: %1").arg(fileName).latin1()); 131 qDebug(QString("Interface: Can't open file: %1").arg(fileName).latin1());
132 return false; 132 return false;
133 } 133 }
134 134
135 // Set to the defaults 135 // Set to the defaults
136 macAddress = ""; 136 macAddress = "";
137 ip = "0.0.0.0"; 137 ip = "0.0.0.0";
138 subnetMask = "0.0.0.0"; 138 subnetMask = "0.0.0.0";
139 broadcast = ""; 139 broadcast = "";
140 140
141 QTextStream stream( &file ); 141 QTextStream stream( &file );
142 QString line; 142 QString line;
143 while ( !stream.eof() ) { 143 while ( !stream.eof() ) {
144 line = stream.readLine(); 144 line = stream.readLine();
145 if(line.contains("HWaddr")){ 145 if(line.contains("HWaddr")){
146 int mac = line.find("HWaddr"); 146 int mac = line.find("HWaddr");
147 macAddress = line.mid(mac+7, line.length()); 147 macAddress = line.mid(mac+7, line.length());
148 } 148 }
149 if(line.contains("inet addr")){ 149 if(line.contains("inet addr")){
150 int ipl = line.find("inet addr"); 150 int ipl = line.find("inet addr");
151 int space = line.find(" ", ipl+10); 151 int space = line.find(" ", ipl+10);
152 ip = line.mid(ipl+10, space-ipl-10); 152 ip = line.mid(ipl+10, space-ipl-10);
153 } 153 }
154 if(line.contains("Mask")){ 154 if(line.contains("Mask")){
155 int mask = line.find("Mask"); 155 int mask = line.find("Mask");
156 subnetMask = line.mid(mask+5, line.length()); 156 subnetMask = line.mid(mask+5, line.length());
157 } 157 }
158 if(line.contains("Bcast")){ 158 if(line.contains("Bcast")){
159 int mask = line.find("Bcast"); 159 int mask = line.find("Bcast");
160 int space = line.find(" ", mask+6); 160 int space = line.find(" ", mask+6);
161 broadcast = line.mid(mask+6, space-mask-6); 161 broadcast = line.mid(mask+6, space-mask-6);
162 } 162 }
163 } 163 }
164 file.close(); 164 file.close();
165 QFile::remove(fileName); 165 QFile::remove(fileName);
166 166
167 // DHCP TESTING 167 // DHCP TESTING
168 // reset DHCP info 168 // reset DHCP info
169 dhcpServerIp = ""; 169 dhcpServerIp = "";
170 leaseObtained = ""; 170 leaseObtained = "";
171 leaseExpires = ""; 171 leaseExpires = "";
172 dhcp = false; 172 dhcp = false;
173 173
174 QString dhcpDirectory(HDCP_INFO_DIR); 174 QString dhcpDirectory(DHCP_INFO_DIR);
175 QDir d(dhcpDirectory); 175 QDir d(dhcpDirectory);
176 if(!d.exists(dhcpDirectory)) 176 if(!d.exists(dhcpDirectory))
177 dhcpDirectory = "/var/run"; 177 dhcpDirectory = "/var/run";
178 178
179 // See if we have 179 // See if we have
180 QString dhcpFile(QString(dhcpDirectory+"/dhcpcd-%1.info").arg(this->name())); 180 QString dhcpFile(QString(dhcpDirectory+"/dhcpcd-%1.info").arg(this->name()));
181 // If there is no DHCP information then exit now with no errors. 181 // If there is no DHCP information then exit now with no errors.
182 if(!QFile::exists(dhcpFile)){ 182 if(!QFile::exists(dhcpFile)){
183 emit(updateInterface(this)); 183 emit(updateInterface(this));
184 return true; 184 return true;
185 } 185 }
186 186
187 file.setName(dhcpFile); 187 file.setName(dhcpFile);
188 if (!file.open(IO_ReadOnly)){ 188 if (!file.open(IO_ReadOnly)){
189 qDebug(QString("Interface: Can't open file: %1").arg(dhcpFile).latin1()); 189 qDebug(QString("Interface: Can't open file: %1").arg(dhcpFile).latin1());
190 return false; 190 return false;
191 } 191 }
192 192
193 // leaseTime and renewalTime and used if pid and deamon exe can be accessed. 193 // leaseTime and renewalTime and used if pid and deamon exe can be accessed.
194 int leaseTime = 0; 194 int leaseTime = 0;
195 int renewalTime = 0; 195 int renewalTime = 0;
196 196
197 stream.setDevice( &file ); 197 stream.setDevice( &file );
198 while ( !stream.eof() ) { 198 while ( !stream.eof() ) {
199 line = stream.readLine(); 199 line = stream.readLine();
200 if(line.contains("DHCPSIADDR=")) 200 if(line.contains("DHCPSIADDR="))
201 dhcpServerIp = line.mid(11, line.length()); 201 dhcpServerIp = line.mid(11, line.length());
202 if(line.contains("LEASETIME=")) 202 if(line.contains("LEASETIME="))
203 leaseTime = line.mid(10, line.length()).toInt(); 203 leaseTime = line.mid(10, line.length()).toInt();
204 if(line.contains("RENEWALTIME=")) 204 if(line.contains("RENEWALTIME="))
205 renewalTime = line.mid(12, line.length()).toInt(); 205 renewalTime = line.mid(12, line.length()).toInt();
206 } 206 }
207 file.close(); 207 file.close();
208 //qDebug(QString("Interface: leaseTime: %1").arg(leaseTime).latin1()); 208 //qDebug(QString("Interface: leaseTime: %1").arg(leaseTime).latin1());
209 //qDebug(QString("Interface: renewalTime: %1").arg(renewalTime).latin1()); 209 //qDebug(QString("Interface: renewalTime: %1").arg(renewalTime).latin1());
210 210
211 // Get the pid of the deamond 211 // Get the pid of the deamond
212 dhcpFile = (QString(dhcpDirectory+"/dhcpcd-%1.pid").arg(this->name())); 212 dhcpFile = (QString(dhcpDirectory+"/dhcpcd-%1.pid").arg(this->name()));
213 file.setName(dhcpFile); 213 file.setName(dhcpFile);
214 if (!file.open(IO_ReadOnly)){ 214 if (!file.open(IO_ReadOnly)){
215 qDebug(QString("Interface: Can't open file: %1").arg(dhcpFile).latin1()); 215 qDebug(QString("Interface: Can't open file: %1").arg(dhcpFile).latin1());
216 return false; 216 return false;
217 } 217 }
218 218
219 int pid = -1; 219 int pid = -1;
220 stream.setDevice( &file ); 220 stream.setDevice( &file );
221 while ( !stream.eof() ) { 221 while ( !stream.eof() ) {
222 line = stream.readLine(); 222 line = stream.readLine();
223 pid = line.toInt(); 223 pid = line.toInt();
224 } 224 }
225 file.close(); 225 file.close();
226 226
227 if( pid == -1){ 227 if( pid == -1){
228 qDebug("Interface: Could not get pid of dhcpc deamon."); 228 qDebug("Interface: Could not get pid of dhcpc deamon.");
229 return false; 229 return false;
230 } 230 }
231 231
232 // Get the start running time of the deamon 232 // Get the start running time of the deamon
233 fileName = (QString("/proc/%1/stat").arg(pid)); 233 fileName = (QString("/proc/%1/stat").arg(pid));
234 file.setName(fileName); 234 file.setName(fileName);
235 stream.setDevice( &file ); 235 stream.setDevice( &file );
236 if (!file.open(IO_ReadOnly)){ 236 if (!file.open(IO_ReadOnly)){
237 qDebug(QString("Interface: Can't open file: %1").arg(fileName).latin1()); 237 qDebug(QString("Interface: Can't open file: %1").arg(fileName).latin1());
238 return false; 238 return false;
239 } 239 }
240 while ( !stream.eof() ) { 240 while ( !stream.eof() ) {
241 line = stream.readLine(); 241 line = stream.readLine();
242 } 242 }
243 file.close(); 243 file.close();
244 long time = 0; 244 long time = 0;
245 // Grab the start time 245 // Grab the start time
246 // pid com state ppid pgrp session tty_nr tpgid flags 246 // pid com state ppid pgrp session tty_nr tpgid flags
247 sscanf(line.latin1(), "%*d %*s %*c %*d %*d %*d %*d %*d %*u " 247 sscanf(line.latin1(), "%*d %*s %*c %*d %*d %*d %*d %*d %*u "
248 // minflt cminflt majflt cmajflt utime stime cutime cstime priority 248 // minflt cminflt majflt cmajflt utime stime cutime cstime priority
249 "%*u %*u %*u %*u %*u %*u %*d %*d %*d " 249 "%*u %*u %*u %*u %*u %*u %*d %*d %*d "
250 // nice 0 itrealvalue starttime 250 // nice 0 itrealvalue starttime
251 "%*d %*d %*d %lu", (long*) &time); 251 "%*d %*d %*d %lu", (long*) &time);
252 time = time/100; 252 time = time/100;
253 253
254 QDateTime datetime(QDateTime::currentDateTime()); 254 QDateTime datetime(QDateTime::currentDateTime());
255 255
256 // Get the uptime of the computer. 256 // Get the uptime of the computer.
257 QFile f("/proc/uptime"); 257 QFile f("/proc/uptime");
258 if ( f.open(IO_ReadOnly) ) { // file opened successfully 258 if ( f.open(IO_ReadOnly) ) { // file opened successfully
259 QTextStream t( &f ); // use a text stream 259 QTextStream t( &f ); // use a text stream
260 int sec = 0; 260 int sec = 0;
261 t >> sec; 261 t >> sec;
262 datetime = datetime.addSecs((-1*sec)); 262 datetime = datetime.addSecs((-1*sec));
263 f.close(); 263 f.close();
264 } 264 }
265 else{ 265 else{
266 qDebug("Interface: Can't open /proc/uptime to retrive uptime."); 266 qDebug("Interface: Can't open /proc/uptime to retrive uptime.");
267 return false; 267 return false;
268 } 268 }
269 269
270 datetime = datetime.addSecs(time); 270 datetime = datetime.addSecs(time);
271 //qDebug(QString("Interface: %1 %2").arg(datetime.toString()).arg(pid).latin1()); 271 //qDebug(QString("Interface: %1 %2").arg(datetime.toString()).arg(pid).latin1());
272 272
273 // Calculate the start and renew times 273 // Calculate the start and renew times
274 leaseObtained= datetime.toString(); 274 leaseObtained= datetime.toString();
275 275
276 // Calculate the start and renew times 276 // Calculate the start and renew times
277 datetime = datetime.addSecs(leaseTime); 277 datetime = datetime.addSecs(leaseTime);
278 leaseExpires = datetime.toString(); 278 leaseExpires = datetime.toString();
279 279
280 dhcp = true; 280 dhcp = true;
281 281
282 emit(updateInterface(this)); 282 emit(updateInterface(this));
283 return true; 283 return true;
284} 284}
285 285
286// interface.cpp 286// interface.cpp
287 287
diff --git a/noncore/settings/networksettings/mainwindowimp.cpp b/noncore/settings/networksettings/mainwindowimp.cpp
index 9d81ab1..c86acdc 100644
--- a/noncore/settings/networksettings/mainwindowimp.cpp
+++ b/noncore/settings/networksettings/mainwindowimp.cpp
@@ -1,558 +1,560 @@
1#include "mainwindowimp.h" 1#include "mainwindowimp.h"
2#include "addconnectionimp.h" 2#include "addconnectionimp.h"
3#include "interfaceinformationimp.h" 3#include "interfaceinformationimp.h"
4#include "interfacesetupimp.h" 4#include "interfacesetupimp.h"
5#include "interfaces.h" 5#include "interfaces.h"
6 6
7#include "module.h" 7#include "module.h"
8 8
9#include "kprocess.h" 9#include "kprocess.h"
10 10
11#include <qpushbutton.h> 11#include <qpushbutton.h>
12#include <qtabwidget.h> 12#include <qtabwidget.h>
13#include <qlistbox.h> 13#include <qlistbox.h>
14#include <qlineedit.h> 14#include <qlineedit.h>
15#include <qlistview.h> 15#include <qlistview.h>
16#include <qheader.h> 16#include <qheader.h>
17#include <qlabel.h> 17#include <qlabel.h>
18 18
19#include <qmainwindow.h> 19#include <qmainwindow.h>
20#include <qmessagebox.h> 20#include <qmessagebox.h>
21 21
22#include <qpe/config.h> 22#include <qpe/config.h>
23#include <qpe/qlibrary.h> 23#include <qpe/qlibrary.h>
24#include <qpe/resource.h> 24#include <qpe/resource.h>
25#include <qpe/qpeapplication.h> 25#include <qpe/qpeapplication.h>
26 26
27#include <qlist.h> 27#include <qlist.h>
28#include <qdir.h> 28#include <qdir.h>
29#include <qfile.h> 29#include <qfile.h>
30#include <qtextstream.h> 30#include <qtextstream.h>
31 31
32#define TEMP_ALL "/tmp/ifconfig-a" 32#define TEMP_ALL "/tmp/ifconfig-a"
33#define TEMP_UP "/tmp/ifconfig" 33#define TEMP_UP "/tmp/ifconfig"
34 34
35#define DEFAULT_SCHEME "/var/lib/pcmcia/scheme" 35#define DEFAULT_SCHEME "/var/lib/pcmcia/scheme"
36 36
37MainWindowImp::MainWindowImp(QWidget *parent, const char *name) : MainWindow(parent, name, true), advancedUserMode(false){ 37MainWindowImp::MainWindowImp(QWidget *parent, const char *name) : MainWindow(parent, name, true), advancedUserMode(false){
38 connect(addConnectionButton, SIGNAL(clicked()), this, SLOT(addClicked())); 38 connect(addConnectionButton, SIGNAL(clicked()), this, SLOT(addClicked()));
39 connect(removeConnectionButton, SIGNAL(clicked()), this, SLOT(removeClicked())); 39 connect(removeConnectionButton, SIGNAL(clicked()), this, SLOT(removeClicked()));
40 connect(informationConnectionButton, SIGNAL(clicked()), this, SLOT(informationClicked())); 40 connect(informationConnectionButton, SIGNAL(clicked()), this, SLOT(informationClicked()));
41 connect(configureConnectionButton, SIGNAL(clicked()), this, SLOT(configureClicked())); 41 connect(configureConnectionButton, SIGNAL(clicked()), this, SLOT(configureClicked()));
42 42
43 connect(newProfileButton, SIGNAL(clicked()), this, SLOT(addProfile())); 43 connect(newProfileButton, SIGNAL(clicked()), this, SLOT(addProfile()));
44 connect(removeProfileButton, SIGNAL(clicked()), this, SLOT(removeProfile())); 44 connect(removeProfileButton, SIGNAL(clicked()), this, SLOT(removeProfile()));
45 connect(setCurrentProfileButton, SIGNAL(clicked()), this, SLOT(changeProfile())); 45 connect(setCurrentProfileButton, SIGNAL(clicked()), this, SLOT(changeProfile()));
46 46
47 connect(newProfile, SIGNAL(textChanged(const QString&)), this, SLOT(newProfileChanged(const QString&))); 47 connect(newProfile, SIGNAL(textChanged(const QString&)), this, SLOT(newProfileChanged(const QString&)));
48 // Load connections. 48 // Load connections.
49 loadModules(QPEApplication::qpeDir() + "/plugins/networksetup"); 49 loadModules(QPEApplication::qpeDir() + "/plugins/networksetup");
50 getInterfaceList(); 50 getInterfaceList();
51 connectionList->header()->hide(); 51 connectionList->header()->hide();
52 52
53 53
54 Config cfg("NetworkSetup"); 54 Config cfg("NetworkSetup");
55 profiles = QStringList::split(" ", cfg.readEntry("Profiles", "All")); 55 profiles = QStringList::split(" ", cfg.readEntry("Profiles", "All"));
56 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it) 56 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it)
57 profilesList->insertItem((*it)); 57 profilesList->insertItem((*it));
58 currentProfileLabel->setText(cfg.readEntry("CurrentProfile", "All")); 58 currentProfileLabel->setText(cfg.readEntry("CurrentProfile", "All"));
59 advancedUserMode = cfg.readBoolEntry("AdvancedUserMode", false); 59 advancedUserMode = cfg.readBoolEntry("AdvancedUserMode", false);
60 scheme = cfg.readEntry("SchemeFile", DEFAULT_SCHEME); 60 scheme = cfg.readEntry("SchemeFile", DEFAULT_SCHEME);
61 61
62 QFile file(scheme); 62 QFile file(scheme);
63 if ( file.open(IO_ReadOnly) ) { // file opened successfully 63 if ( file.open(IO_ReadOnly) ) { // file opened successfully
64 QTextStream stream( &file ); // use a text stream 64 QTextStream stream( &file ); // use a text stream
65 while ( !stream.eof() ) { // until end of file... 65 while ( !stream.eof() ) { // until end of file...
66 QString line = stream.readLine(); // line of text excluding '\n' 66 QString line = stream.readLine(); // line of text excluding '\n'
67 if(line.contains("SCHEME")){ 67 if(line.contains("SCHEME")){
68 line = line.mid(7, line.length()); 68 line = line.mid(7, line.length());
69 currentProfileLabel->setText(line); 69 currentProfileLabel->setText(line);
70 break; 70 break;
71 } 71 }
72 } 72 }
73 file.close(); 73 file.close();
74 } 74 }
75} 75}
76 76
77/** 77/**
78 * Deconstructor. Save profiles. Delete loaded libraries. 78 * Deconstructor. Save profiles. Delete loaded libraries.
79 */ 79 */
80MainWindowImp::~MainWindowImp(){ 80MainWindowImp::~MainWindowImp(){
81 qDebug("start Saving mainwindow");
81 // Save profiles. 82 // Save profiles.
82 Config cfg("NetworkSetup"); 83 Config cfg("NetworkSetup");
83 cfg.setGroup("General"); 84 cfg.setGroup("General");
84 cfg.writeEntry("Profiles", profiles.join(" ")); 85 cfg.writeEntry("Profiles", profiles.join(" "));
85 86
86 // Delete all interfaces that don't have owners. 87 // Delete all interfaces that don't have owners.
87 QMap<Interface*, QListViewItem*>::Iterator iIt; 88 QMap<Interface*, QListViewItem*>::Iterator iIt;
88 for( iIt = items.begin(); iIt != items.end(); ++iIt ){ 89 for( iIt = items.begin(); iIt != items.end(); ++iIt ){
89 if(iIt.key()->getModuleOwner() == NULL) 90 if(iIt.key()->getModuleOwner() == NULL)
90 delete iIt.key(); 91 delete iIt.key();
91 } 92 }
92 93
93 // Delete Modules and Libraries 94 // Delete Modules and Libraries
94 QMap<Module*, QLibrary*>::Iterator it; 95 QMap<Module*, QLibrary*>::Iterator it;
95 for( it = libraries.begin(); it != libraries.end(); ++it ){ 96 for( it = libraries.begin(); it != libraries.end(); ++it ){
96 delete it.key(); 97 delete it.key();
97 delete it.data(); 98 delete it.data();
98 } 99 }
100 qDebug("done Saving mainwindow");
99} 101}
100 102
101/** 103/**
102 * Load all modules that are found in the path 104 * Load all modules that are found in the path
103 * @param path a directory that is scaned for any plugins that can be loaded 105 * @param path a directory that is scaned for any plugins that can be loaded
104 * and attempts to load them 106 * and attempts to load them
105 */ 107 */
106void MainWindowImp::loadModules(QString path){ 108void MainWindowImp::loadModules(QString path){
107 //qDebug(path.latin1()); 109 //qDebug(path.latin1());
108 QDir d(path); 110 QDir d(path);
109 if(!d.exists()) 111 if(!d.exists())
110 return; 112 return;
111 113
112 // Don't want sym links 114 // Don't want sym links
113 d.setFilter( QDir::Files | QDir::NoSymLinks ); 115 d.setFilter( QDir::Files | QDir::NoSymLinks );
114 const QFileInfoList *list = d.entryInfoList(); 116 const QFileInfoList *list = d.entryInfoList();
115 QFileInfoListIterator it( *list ); 117 QFileInfoListIterator it( *list );
116 QFileInfo *fi; 118 QFileInfo *fi;
117 while ( (fi=it.current()) ) { 119 while ( (fi=it.current()) ) {
118 if(fi->fileName().contains(".so")){ 120 if(fi->fileName().contains(".so")){
119 loadPlugin(path + "/" + fi->fileName()); 121 loadPlugin(path + "/" + fi->fileName());
120 } 122 }
121 ++it; 123 ++it;
122 } 124 }
123} 125}
124 126
125/** 127/**
126 * Attempt to load a function and resolve a function. 128 * Attempt to load a function and resolve a function.
127 * @param pluginFileName - the name of the file in which to attempt to load 129 * @param pluginFileName - the name of the file in which to attempt to load
128 * @param resolveString - function pointer to resolve 130 * @param resolveString - function pointer to resolve
129 * @return pointer to the function with name resolveString or NULL 131 * @return pointer to the function with name resolveString or NULL
130 */ 132 */
131Module* MainWindowImp::loadPlugin(QString pluginFileName, QString resolveString){ 133Module* MainWindowImp::loadPlugin(QString pluginFileName, QString resolveString){
132 //qDebug(QString("MainWindowImp::loadPlugin: %1").arg(pluginFileName).latin1()); 134 //qDebug(QString("MainWindowImp::loadPlugin: %1").arg(pluginFileName).latin1());
133 QLibrary *lib = new QLibrary(pluginFileName); 135 QLibrary *lib = new QLibrary(pluginFileName);
134 void *functionPointer = lib->resolve(resolveString); 136 void *functionPointer = lib->resolve(resolveString);
135 if( !functionPointer ){ 137 if( !functionPointer ){
136 qDebug(QString("MainWindowImp: File: %1 is not a plugin, but though was.").arg(pluginFileName).latin1()); 138 qDebug(QString("MainWindowImp: File: %1 is not a plugin, but though was.").arg(pluginFileName).latin1());
137 delete lib; 139 delete lib;
138 return NULL; 140 return NULL;
139 } 141 }
140 142
141 // Try to get an object. 143 // Try to get an object.
142 Module *object = ((Module* (*)()) functionPointer)(); 144 Module *object = ((Module* (*)()) functionPointer)();
143 if(object == NULL){ 145 if(object == NULL){
144 qDebug("MainWindowImp: Couldn't create object, but did load library!"); 146 qDebug("MainWindowImp: Couldn't create object, but did load library!");
145 delete lib; 147 delete lib;
146 return NULL; 148 return NULL;
147 } 149 }
148 150
149 // Store for deletion later 151 // Store for deletion later
150 libraries.insert(object, lib); 152 libraries.insert(object, lib);
151 return object; 153 return object;
152} 154}
153 155
154/** 156/**
155 * The Add button was clicked. Bring up the add dialog and if OK is hit 157 * The Add button was clicked. Bring up the add dialog and if OK is hit
156 * load the plugin and append it to the list 158 * load the plugin and append it to the list
157 */ 159 */
158void MainWindowImp::addClicked(){ 160void MainWindowImp::addClicked(){
159 QMap<Module*, QLibrary*>::Iterator it; 161 QMap<Module*, QLibrary*>::Iterator it;
160 QMap<QString, QString> list; 162 QMap<QString, QString> list;
161 QMap<QString, Module*> newInterfaceOwners; 163 QMap<QString, Module*> newInterfaceOwners;
162 list.insert("USB (PPP) / (ADD_TEST)", "A dialup connection over the USB port"); 164 list.insert("USB (PPP) / (ADD_TEST)", "A dialup connection over the USB port");
163 list.insert("IrDa (PPP) / (ADD_TEST)", "A dialup connection over the IdDa port"); 165 list.insert("IrDa (PPP) / (ADD_TEST)", "A dialup connection over the IdDa port");
164 for( it = libraries.begin(); it != libraries.end(); ++it ){ 166 for( it = libraries.begin(); it != libraries.end(); ++it ){
165 if(it.key()){ 167 if(it.key()){
166 (it.key())->possibleNewInterfaces(list); 168 (it.key())->possibleNewInterfaces(list);
167 } 169 }
168 } 170 }
169 // See if the list has anything that we can add. 171 // See if the list has anything that we can add.
170 if(list.count() == 0){ 172 if(list.count() == 0){
171 QMessageBox::information(this, "Sorry", "Nothing to add.", "Ok"); 173 QMessageBox::information(this, "Sorry", "Nothing to add.", "Ok");
172 return; 174 return;
173 } 175 }
174 AddConnectionImp addNewConnection(this, "AddConnectionImp", true); 176 AddConnectionImp addNewConnection(this, "AddConnectionImp", true);
175 addNewConnection.addConnections(list); 177 addNewConnection.addConnections(list);
176 addNewConnection.showMaximized(); 178 addNewConnection.showMaximized();
177 if(QDialog::Accepted == addNewConnection.exec()){ 179 if(QDialog::Accepted == addNewConnection.exec()){
178 QListViewItem *item = addNewConnection.registeredServicesList->currentItem(); 180 QListViewItem *item = addNewConnection.registeredServicesList->currentItem();
179 if(!item) 181 if(!item)
180 return; 182 return;
181 183
182 for( it = libraries.begin(); it != libraries.end(); ++it ){ 184 for( it = libraries.begin(); it != libraries.end(); ++it ){
183 if(it.key()){ 185 if(it.key()){
184 Interface *i = (it.key())->addNewInterface(item->text(0)); 186 Interface *i = (it.key())->addNewInterface(item->text(0));
185 if(i){ 187 if(i){
186 interfaceNames.insert(i->getInterfaceName(), i); 188 interfaceNames.insert(i->getInterfaceName(), i);
187 updateInterface(i); 189 updateInterface(i);
188 } 190 }
189 } 191 }
190 } 192 }
191 } 193 }
192} 194}
193 195
194/** 196/**
195 * Prompt the user to see if they really want to do this. 197 * Prompt the user to see if they really want to do this.
196 * If they do then remove from the list and unload. 198 * If they do then remove from the list and unload.
197 */ 199 */
198void MainWindowImp::removeClicked(){ 200void MainWindowImp::removeClicked(){
199 QListViewItem *item = connectionList->currentItem(); 201 QListViewItem *item = connectionList->currentItem();
200 if(!item) { 202 if(!item) {
201 QMessageBox::information(this, "Sorry","Please select an interface First.", "Ok"); 203 QMessageBox::information(this, "Sorry","Please select an interface First.", "Ok");
202 return; 204 return;
203 } 205 }
204 206
205 Interface *i = interfaceItems[item]; 207 Interface *i = interfaceItems[item];
206 if(i->getModuleOwner() == NULL){ 208 if(i->getModuleOwner() == NULL){
207 QMessageBox::information(this, "Can't remove interface.", "Interface is built in.", "Ok"); 209 QMessageBox::information(this, "Can't remove interface.", "Interface is built in.", "Ok");
208 } 210 }
209 else{ 211 else{
210 if(!i->getModuleOwner()->remove(i)) 212 if(!i->getModuleOwner()->remove(i))
211 QMessageBox::information(this, "Error", "Unable to remove.", "Ok"); 213 QMessageBox::information(this, "Error", "Unable to remove.", "Ok");
212 else{ 214 else{
213 QMessageBox::information(this, "Success", "Interface was removed.", "Ok"); 215 QMessageBox::information(this, "Success", "Interface was removed.", "Ok");
214 // TODO memory managment.... 216 // TODO memory managment....
215 // who deletes the interface? 217 // who deletes the interface?
216 } 218 }
217 } 219 }
218} 220}
219 221
220/** 222/**
221 * Pull up the configure about the currently selected interface. 223 * Pull up the configure about the currently selected interface.
222 * Report an error if no interface is selected. 224 * Report an error if no interface is selected.
223 * If the interface has a module owner then request its configure with a empty 225 * If the interface has a module owner then request its configure with a empty
224 * tab. If tab is !NULL then append the interfaces setup widget to it. 226 * tab. If tab is !NULL then append the interfaces setup widget to it.
225 */ 227 */
226void MainWindowImp::configureClicked(){ 228void MainWindowImp::configureClicked(){
227 QListViewItem *item = connectionList->currentItem(); 229 QListViewItem *item = connectionList->currentItem();
228 if(!item){ 230 if(!item){
229 QMessageBox::information(this, "Sorry","Please select an interface first.", QMessageBox::Ok); 231 QMessageBox::information(this, "Sorry","Please select an interface first.", QMessageBox::Ok);
230 return; 232 return;
231 } 233 }
232 234
233 QString currentProfile = currentProfileLabel->text(); 235 QString currentProfile = currentProfileLabel->text();
234 if(profilesList->count() <= 1 || currentProfile == "All"){ 236 if(profilesList->count() <= 1 || currentProfile == "All"){
235 currentProfile = ""; 237 currentProfile = "";
236 } 238 }
237 239
238 Interface *i = interfaceItems[item]; 240 Interface *i = interfaceItems[item];
239 if(i->getModuleOwner()){ 241 if(i->getModuleOwner()){
240 i->getModuleOwner()->setProfile(currentProfile); 242 i->getModuleOwner()->setProfile(currentProfile);
241 QTabWidget *tabWidget = NULL; 243 QTabWidget *tabWidget = NULL;
242 QWidget *moduleConfigure = i->getModuleOwner()->configure(i, &tabWidget); 244 QWidget *moduleConfigure = i->getModuleOwner()->configure(i, &tabWidget);
243 if(moduleConfigure != NULL){ 245 if(moduleConfigure != NULL){
244 if(tabWidget != NULL){ 246 if(tabWidget != NULL){
245 InterfaceSetupImp *configure = new InterfaceSetupImp(tabWidget, "InterfaceSetupImp", i, true); 247 InterfaceSetupImp *configure = new InterfaceSetupImp(tabWidget, "InterfaceSetupImp", i, true);
246 configure->setProfile(currentProfile); 248 configure->setProfile(currentProfile);
247 tabWidget->insertTab(configure, "TCP/IP"); 249 tabWidget->insertTab(configure, "TCP/IP");
248 250
249 } 251 }
250 moduleConfigure->showMaximized(); 252 moduleConfigure->showMaximized();
251 moduleConfigure->show(); 253 moduleConfigure->show();
252 return; 254 return;
253 } 255 }
254 } 256 }
255 257
256 InterfaceSetupImp *configure = new InterfaceSetupImp(0, "InterfaceSetupImp", i, true); 258 InterfaceSetupImp *configure = new InterfaceSetupImp(0, "InterfaceSetupImp", i, true);
257 configure->setProfile(currentProfile); 259 configure->setProfile(currentProfile);
258 configure->showMaximized(); 260 configure->showMaximized();
259 configure->show(); 261 configure->show();
260} 262}
261 263
262/** 264/**
263 * Pull up the information about the currently selected interface. 265 * Pull up the information about the currently selected interface.
264 * Report an error if no interface is selected. 266 * Report an error if no interface is selected.
265 * If the interface has a module owner then request its configure with a empty 267 * If the interface has a module owner then request its configure with a empty
266 * tab. If tab is !NULL then append the interfaces setup widget to it. 268 * tab. If tab is !NULL then append the interfaces setup widget to it.
267 */ 269 */
268void MainWindowImp::informationClicked(){ 270void MainWindowImp::informationClicked(){
269 QListViewItem *item = connectionList->currentItem(); 271 QListViewItem *item = connectionList->currentItem();
270 if(!item){ 272 if(!item){
271 QMessageBox::information(this, "Sorry","Please select an interface First.", QMessageBox::Ok); 273 QMessageBox::information(this, "Sorry","Please select an interface First.", QMessageBox::Ok);
272 return; 274 return;
273 } 275 }
274 276
275 Interface *i = interfaceItems[item]; 277 Interface *i = interfaceItems[item];
276 if(!i->isAttached()){ 278 if(!i->isAttached()){
277 QMessageBox::information(this, "Sorry","No information about\na disconnected interface.", QMessageBox::Ok); 279 QMessageBox::information(this, "Sorry","No information about\na disconnected interface.", QMessageBox::Ok);
278 return; 280 return;
279 } 281 }
280 282
281 QStringList list; 283 QStringList list;
282 for(uint i = 0; i < profilesList->count(); i++){ 284 for(uint i = 0; i < profilesList->count(); i++){
283 list.append(profilesList->text(i)); 285 list.append(profilesList->text(i));
284 } 286 }
285 287
286 if(i->getModuleOwner()){ 288 if(i->getModuleOwner()){
287 QTabWidget *tabWidget = NULL; 289 QTabWidget *tabWidget = NULL;
288 QWidget *moduleInformation = i->getModuleOwner()->information(i, &tabWidget); 290 QWidget *moduleInformation = i->getModuleOwner()->information(i, &tabWidget);
289 if(moduleInformation != NULL){ 291 if(moduleInformation != NULL){
290 if(tabWidget != NULL){ 292 if(tabWidget != NULL){
291 InterfaceInformationImp *information = new InterfaceInformationImp(tabWidget, "InterfaceSetupImp", i, true); 293 InterfaceInformationImp *information = new InterfaceInformationImp(tabWidget, "InterfaceSetupImp", i, true);
292 tabWidget->insertTab(information, "TCP/IP"); 294 tabWidget->insertTab(information, "TCP/IP");
293 } 295 }
294 moduleInformation->showMaximized(); 296 moduleInformation->showMaximized();
295 moduleInformation->show(); 297 moduleInformation->show();
296 return; 298 return;
297 } 299 }
298 } 300 }
299 301
300 InterfaceInformationImp *information = new InterfaceInformationImp(0, "InterfaceSetupImp", i, true); 302 InterfaceInformationImp *information = new InterfaceInformationImp(0, "InterfaceSetupImp", i, true);
301 information->showMaximized(); 303 information->showMaximized();
302 information->show(); 304 information->show();
303} 305}
304 306
305/** 307/**
306 * Aquire the list of active interfaces from ifconfig 308 * Aquire the list of active interfaces from ifconfig
307 * Call ifconfig and ifconfig -a 309 * Call ifconfig and ifconfig -a
308 */ 310 */
309void MainWindowImp::getInterfaceList(){ 311void MainWindowImp::getInterfaceList(){
310 KShellProcess *processAll = new KShellProcess(); 312 KShellProcess *processAll = new KShellProcess();
311 *processAll << "/sbin/ifconfig" << "-a" << " > " TEMP_ALL; 313 *processAll << "/sbin/ifconfig" << "-a" << " > " TEMP_ALL;
312 connect(processAll, SIGNAL(processExited(KProcess *)), 314 connect(processAll, SIGNAL(processExited(KProcess *)),
313 this, SLOT(jobDone(KProcess *))); 315 this, SLOT(jobDone(KProcess *)));
314 threads.insert(processAll, TEMP_ALL); 316 threads.insert(processAll, TEMP_ALL);
315 317
316 KShellProcess *process = new KShellProcess(); 318 KShellProcess *process = new KShellProcess();
317 *process << "/sbin/ifconfig" << " > " TEMP_UP; 319 *process << "/sbin/ifconfig" << " > " TEMP_UP;
318 connect(process, SIGNAL(processExited(KProcess *)), 320 connect(process, SIGNAL(processExited(KProcess *)),
319 this, SLOT(jobDone(KProcess *))); 321 this, SLOT(jobDone(KProcess *)));
320 threads.insert(process, TEMP_UP); 322 threads.insert(process, TEMP_UP);
321 323
322 processAll->start(KShellProcess::NotifyOnExit); 324 processAll->start(KShellProcess::NotifyOnExit);
323 process->start(KShellProcess::NotifyOnExit); 325 process->start(KShellProcess::NotifyOnExit);
324} 326}
325 327
326void MainWindowImp::jobDone(KProcess *process){ 328void MainWindowImp::jobDone(KProcess *process){
327 QString fileName = threads[process]; 329 QString fileName = threads[process];
328 threads.remove(process); 330 threads.remove(process);
329 delete process; 331 delete process;
330 332
331 QFile file(fileName); 333 QFile file(fileName);
332 if (!file.open(IO_ReadOnly)){ 334 if (!file.open(IO_ReadOnly)){
333 qDebug(QString("MainWindowImp: Can't open file: %1").arg(fileName).latin1()); 335 qDebug(QString("MainWindowImp: Can't open file: %1").arg(fileName).latin1());
334 return; 336 return;
335 } 337 }
336 338
337 QTextStream stream( &file ); 339 QTextStream stream( &file );
338 QString line; 340 QString line;
339 while ( !stream.eof() ) { 341 while ( !stream.eof() ) {
340 line = stream.readLine(); 342 line = stream.readLine();
341 int space = line.find(" "); 343 int space = line.find(" ");
342 if(space > 1){ 344 if(space > 1){
343 // We have found an interface 345 // We have found an interface
344 QString interfaceName = line.mid(0, space); 346 QString interfaceName = line.mid(0, space);
345 Interface *i; 347 Interface *i;
346 // We have found an interface 348 // We have found an interface
347 //qDebug(QString("MainWindowImp: Found Interface: %1").arg(line).latin1()); 349 //qDebug(QString("MainWindowImp: Found Interface: %1").arg(line).latin1());
348 // See if we already have it 350 // See if we already have it
349 if(interfaceNames.find(interfaceName) == interfaceNames.end()){ 351 if(interfaceNames.find(interfaceName) == interfaceNames.end()){
350 if(fileName == TEMP_ALL) 352 if(fileName == TEMP_ALL)
351 i = new Interface(this, interfaceName, false); 353 i = new Interface(this, interfaceName, false);
352 else 354 else
353 i = new Interface(this, interfaceName, true); 355 i = new Interface(this, interfaceName, true);
354 i->setAttached(true); 356 i->setAttached(true);
355 357
356 QString hardName = "Ethernet"; 358 QString hardName = "Ethernet";
357 int hardwareName = line.find("Link encap:"); 359 int hardwareName = line.find("Link encap:");
358 int macAddress = line.find("HWaddr"); 360 int macAddress = line.find("HWaddr");
359 if(macAddress == -1) 361 if(macAddress == -1)
360 macAddress = line.length(); 362 macAddress = line.length();
361 if(hardwareName != -1) 363 if(hardwareName != -1)
362 i->setHardwareName(line.mid(hardwareName+11, macAddress-(hardwareName+11)) ); 364 i->setHardwareName(line.mid(hardwareName+11, macAddress-(hardwareName+11)) );
363 365
364 interfaceNames.insert(i->getInterfaceName(), i); 366 interfaceNames.insert(i->getInterfaceName(), i);
365 updateInterface(i); 367 updateInterface(i);
366 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *))); 368 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *)));
367 } 369 }
368 // It was an interface we already had. 370 // It was an interface we already had.
369 else{ 371 else{
370 if(fileName != TEMP_ALL) 372 if(fileName != TEMP_ALL)
371 (interfaceNames[interfaceName])->setStatus(true); 373 (interfaceNames[interfaceName])->setStatus(true);
372 } 374 }
373 } 375 }
374 } 376 }
375 file.close(); 377 file.close();
376 QFile::remove(fileName); 378 QFile::remove(fileName);
377 379
378 if(threads.count() == 0){ 380 if(threads.count() == 0){
379 Interfaces i; 381 Interfaces i;
380 QStringList list = i.getInterfaceList(); 382 QStringList list = i.getInterfaceList();
381 QMap<QString, Interface*>::Iterator it; 383 QMap<QString, Interface*>::Iterator it;
382 for ( QStringList::Iterator ni = list.begin(); ni != list.end(); ++ni ) { 384 for ( QStringList::Iterator ni = list.begin(); ni != list.end(); ++ni ) {
383 bool found = false; 385 bool found = false;
384 for( it = interfaceNames.begin(); it != interfaceNames.end(); ++it ){ 386 for( it = interfaceNames.begin(); it != interfaceNames.end(); ++it ){
385 if(it.key() == (*ni)) 387 if(it.key() == (*ni))
386 found = true; 388 found = true;
387 } 389 }
388 if(!found){ 390 if(!found){
389 if(!(*ni).contains("_")){ 391 if(!(*ni).contains("_")){
390 Interface *i = new Interface(this, *ni, false); 392 Interface *i = new Interface(this, *ni, false);
391 i->setAttached(false); 393 i->setAttached(false);
392 i->setHardwareName("Disconnected"); 394 i->setHardwareName("Disconnected");
393 interfaceNames.insert(i->getInterfaceName(), i); 395 interfaceNames.insert(i->getInterfaceName(), i);
394 updateInterface(i); 396 updateInterface(i);
395 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *))); 397 connect(i, SIGNAL(updateInterface(Interface *)), this, SLOT(updateInterface(Interface *)));
396 } 398 }
397 } 399 }
398 } 400 }
399 } 401 }
400} 402}
401 403
402/** 404/**
403 * Update this interface. If no QListViewItem exists create one. 405 * Update this interface. If no QListViewItem exists create one.
404 * @param Interface* pointer to the interface that needs to be updated. 406 * @param Interface* pointer to the interface that needs to be updated.
405 */ 407 */
406void MainWindowImp::updateInterface(Interface *i){ 408void MainWindowImp::updateInterface(Interface *i){
407 if(!advancedUserMode){ 409 if(!advancedUserMode){
408 if(i->getInterfaceName() == "lo") 410 if(i->getInterfaceName() == "lo")
409 return; 411 return;
410 } 412 }
411 413
412 QListViewItem *item = NULL; 414 QListViewItem *item = NULL;
413 415
414 // Find the interface, making it if needed. 416 // Find the interface, making it if needed.
415 if(items.find(i) == items.end()){ 417 if(items.find(i) == items.end()){
416 item = new QListViewItem(connectionList, "", "", ""); 418 item = new QListViewItem(connectionList, "", "", "");
417 // See if you can't find a module owner for this interface 419 // See if you can't find a module owner for this interface
418 QMap<Module*, QLibrary*>::Iterator it; 420 QMap<Module*, QLibrary*>::Iterator it;
419 for( it = libraries.begin(); it != libraries.end(); ++it ){ 421 for( it = libraries.begin(); it != libraries.end(); ++it ){
420 if(it.key()->isOwner(i)) 422 if(it.key()->isOwner(i))
421 i->setModuleOwner(it.key()); 423 i->setModuleOwner(it.key());
422 } 424 }
423 items.insert(i, item); 425 items.insert(i, item);
424 interfaceItems.insert(item, i); 426 interfaceItems.insert(item, i);
425 } 427 }
426 else 428 else
427 item = items[i]; 429 item = items[i];
428 430
429 // Update the icons and information 431 // Update the icons and information
430 item->setPixmap(0, (Resource::loadPixmap(i->getStatus() ? "up": "down"))); 432 item->setPixmap(0, (Resource::loadPixmap(i->getStatus() ? "up": "down")));
431 433
432 QString typeName = "lan"; 434 QString typeName = "lan";
433 if(i->getHardwareName().contains("Local Loopback")) 435 if(i->getHardwareName().contains("Local Loopback"))
434 typeName = "lo"; 436 typeName = "lo";
435 if(i->getInterfaceName().contains("irda")) 437 if(i->getInterfaceName().contains("irda"))
436 typeName = "irda"; 438 typeName = "irda";
437 if(i->getInterfaceName().contains("wlan")) 439 if(i->getInterfaceName().contains("wlan"))
438 typeName = "wlan"; 440 typeName = "wlan";
439 if(i->getInterfaceName().contains("usb")) 441 if(i->getInterfaceName().contains("usb"))
440 typeName = "usb"; 442 typeName = "usb";
441 443
442 if(!i->isAttached()) 444 if(!i->isAttached())
443 typeName = "connect_no"; 445 typeName = "connect_no";
444 // Actually try to use the Module 446 // Actually try to use the Module
445 if(i->getModuleOwner() != NULL) 447 if(i->getModuleOwner() != NULL)
446 typeName = i->getModuleOwner()->getPixmapName(i); 448 typeName = i->getModuleOwner()->getPixmapName(i);
447 449
448 item->setPixmap(1, (Resource::loadPixmap(typeName))); 450 item->setPixmap(1, (Resource::loadPixmap(typeName)));
449 item->setText(2, i->getHardwareName()); 451 item->setText(2, i->getHardwareName());
450 item->setText(3, QString("(%1)").arg(i->getInterfaceName())); 452 item->setText(3, QString("(%1)").arg(i->getInterfaceName()));
451 item->setText(4, (i->getStatus()) ? i->getIp() : QString("")); 453 item->setText(4, (i->getStatus()) ? i->getIp() : QString(""));
452} 454}
453 455
454void MainWindowImp::newProfileChanged(const QString& newText){ 456void MainWindowImp::newProfileChanged(const QString& newText){
455 if(newText.length() > 0) 457 if(newText.length() > 0)
456 newProfileButton->setEnabled(true); 458 newProfileButton->setEnabled(true);
457 else 459 else
458 newProfileButton->setEnabled(false); 460 newProfileButton->setEnabled(false);
459} 461}
460 462
461/** 463/**
462 * Adds a new profile to the list of profiles. 464 * Adds a new profile to the list of profiles.
463 * Don't add profiles that already exists. 465 * Don't add profiles that already exists.
464 * Appends to the list and QStringList 466 * Appends to the list and QStringList
465 */ 467 */
466void MainWindowImp::addProfile(){ 468void MainWindowImp::addProfile(){
467 QString newProfileName = newProfile->text(); 469 QString newProfileName = newProfile->text();
468 if(profiles.grep(newProfileName).count() > 0){ 470 if(profiles.grep(newProfileName).count() > 0){
469 QMessageBox::information(this, "Can't Add","Profile already exists.", "Ok"); 471 QMessageBox::information(this, "Can't Add","Profile already exists.", "Ok");
470 return; 472 return;
471 } 473 }
472 profiles.append(newProfileName); 474 profiles.append(newProfileName);
473 profilesList->insertItem(newProfileName); 475 profilesList->insertItem(newProfileName);
474} 476}
475 477
476/** 478/**
477 * Removes the currently selected profile in the combo. 479 * Removes the currently selected profile in the combo.
478 * Doesn't delete if there are less then 2 profiles. 480 * Doesn't delete if there are less then 2 profiles.
479 */ 481 */
480void MainWindowImp::removeProfile(){ 482void MainWindowImp::removeProfile(){
481 if(profilesList->count() <= 1){ 483 if(profilesList->count() <= 1){
482 QMessageBox::information(this, "Can't remove.","At least one profile\nis needed.", "Ok"); 484 QMessageBox::information(this, "Can't remove.","At least one profile\nis needed.", "Ok");
483 return; 485 return;
484 } 486 }
485 QString profileToRemove = profilesList->currentText(); 487 QString profileToRemove = profilesList->currentText();
486 if(profileToRemove == "All"){ 488 if(profileToRemove == "All"){
487 QMessageBox::information(this, "Can't remove.","Can't remove default.", "Ok"); 489 QMessageBox::information(this, "Can't remove.","Can't remove default.", "Ok");
488 return; 490 return;
489 } 491 }
490 // Can't remove the curent profile 492 // Can't remove the curent profile
491 if(profileToRemove == currentProfileLabel->text()){ 493 if(profileToRemove == currentProfileLabel->text()){
492 QMessageBox::information(this, "Can't remove.",QString("%1 is the current profile.").arg(profileToRemove), "Ok"); 494 QMessageBox::information(this, "Can't remove.",QString("%1 is the current profile.").arg(profileToRemove), "Ok");
493 return; 495 return;
494 496
495 } 497 }
496 498
497 if(QMessageBox::information(this, "Question",QString("Remove profile: %1").arg(profileToRemove), QMessageBox::Ok, QMessageBox::Cancel) == QMessageBox::Ok){ 499 if(QMessageBox::information(this, "Question",QString("Remove profile: %1").arg(profileToRemove), QMessageBox::Ok, QMessageBox::Cancel) == QMessageBox::Ok){
498 profiles = QStringList::split(" ", profiles.join(" ").replace(QRegExp(profileToRemove), "")); 500 profiles = QStringList::split(" ", profiles.join(" ").replace(QRegExp(profileToRemove), ""));
499 profilesList->clear(); 501 profilesList->clear();
500 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it) 502 for ( QStringList::Iterator it = profiles.begin(); it != profiles.end(); ++it)
501 profilesList->insertItem((*it)); 503 profilesList->insertItem((*it));
502 504
503 // Remove any interface settings and mappings. 505 // Remove any interface settings and mappings.
504 Interfaces interfaces; 506 Interfaces interfaces;
505 // Go through them one by one 507 // Go through them one by one
506 QMap<Interface*, QListViewItem*>::Iterator it; 508 QMap<Interface*, QListViewItem*>::Iterator it;
507 for( it = items.begin(); it != items.end(); ++it ){ 509 for( it = items.begin(); it != items.end(); ++it ){
508 QString interfaceName = it.key()->getInterfaceName(); 510 QString interfaceName = it.key()->getInterfaceName();
509 qDebug(interfaceName.latin1()); 511 qDebug(interfaceName.latin1());
510 if(interfaces.setInterface(interfaceName + "_" + profileToRemove)){ 512 if(interfaces.setInterface(interfaceName + "_" + profileToRemove)){
511 interfaces.removeInterface(); 513 interfaces.removeInterface();
512 if(interfaces.setMapping(interfaceName)){ 514 if(interfaces.setMapping(interfaceName)){
513 if(profilesList->count() == 1) 515 if(profilesList->count() == 1)
514 interfaces.removeMapping(); 516 interfaces.removeMapping();
515 else{ 517 else{
516 interfaces.removeMap("map", interfaceName + "_" + profileToRemove); 518 interfaces.removeMap("map", interfaceName + "_" + profileToRemove);
517 } 519 }
518 } 520 }
519 interfaces.write(); 521 interfaces.write();
520 break; 522 break;
521 } 523 }
522 } 524 }
523 } 525 }
524} 526}
525 527
526/** 528/**
527 * A new profile has been selected, change. 529 * A new profile has been selected, change.
528 * @param newProfile the new profile. 530 * @param newProfile the new profile.
529 */ 531 */
530void MainWindowImp::changeProfile(){ 532void MainWindowImp::changeProfile(){
531 if(profilesList->currentItem() == -1){ 533 if(profilesList->currentItem() == -1){
532 QMessageBox::information(this, "Can't Change.","Please select a profile.", "Ok"); 534 QMessageBox::information(this, "Can't Change.","Please select a profile.", "Ok");
533 return; 535 return;
534 } 536 }
535 QString newProfile = profilesList->text(profilesList->currentItem()); 537 QString newProfile = profilesList->text(profilesList->currentItem());
536 if(newProfile != currentProfileLabel->text()){ 538 if(newProfile != currentProfileLabel->text()){
537 currentProfileLabel->setText(newProfile); 539 currentProfileLabel->setText(newProfile);
538 QFile::remove(scheme); 540 QFile::remove(scheme);
539 QFile file(scheme); 541 QFile file(scheme);
540 if ( file.open(IO_ReadWrite) ) { 542 if ( file.open(IO_ReadWrite) ) {
541 QTextStream stream( &file ); 543 QTextStream stream( &file );
542 stream << QString("SCHEME=%1").arg(newProfile); 544 stream << QString("SCHEME=%1").arg(newProfile);
543 file.close(); 545 file.close();
544 } 546 }
545 // restart all up devices? 547 // restart all up devices?
546 if(QMessageBox::information(this, "Question","Restart all running interfaces?", QMessageBox::Ok, QMessageBox::No) == QMessageBox::Ok){ 548 if(QMessageBox::information(this, "Question","Restart all running interfaces?", QMessageBox::Ok, QMessageBox::No) == QMessageBox::Ok){
547 // Go through them one by one 549 // Go through them one by one
548 QMap<Interface*, QListViewItem*>::Iterator it; 550 QMap<Interface*, QListViewItem*>::Iterator it;
549 for( it = items.begin(); it != items.end(); ++it ){ 551 for( it = items.begin(); it != items.end(); ++it ){
550 if(it.key()->getStatus() == true) 552 if(it.key()->getStatus() == true)
551 it.key()->restart(); 553 it.key()->restart();
552 } 554 }
553 } 555 }
554 } 556 }
555} 557}
556 558
557// mainwindowimp.cpp 559// mainwindowimp.cpp
558 560
diff --git a/noncore/settings/networksettings/wlan/wextensions.cpp b/noncore/settings/networksettings/wlan/wextensions.cpp
index ef4ba8f..e545bd1 100644
--- a/noncore/settings/networksettings/wlan/wextensions.cpp
+++ b/noncore/settings/networksettings/wlan/wextensions.cpp
@@ -1,175 +1,175 @@
1#include "wextensions.h" 1#include "wextensions.h"
2 2
3#include <qfile.h> 3#include <qfile.h>
4#include <qtextstream.h> 4#include <qtextstream.h>
5 5
6#include <arpa/inet.h> 6#include <arpa/inet.h>
7#include <sys/socket.h> 7#include <sys/socket.h>
8#include <sys/ioctl.h> 8#include <sys/ioctl.h>
9 9
10#include <math.h> 10#include <math.h>
11 11
12#define PROCNETWIRELESS "/proc/net/wireless" 12#define PROCNETWIRELESS "/proc/net/wireless"
13#define IW_LOWER 0 13#define IW_LOWER 0
14#define IW_UPPER 256 14#define IW_UPPER 256
15 15
16/** 16/**
17 * Constructor. Sets hasWirelessExtensions 17 * Constructor. Sets hasWirelessExtensions
18 */ 18 */
19WExtensions::WExtensions(QString interfaceName){ 19WExtensions::WExtensions(QString interfaceName){
20 interface = interfaceName; 20 interface = interfaceName;
21 fd = socket( AF_INET, SOCK_DGRAM, 0 ); 21 fd = socket( AF_INET, SOCK_DGRAM, 0 );
22 22
23 const char* buffer[200]; 23 const char* buffer[200];
24 memset( &iwr, 0, sizeof( iwr ) ); 24 memset( &iwr, 0, sizeof( iwr ) );
25 iwr.u.essid.pointer = (caddr_t) buffer; 25 iwr.u.essid.pointer = (caddr_t) buffer;
26 iwr.u.essid.length = IW_ESSID_MAX_SIZE; 26 iwr.u.essid.length = IW_ESSID_MAX_SIZE;
27 iwr.u.essid.flags = 0; 27 iwr.u.essid.flags = 0;
28 28
29 // check if it is an IEEE 802.11 standard conform 29 // check if it is an IEEE 802.11 standard conform
30 // wireless device by sending SIOCGIWESSID 30 // wireless device by sending SIOCGIWESSID
31 // which also gives back the Extended Service Set ID 31 // which also gives back the Extended Service Set ID
32 // (see IEEE 802.11 for more information) 32 // (see IEEE 802.11 for more information)
33 33
34 const char* iname = interface.latin1(); 34 const char* iname = interface.latin1();
35 strcpy( iwr.ifr_ifrn.ifrn_name, (const char *)iname ); 35 strcpy( iwr.ifr_ifrn.ifrn_name, (const char *)iname );
36 if ( 0 == ioctl( fd, SIOCGIWESSID, &iwr ) ) 36 if ( 0 == ioctl( fd, SIOCGIWESSID, &iwr ) )
37 hasWirelessExtensions = true; 37 hasWirelessExtensions = true;
38 else 38 else
39 hasWirelessExtensions = false; 39 hasWirelessExtensions = false;
40} 40}
41 41
42/** 42/**
43 * @return QString the station name of the access point. 43 * @return QString the station name of the access point.
44 */ 44 */
45QString WExtensions::station(){ 45QString WExtensions::station(){
46 if(!hasWirelessExtensions) 46 if(!hasWirelessExtensions)
47 return QString(); 47 return QString();
48 const char* buffer[200]; 48 const char* buffer[200];
49 iwr.u.data.pointer = (caddr_t) buffer; 49 iwr.u.data.pointer = (caddr_t) buffer;
50 iwr.u.data.length = IW_ESSID_MAX_SIZE; 50 iwr.u.data.length = IW_ESSID_MAX_SIZE;
51 iwr.u.data.flags = 0; 51 iwr.u.data.flags = 0;
52 if ( 0 == ioctl( fd, SIOCGIWNICKN, &iwr )){ 52 if ( 0 == ioctl( fd, SIOCGIWNICKN, &iwr )){
53 iwr.u.data.pointer[(unsigned int) iwr.u.data.length-1] = '\0'; 53 iwr.u.data.pointer[(unsigned int) iwr.u.data.length-1] = '\0';
54 return QString(iwr.u.data.pointer); 54 return QString(iwr.u.data.pointer);
55 } 55 }
56 return QString(); 56 return QString();
57} 57}
58 58
59/** 59/**
60 * @return QString the essid of the host 802.11 access point. 60 * @return QString the essid of the host 802.11 access point.
61 */ 61 */
62QString WExtensions::essid(){ 62QString WExtensions::essid(){
63 if(!hasWirelessExtensions) 63 if(!hasWirelessExtensions)
64 return QString(); 64 return QString();
65 if ( 0 == ioctl( fd, SIOCGIWESSID, &iwr )){ 65 if ( 0 == ioctl( fd, SIOCGIWESSID, &iwr )){
66 iwr.u.essid.pointer[(unsigned int) iwr.u.essid.length-1] = '\0'; 66 iwr.u.essid.pointer[(unsigned int) iwr.u.essid.length-1] = '\0';
67 return QString(iwr.u.essid.pointer); 67 return QString(iwr.u.essid.pointer);
68 } 68 }
69 return QString(); 69 return QString();
70} 70}
71 71
72/** 72/**
73 * @return QString the mode of interface 73 * @return QString the mode of interface
74 */ 74 */
75QString WExtensions::mode(){ 75QString WExtensions::mode(){
76 if(!hasWirelessExtensions) 76 if(!hasWirelessExtensions)
77 return QString(); 77 return QString();
78 if ( 0 == ioctl( fd, SIOCGIWMODE, &iwr ) ) 78 if ( 0 == ioctl( fd, SIOCGIWMODE, &iwr ) )
79 return QString("%1").arg(iwr.u.mode == IW_MODE_ADHOC ? "Ad-Hoc" : "Managed"); 79 return QString("%1").arg(iwr.u.mode == IW_MODE_ADHOC ? "Ad-Hoc" : "Managed");
80 return QString(); 80 return QString();
81} 81}
82 82
83/** 83/**
84 * Get the frequency that the interface is running at. 84 * Get the frequency that the interface is running at.
85 * @return int the frequency that the interfacae is running at. 85 * @return int the frequency that the interfacae is running at.
86 */ 86 */
87double WExtensions::frequency(){ 87double WExtensions::frequency(){
88 if(!hasWirelessExtensions) 88 if(!hasWirelessExtensions)
89 return 0; 89 return 0;
90 if ( 0 == ioctl( fd, SIOCGIWFREQ, &iwr )) 90 if ( 0 == ioctl( fd, SIOCGIWFREQ, &iwr ))
91 return (double( iwr.u.freq.m ) * pow( 10, iwr.u.freq.e ) / 1000000000); 91 return (double( iwr.u.freq.m ) * pow( 10, iwr.u.freq.e ) / 1000000000);
92 return 0; 92 return 0;
93} 93}
94 94
95/*** 95/***
96 * Get the current rate that the card is transmiting at. 96 * Get the current rate that the card is transmiting at.
97 */ 97 */
98double WExtensions::rate(){ 98double WExtensions::rate(){
99 if(!hasWirelessExtensions) 99 if(!hasWirelessExtensions)
100 return 0; 100 return 0;
101 if(0 == ioctl(fd, SIOCGIWRATE, &iwr)){ 101 if(0 == ioctl(fd, SIOCGIWRATE, &iwr)){
102 return ((double)iwr.u.bitrate.value)/1000000; 102 return ((double)iwr.u.bitrate.value)/1000000;
103 } 103 }
104 return 0; 104 return 0;
105} 105}
106 106
107 107
108/** 108/**
109 * @return QString the AccessPoint that the interface is connected to. 109 * @return QString the AccessPoint that the interface is connected to.
110 */ 110 */
111QString WExtensions::ap(){ 111QString WExtensions::ap(){
112 if(!hasWirelessExtensions) 112 if(!hasWirelessExtensions)
113 return QString(); 113 return QString();
114 if ( 0 == ioctl( fd, SIOCGIWAP, &iwr )){ 114 if ( 0 == ioctl( fd, SIOCGIWAP, &iwr )){
115 QString ap; 115 QString ap;
116 ap = ap.sprintf( "%.2X:%.2X:%.2X:%.2X:%.2X:%.2X", 116 ap = ap.sprintf( "%.2X:%.2X:%.2X:%.2X:%.2X:%.2X",
117 iwr.u.ap_addr.sa_data[0]&0xff, 117 iwr.u.ap_addr.sa_data[0]&0xff,
118 iwr.u.ap_addr.sa_data[1]&0xff, 118 iwr.u.ap_addr.sa_data[1]&0xff,
119 iwr.u.ap_addr.sa_data[2]&0xff, 119 iwr.u.ap_addr.sa_data[2]&0xff,
120 iwr.u.ap_addr.sa_data[3]&0xff, 120 iwr.u.ap_addr.sa_data[3]&0xff,
121 iwr.u.ap_addr.sa_data[4]&0xff, 121 iwr.u.ap_addr.sa_data[4]&0xff,
122 iwr.u.ap_addr.sa_data[5]&0xff ); 122 iwr.u.ap_addr.sa_data[5]&0xff );
123 return ap; 123 return ap;
124 } 124 }
125 else return QString(); 125 else return QString();
126} 126}
127 127
128/** 128/**
129 * Get the stats for interfaces 129 * Get the stats for interfaces
130 * @param signal the signal strength of interface 130 * @param signal the signal strength of interface
131 * @param noise the noise level of the interface 131 * @param noise the noise level of the interface
132 * @param quality the quality level of the interface 132 * @param quality the quality level of the interface
133 * @return bool true if successfull 133 * @return bool true if successfull
134 */ 134 */
135bool WExtensions::stats(int &signal, int &noise, int &quality){ 135bool WExtensions::stats(int &signal, int &noise, int &quality){
136 // gather link quality from /proc/net/wireless 136 // gather link quality from /proc/net/wireless
137 if(!QFile::exists(PROCNETWIRELESS)) 137 if(!QFile::exists(PROCNETWIRELESS))
138 return false; 138 return false;
139 139
140 char c; 140 char c;
141 QString status; 141 QString status;
142 QString name; 142 QString name;
143 143
144 QFile wfile( PROCNETWIRELESS ); 144 QFile wfile( PROCNETWIRELESS );
145 if(!wfile.open( IO_ReadOnly )) 145 if(!wfile.open( IO_ReadOnly ))
146 return false; 146 return false;
147 147
148 QTextStream wstream( &wfile ); 148 QTextStream wstream( &wfile );
149 wstream.readLine(); // skip the first two lines 149 wstream.readLine(); // skip the first two lines
150 wstream.readLine(); // because they only contain headers 150 wstream.readLine(); // because they only contain headers
151 while(!wstream.atEnd()){ 151 while(!wstream.atEnd()){
152 wstream >> name >> status >> quality >> c >> signal >> c >> noise; 152 wstream >> name >> status >> quality >> c >> signal >> c >> noise;
153 if(name == QString("%1:").arg(interface)){ 153 if(name == QString("%1:").arg(interface)){
154 if ( quality > 92 ) 154 if ( quality > 92 )
155 qDebug( "WIFIAPPLET: D'oh! Quality %d > estimated max!\n", quality ); 155 qDebug( "WIFIAPPLET: D'oh! Quality %d > estimated max!\n", quality );
156 if ( ( signal > IW_UPPER ) || ( signal < IW_LOWER ) ) 156 if ( ( signal > IW_UPPER ) || ( signal < IW_LOWER ) )
157 qDebug( "WIFIAPPLET: Doh! Strength %d > estimated max!\n", signal ); 157 qDebug( "WIFIAPPLET: Doh! Strength %d > estimated max!\n", signal );
158 if ( ( noise > IW_UPPER ) || ( noise < IW_LOWER ) ) 158 if ( ( noise > IW_UPPER ) || ( noise < IW_LOWER ) )
159 qDebug( "WIFIAPPLET: Doh! Noise %d > estimated max!\n", noise ); 159 qDebug( "WIFIAPPLET: Doh! Noise %d > estimated max!\n", noise );
160 qDebug(QString("q:%1, s:%2, n:%3").arg(quality).arg(signal).arg(noise).latin1()); 160 //qDebug(QString("q:%1, s:%2, n:%3").arg(quality).arg(signal).arg(noise).latin1());
161 signal = ( ( signal-IW_LOWER ) * 100 ) / IW_UPPER; 161 signal = ( ( signal-IW_LOWER ) * 100 ) / IW_UPPER;
162 noise = ( ( noise-IW_LOWER ) * 100 ) / IW_UPPER; 162 noise = ( ( noise-IW_LOWER ) * 100 ) / IW_UPPER;
163 quality = ( quality*100 ) / 92; 163 quality = ( quality*100 ) / 92;
164 return true; 164 return true;
165 } 165 }
166 } 166 }
167 167
168 qDebug("WExtensions::statsCard no longer present."); 168 qDebug("WExtensions::statsCard no longer present.");
169 quality = -1; 169 quality = -1;
170 signal = IW_LOWER; 170 signal = IW_LOWER;
171 noise = IW_LOWER; 171 noise = IW_LOWER;
172 return false; 172 return false;
173} 173}
174 174
175// wextensions.cpp 175// wextensions.cpp
diff --git a/noncore/settings/networksettings/wlan/wlanimp.cpp b/noncore/settings/networksettings/wlan/wlanimp.cpp
index ea19207..94c7518 100644
--- a/noncore/settings/networksettings/wlan/wlanimp.cpp
+++ b/noncore/settings/networksettings/wlan/wlanimp.cpp
@@ -1,239 +1,239 @@
1#include "wlanimp.h" 1#include "wlanimp.h"
2 2
3/* Config class */ 3/* Config class */
4#include <qpe/config.h> 4#include <qpe/config.h>
5/* Global namespace */ 5/* Global namespace */
6#include <qpe/global.h> 6#include <qpe/global.h>
7/* system() */ 7/* system() */
8#include <stdlib.h> 8#include <stdlib.h>
9#include <qfile.h> 9#include <qfile.h>
10#include <qdir.h> 10#include <qdir.h>
11#include <qtextstream.h> 11#include <qtextstream.h>
12#include <qmessagebox.h> 12#include <qmessagebox.h>
13#include <qlineedit.h> 13#include <qlineedit.h>
14#include <qspinbox.h> 14#include <qspinbox.h>
15#include <qradiobutton.h> 15#include <qradiobutton.h>
16#include <qcheckbox.h> 16#include <qcheckbox.h>
17#include <qregexp.h> 17#include <qregexp.h>
18 18
19WLANImp::WLANImp( QWidget* parent, const char* name):WLAN(parent, name){ 19WLANImp::WLANImp( QWidget* parent, const char* name):WLAN(parent, name, Qt::WDestructiveClose){
20 config = new Config("wireless"); 20 config = new Config("wireless");
21 readConfig(); 21 readConfig();
22} 22}
23 23
24WLANImp::~WLANImp( ){ 24WLANImp::~WLANImp( ){
25 delete config; 25 delete config;
26} 26}
27 27
28void WLANImp::readConfig() 28void WLANImp::readConfig()
29{ 29{
30 qWarning( "WLANImp::readConfig() called." ); 30 qWarning( "WLANImp::readConfig() called." );
31 config->setGroup( "Properties" ); 31 config->setGroup( "Properties" );
32 QString ssid = config->readEntry( "SSID", "any" ); 32 QString ssid = config->readEntry( "SSID", "any" );
33 if( ssid == "any" || ssid == "ANY" ){ 33 if( ssid == "any" || ssid == "ANY" ){
34 essNon->setChecked( true ); 34 essNon->setChecked( true );
35 } else { 35 } else {
36 essSpecific->setChecked( true ); 36 essSpecific->setChecked( true );
37 essSpecificLineEdit->setText( ssid ); 37 essSpecificLineEdit->setText( ssid );
38 } 38 }
39 QString mode = config->readEntry( "Mode", "Managed" ); 39 QString mode = config->readEntry( "Mode", "Managed" );
40 if( mode == "adhoc" ) { 40 if( mode == "adhoc" ) {
41 network802->setChecked( true ); 41 network802->setChecked( true );
42 } else { 42 } else {
43 networkInfrastructure->setChecked( true ); 43 networkInfrastructure->setChecked( true );
44 } 44 }
45 networkChannel->setValue( config->readNumEntry( "CHANNEL", 1 ) ); 45 networkChannel->setValue( config->readNumEntry( "CHANNEL", 1 ) );
46// config->readEntry( "RATE", "auto" ); 46// config->readEntry( "RATE", "auto" );
47 config->readEntry( "dot11PrivacyInvoked" ) == "true" ? wepEnabled->setChecked( true ) : wepEnabled->setChecked( false ); 47 config->readEntry( "dot11PrivacyInvoked" ) == "true" ? wepEnabled->setChecked( true ) : wepEnabled->setChecked( false );
48 config->readEntry( "AuthType", "opensystem" ); 48 config->readEntry( "AuthType", "opensystem" );
49 config->readEntry( "PRIV_KEY128", "false" ) == "false" ? key40->setChecked( true ) : key128->setChecked( true ); 49 config->readEntry( "PRIV_KEY128", "false" ) == "false" ? key40->setChecked( true ) : key128->setChecked( true );
50 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 ); 50 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 );
51 switch( defaultkey ){ 51 switch( defaultkey ){
52 case 0: 52 case 0:
53 keyRadio0->setChecked( true ); 53 keyRadio0->setChecked( true );
54 break; 54 break;
55 case 1: 55 case 1:
56 keyRadio1->setChecked( true ); 56 keyRadio1->setChecked( true );
57 break; 57 break;
58 case 2: 58 case 2:
59 keyRadio2->setChecked( true ); 59 keyRadio2->setChecked( true );
60 break; 60 break;
61 case 3: 61 case 3:
62 keyRadio3->setChecked( true ); 62 keyRadio3->setChecked( true );
63 break; 63 break;
64 } 64 }
65 keyLineEdit0->setText(config->readEntry( "dot11WEPDefaultKey0" )); 65 keyLineEdit0->setText(config->readEntry( "dot11WEPDefaultKey0" ));
66 keyLineEdit1->setText(config->readEntry( "dot11WEPDefaultKey1" )); 66 keyLineEdit1->setText(config->readEntry( "dot11WEPDefaultKey1" ));
67 keyLineEdit2->setText(config->readEntry( "dot11WEPDefaultKey2" )); 67 keyLineEdit2->setText(config->readEntry( "dot11WEPDefaultKey2" ));
68 keyLineEdit3->setText(config->readEntry( "dot11WEPDefaultKey3" )); 68 keyLineEdit3->setText(config->readEntry( "dot11WEPDefaultKey3" ));
69 return; 69 return;
70} 70}
71 71
72bool WLANImp::writeConfig() 72bool WLANImp::writeConfig()
73{ 73{
74 qWarning( "WLANImp::writeConfig() called." ); 74 qWarning( "WLANImp::writeConfig() called." );
75 config->setGroup( "Properties" ); 75 config->setGroup( "Properties" );
76 if( essNon->isChecked() ) { 76 if( essNon->isChecked() ) {
77 config->writeEntry( "SSID", "any" ); 77 config->writeEntry( "SSID", "any" );
78 } else { 78 } else {
79 config->writeEntry( "SSID", essSpecificLineEdit->text() ); 79 config->writeEntry( "SSID", essSpecificLineEdit->text() );
80 } 80 }
81 if( networkInfrastructure->isChecked() ){ 81 if( networkInfrastructure->isChecked() ){
82 config->writeEntry( "Mode", "Managed" ); 82 config->writeEntry( "Mode", "Managed" );
83 } else if( network802->isChecked() ){ 83 } else if( network802->isChecked() ){
84 config->writeEntry( "Mode", "adhoc" ); 84 config->writeEntry( "Mode", "adhoc" );
85 } 85 }
86 config->writeEntry( "CHANNEL", networkChannel->value() ); 86 config->writeEntry( "CHANNEL", networkChannel->value() );
87// config->readEntry( "RATE", "auto" ); 87// config->readEntry( "RATE", "auto" );
88 wepEnabled->isChecked() ? config->writeEntry( "dot11PrivacyInvoked", "true" ) : config->writeEntry( "dot11PrivacyInvoked", "false" ); 88 wepEnabled->isChecked() ? config->writeEntry( "dot11PrivacyInvoked", "true" ) : config->writeEntry( "dot11PrivacyInvoked", "false" );
89 authOpen->isChecked() ? config->writeEntry( "AuthType", "opensystem" ) : config->writeEntry( "AuthType", "sharedkey" ); 89 authOpen->isChecked() ? config->writeEntry( "AuthType", "opensystem" ) : config->writeEntry( "AuthType", "sharedkey" );
90 key40->isChecked() ? config->writeEntry( "PRIV_KEY128", "false" ) : config->writeEntry( "PRIV_KEY128", "true" ); 90 key40->isChecked() ? config->writeEntry( "PRIV_KEY128", "false" ) : config->writeEntry( "PRIV_KEY128", "true" );
91 if( keyRadio0->isChecked() ){ 91 if( keyRadio0->isChecked() ){
92 config->writeEntry( "dot11WEPDefaultKeyID", 0 ); 92 config->writeEntry( "dot11WEPDefaultKeyID", 0 );
93 } else if( keyRadio1->isChecked() ){ 93 } else if( keyRadio1->isChecked() ){
94 config->writeEntry( "dot11WEPDefaultKeyID", 1 ); 94 config->writeEntry( "dot11WEPDefaultKeyID", 1 );
95 } else if( keyRadio2->isChecked() ){ 95 } else if( keyRadio2->isChecked() ){
96 config->writeEntry( "dot11WEPDefaultKeyID", 2 ); 96 config->writeEntry( "dot11WEPDefaultKeyID", 2 );
97 } else if( keyRadio3->isChecked() ){ 97 } else if( keyRadio3->isChecked() ){
98 config->writeEntry( "dot11WEPDefaultKeyID", 3 ); 98 config->writeEntry( "dot11WEPDefaultKeyID", 3 );
99 } 99 }
100 config->writeEntry( "dot11WEPDefaultKey0", keyLineEdit0->text() ); 100 config->writeEntry( "dot11WEPDefaultKey0", keyLineEdit0->text() );
101 config->writeEntry( "dot11WEPDefaultKey1", keyLineEdit1->text() ); 101 config->writeEntry( "dot11WEPDefaultKey1", keyLineEdit1->text() );
102 config->writeEntry( "dot11WEPDefaultKey2", keyLineEdit2->text() ); 102 config->writeEntry( "dot11WEPDefaultKey2", keyLineEdit2->text() );
103 config->writeEntry( "dot11WEPDefaultKey3", keyLineEdit3->text() ); 103 config->writeEntry( "dot11WEPDefaultKey3", keyLineEdit3->text() );
104 return writeWirelessOpts( ); 104 return writeWirelessOpts( );
105} 105}
106 106
107/** 107/**
108 */ 108 */
109void WLANImp::accept() 109void WLANImp::accept()
110{ 110{
111 if ( writeConfig() ) 111 if ( writeConfig() )
112 QDialog::accept(); 112 QDialog::accept();
113} 113}
114 114
115void WLANImp::done ( int r ) 115void WLANImp::done ( int r )
116{ 116{
117 QDialog::done ( r ); 117 QDialog::done ( r );
118 close ( ); 118 close ( );
119} 119}
120 120
121bool WLANImp::writeWirelessOpts( QString scheme ) 121bool WLANImp::writeWirelessOpts( QString scheme )
122{ 122{
123 qWarning( "WLANImp::writeWirelessOpts entered." ); 123 qWarning( "WLANImp::writeWirelessOpts entered." );
124 QString prev = "/etc/pcmcia/wireless.opts"; 124 QString prev = "/etc/pcmcia/wireless.opts";
125 QFile prevFile(prev); 125 QFile prevFile(prev);
126 if ( !prevFile.open( IO_ReadOnly ) ) 126 if ( !prevFile.open( IO_ReadOnly ) )
127 return false; 127 return false;
128 128
129 QString tmp = "/etc/pcmcia/wireless.opts-qpe-new"; 129 QString tmp = "/etc/pcmcia/wireless.opts-qpe-new";
130 QFile tmpFile(tmp); 130 QFile tmpFile(tmp);
131 if ( !tmpFile.open( IO_WriteOnly ) ) 131 if ( !tmpFile.open( IO_WriteOnly ) )
132 return false; 132 return false;
133 133
134 bool retval = true; 134 bool retval = true;
135 135
136 QTextStream in( &prevFile ); 136 QTextStream in( &prevFile );
137 QTextStream out( &tmpFile ); 137 QTextStream out( &tmpFile );
138 138
139 config->setGroup("Properties"); 139 config->setGroup("Properties");
140 140
141 QString line; 141 QString line;
142 bool found=false; 142 bool found=false;
143 bool done=false; 143 bool done=false;
144 while ( !in.atEnd() ) { 144 while ( !in.atEnd() ) {
145 QString line = in.readLine(); 145 QString line = in.readLine();
146 QString wline = line.simplifyWhiteSpace(); 146 QString wline = line.simplifyWhiteSpace();
147 if ( !done ) { 147 if ( !done ) {
148 if ( found ) { 148 if ( found ) {
149 // skip existing entry for this scheme, and write our own. 149 // skip existing entry for this scheme, and write our own.
150 if ( wline == ";;" ) { 150 if ( wline == ";;" ) {
151 found = false; 151 found = false;
152 continue; 152 continue;
153 } else { 153 } else {
154 continue; 154 continue;
155 } 155 }
156 } else { 156 } else {
157 if ( wline.left(scheme.length()+7) == scheme + ",*,*,*)" ) { 157 if ( wline.left(scheme.length()+7) == scheme + ",*,*,*)" ) {
158 found=true; 158 found=true;
159 continue; // skip this line 159 continue; // skip this line
160 } else if ( wline == "esac" || wline == "*,*,*,*)" ) { 160 } else if ( wline == "esac" || wline == "*,*,*,*)" ) {
161 // end - add new entry 161 // end - add new entry
162 // Not all fields have a GUI, but all are supported 162 // Not all fields have a GUI, but all are supported
163 // in the letwork configuration files. 163 // in the letwork configuration files.
164 static const char* txtfields[] = { 164 static const char* txtfields[] = {
165 0 165 0
166 }; 166 };
167 QString readmode = config->readEntry( "Mode", "Managed" ); 167 QString readmode = config->readEntry( "Mode", "Managed" );
168 QString mode; 168 QString mode;
169 if( readmode == "Managed" ){ 169 if( readmode == "Managed" ){
170 mode = readmode; 170 mode = readmode;
171 } else if( readmode == "adhoc" ){ 171 } else if( readmode == "adhoc" ){
172 mode = "Ad-Hoc"; 172 mode = "Ad-Hoc";
173 } 173 }
174 QString key; 174 QString key;
175 if( wepEnabled->isChecked() ){ 175 if( wepEnabled->isChecked() ){
176 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 ); 176 int defaultkey = config->readNumEntry( "dot11WEPDefaultKeyID", 0 );
177 switch( defaultkey ){ 177 switch( defaultkey ){
178 case 0: 178 case 0:
179 key += keyLineEdit0->text(); 179 key += keyLineEdit0->text();
180 break; 180 break;
181 case 1: 181 case 1:
182 key += keyLineEdit1->text(); 182 key += keyLineEdit1->text();
183 break; 183 break;
184 case 2: 184 case 2:
185 key += keyLineEdit2->text(); 185 key += keyLineEdit2->text();
186 break; 186 break;
187 case 3: 187 case 3:
188 key += keyLineEdit3->text(); 188 key += keyLineEdit3->text();
189 break; 189 break;
190 } 190 }
191 if( config->readEntry( "AuthType", "opensystem" ) == "opensystem") 191 if( config->readEntry( "AuthType", "opensystem" ) == "opensystem")
192 key += " open"; 192 key += " open";
193 } 193 }
194 out << scheme << ",*,*,*)" << "\n" 194 out << scheme << ",*,*,*)" << "\n"
195 << " ESSID=" << Global::shellQuote( config->readEntry( "SSID", "any" ) ) << "\n" 195 << " ESSID=" << Global::shellQuote( config->readEntry( "SSID", "any" ) ) << "\n"
196 << " MODE=" << mode << "\n" 196 << " MODE=" << mode << "\n"
197 << " KEY=" << Global::shellQuote( key ) << "\n" 197 << " KEY=" << Global::shellQuote( key ) << "\n"
198 << " RATE=" << "auto" << "\n" 198 << " RATE=" << "auto" << "\n"
199 ; 199 ;
200 if( mode != "Managed" ) 200 if( mode != "Managed" )
201 out << " CHANNEL=" << config->readNumEntry( "CHANNEL", 1 ) << "\n"; 201 out << " CHANNEL=" << config->readNumEntry( "CHANNEL", 1 ) << "\n";
202 const char** f = txtfields; 202 const char** f = txtfields;
203 while (*f) { 203 while (*f) {
204 out << " " << *f << "=" << config->readEntry(*f,"") << "\n"; 204 out << " " << *f << "=" << config->readEntry(*f,"") << "\n";
205 ++f; 205 ++f;
206 } 206 }
207 out << " ;;\n"; 207 out << " ;;\n";
208 done = true; 208 done = true;
209 } 209 }
210 } 210 }
211 } 211 }
212 out << line << "\n"; 212 out << line << "\n";
213 } 213 }
214 214
215 prevFile.close(); 215 prevFile.close();
216 tmpFile.close(); 216 tmpFile.close();
217 QString initpath; 217 QString initpath;
218 //system("cardctl suspend"); 218 //system("cardctl suspend");
219 if( QDir("/etc/rc.d/init.d").exists() ){ 219 if( QDir("/etc/rc.d/init.d").exists() ){
220 initpath = "/etc/rc.d/init.d"; 220 initpath = "/etc/rc.d/init.d";
221 } else if( QDir("/etc/init.d").exists() ){ 221 } else if( QDir("/etc/init.d").exists() ){
222 initpath = "/etc/init.d"; 222 initpath = "/etc/init.d";
223 } 223 }
224 if( initpath ) 224 if( initpath )
225 system(QString("%1/pcmcia stop").arg(initpath)); 225 system(QString("%1/pcmcia stop").arg(initpath));
226 226
227 if( system( "mv " + tmp + " " + prev ) ) 227 if( system( "mv " + tmp + " " + prev ) )
228 retval = false; 228 retval = false;
229//#ifdef USE_SCHEMES 229//#ifdef USE_SCHEMES
230// if ( retval ) 230// if ( retval )
231 //SchemeChanger::changeScheme(scheme); 231 //SchemeChanger::changeScheme(scheme);
232//#endif 232//#endif
233 233
234 //system("cardctl resume"); 234 //system("cardctl resume");
235 if( initpath ) 235 if( initpath )
236 system(QString("%1/pcmcia start").arg(initpath)); 236 system(QString("%1/pcmcia start").arg(initpath));
237 237
238 return retval; 238 return retval;
239} 239}
diff --git a/noncore/settings/networksettings/wlan/wlanmodule.cpp b/noncore/settings/networksettings/wlan/wlanmodule.cpp
index 73e753c..7507c54 100644
--- a/noncore/settings/networksettings/wlan/wlanmodule.cpp
+++ b/noncore/settings/networksettings/wlan/wlanmodule.cpp
@@ -1,129 +1,129 @@
1#include "wlanmodule.h" 1#include "wlanmodule.h"
2#include "wlanimp.h" 2#include "wlanimp.h"
3#include "info.h" 3#include "info.h"
4#include "wextensions.h" 4#include "wextensions.h"
5 5
6#include <qlabel.h> 6#include <qlabel.h>
7#include <qprogressbar.h> 7#include <qprogressbar.h>
8 8
9/** 9/**
10 * Constructor, find all of the possible interfaces 10 * Constructor, find all of the possible interfaces
11 */ 11 */
12WLANModule::WLANModule() : Module() { 12WLANModule::WLANModule() : Module() {
13 // get output from iwconfig
14} 13}
15 14
16/** 15/**
17 */ 16 */
18WLANModule::~WLANModule(){ 17WLANModule::~WLANModule(){
19 Interface *i; 18 Interface *i;
20 for ( i=list.first(); i != 0; i=list.next() ) 19 for ( i=list.first(); i != 0; i=list.next() )
21 delete i; 20 delete i;
22} 21}
23 22
24/** 23/**
25 * Change the current profile 24 * Change the current profile
26 */ 25 */
27void WLANModule::setProfile(QString newProfile){ 26void WLANModule::setProfile(QString newProfile){
28 profile = newProfile; 27 profile = newProfile;
29} 28}
30 29
31/** 30/**
32 * get the icon name for this device. 31 * get the icon name for this device.
33 * @param Interface* can be used in determining the icon. 32 * @param Interface* can be used in determining the icon.
34 * @return QString the icon name (minus .png, .gif etc) 33 * @return QString the icon name (minus .png, .gif etc)
35 */ 34 */
36QString WLANModule::getPixmapName(Interface* ){ 35QString WLANModule::getPixmapName(Interface* ){
37 return "wlan"; 36 return "wlan";
38} 37}
39 38
40/** 39/**
41 * Check to see if the interface i is owned by this module. 40 * Check to see if the interface i is owned by this module.
42 * @param Interface* interface to check against 41 * @param Interface* interface to check against
43 * @return bool true if i is owned by this module, false otherwise. 42 * @return bool true if i is owned by this module, false otherwise.
44 */ 43 */
45bool WLANModule::isOwner(Interface *i){ 44bool WLANModule::isOwner(Interface *i){
46 WExtensions we(i->getInterfaceName()); 45 WExtensions we(i->getInterfaceName());
47 if(!we.doesHaveWirelessExtensions()) 46 if(!we.doesHaveWirelessExtensions())
48 return false; 47 return false;
49 48
50 //if(i->getInterfaceName() == "eth0" || i->getInterfaceName() == "wlan0"){ 49 i->setHardwareName("802.11b");
51 i->setHardwareName("802.11b"); 50 list.append(i);
52 list.append(i); 51 return true;
53 return true;
54 //}
55 //return false;
56} 52}
57 53
58/** 54/**
59 * Create, set tabWiget and return the WLANConfigure Module 55 * Create, set tabWiget and return the WLANConfigure Module
60 * @param tabWidget a pointer to the tab widget that this configure has. 56 * @param tabWidget a pointer to the tab widget that this configure has.
61 * @return QWidget* pointer to the tab widget in this modules configure. 57 * @return QWidget* pointer to the tab widget in this modules configure.
62 */ 58 */
63QWidget *WLANModule::configure(Interface *, QTabWidget **tabWidget){ 59QWidget *WLANModule::configure(Interface *, QTabWidget **tabWidget){
64 WLANImp *wlanconfig = new WLANImp(0, "WlanConfig"); 60 WLANImp *wlanconfig = new WLANImp(0, "WlanConfig");
65 (*tabWidget) = wlanconfig->tabWidget; 61 (*tabWidget) = wlanconfig->tabWidget;
66 return wlanconfig; 62 return wlanconfig;
67} 63}
68 64
69/** 65/**
70 * Create, set tabWiget and return the Information Module 66 * Create, set tabWiget and return the Information Module
71 * @param tabWidget a pointer to the tab widget that this information has. 67 * @param tabWidget a pointer to the tab widget that this information has.
72 * @return QWidget* pointer to the tab widget in this modules info. 68 * @return QWidget* pointer to the tab widget in this modules info.
73 */ 69 */
74QWidget *WLANModule::information(Interface *i, QTabWidget **tabWidget){ 70QWidget *WLANModule::information(Interface *i, QTabWidget **tabWidget){
75 WExtensions we(i->getInterfaceName()); 71 WExtensions we(i->getInterfaceName());
76 if(!we.doesHaveWirelessExtensions()) 72 if(!we.doesHaveWirelessExtensions())
77 return NULL; 73 return NULL;
78 74
79 WlanInfo *info = new WlanInfo(0, "wireless info"); 75 WlanInfo *info = new WlanInfo(0, "wireless info", Qt::WDestructiveClose);
80 (*tabWidget) = info->tabWidget; 76 (*tabWidget) = info->tabWidget;
81 77
82 info->essidLabel->setText(we.essid()); 78 info->essidLabel->setText(we.essid());
83 info->apLabel->setText(we.ap()); 79 info->apLabel->setText(we.ap());
84 info->stationLabel->setText(we.station()); 80 info->stationLabel->setText(we.station());
85 info->modeLabel->setText(we.mode()); 81 info->modeLabel->setText(we.mode());
86 info->freqLabel->setText(QString("%1 GHz").arg(we.frequency())); 82 info->freqLabel->setText(QString("%1 GHz").arg(we.frequency()));
87 int signal = 0; 83 int signal = 0;
88 int noise = 0; 84 int noise = 0;
89 int quality = 0; 85 int quality = 0;
90 we.stats(signal, noise, quality); 86 we.stats(signal, noise, quality);
91 info->signalProgressBar->setProgress(signal); 87 info->signalProgressBar->setProgress(signal);
92 info->noiseProgressBar->setProgress(noise); 88 info->noiseProgressBar->setProgress(noise);
93 info->qualityProgressBar->setProgress(quality); 89 info->qualityProgressBar->setProgress(quality);
94 info->rateLabel->setText(QString("%1 Mb/s").arg(we.rate())); 90 info->rateLabel->setText(QString("%1 Mb/s").arg(we.rate()));
91 //WlanInfo info (0, "wireless info", true);
92 //info.show();
93 //return NULL;
94
95 return info; 95 return info;
96} 96}
97 97
98/** 98/**
99 * Get all active (up or down) interfaces 99 * Get all active (up or down) interfaces
100 * @return QList<Interface> A list of interfaces that exsist that havn't 100 * @return QList<Interface> A list of interfaces that exsist that havn't
101 * been called by isOwner() 101 * been called by isOwner()
102 */ 102 */
103QList<Interface> WLANModule::getInterfaces(){ 103QList<Interface> WLANModule::getInterfaces(){
104 return list; 104 return list;
105} 105}
106 106
107/** 107/**
108 * Attempt to add a new interface as defined by name 108 * Attempt to add a new interface as defined by name
109 * @param name the name of the type of interface that should be created given 109 * @param name the name of the type of interface that should be created given
110 * by possibleNewInterfaces(); 110 * by possibleNewInterfaces();
111 * @return Interface* NULL if it was unable to be created. 111 * @return Interface* NULL if it was unable to be created.
112 */ 112 */
113Interface *WLANModule::addNewInterface(QString ){ 113Interface *WLANModule::addNewInterface(QString ){
114 // We can't add a 802.11 interface, either the hardware will be there 114 // We can't add a 802.11 interface, either the hardware will be there
115 // or it wont. 115 // or it wont.
116 return NULL; 116 return NULL;
117} 117}
118 118
119/** 119/**
120 * Attempts to remove the interface, doesn't delete i 120 * Attempts to remove the interface, doesn't delete i
121 * @return bool true if successfull, false otherwise. 121 * @return bool true if successfull, false otherwise.
122 */ 122 */
123bool WLANModule::remove(Interface*){ 123bool WLANModule::remove(Interface*){
124 // Can't remove a hardware device, you can stop it though. 124 // Can't remove a hardware device, you can stop it though.
125 return false; 125 return false;
126} 126}
127 127
128// wlanmodule.cpp 128// wlanmodule.cpp
129 129