-rw-r--r-- | noncore/settings/networksettings/wlan/config.in | 4 | ||||
-rw-r--r-- | noncore/settings/networksettings/wlan/opie-networksettingsplugin-wlan.control | 2 | ||||
-rw-r--r-- | noncore/settings/networksettings/wlan/wlan.pro | 2 | ||||
-rw-r--r-- | noncore/settings/networksettings/wlan/wlan.ui | 658 | ||||
-rw-r--r-- | noncore/settings/networksettings/wlan/wlanimp.cpp | 2 | ||||
-rw-r--r-- | noncore/settings/networksettings/wlan/wlanimp2.cpp | 216 | ||||
-rw-r--r-- | noncore/settings/networksettings/wlan/wlanimp2.h | 21 | ||||
-rw-r--r-- | pics/networksettings/adhoc.png | bin | 0 -> 694 bytes | |||
-rw-r--r-- | pics/networksettings/managed.png | bin | 0 -> 410 bytes |
9 files changed, 577 insertions, 328 deletions
diff --git a/noncore/settings/networksettings/wlan/config.in b/noncore/settings/networksettings/wlan/config.in index 53bcb1e..e459788 100644 --- a/noncore/settings/networksettings/wlan/config.in +++ b/noncore/settings/networksettings/wlan/config.in | |||
@@ -1,4 +1,6 @@ | |||
1 | config WLAN | 1 | config WLAN |
2 | boolean "opie-networksettingsplugin-wlan (wireless LAN module)" | 2 | boolean "opie-networksettingsplugin-wlan (wireless LAN module)" |
3 | default "n" if NETWORKSETUP | 3 | default "n" if NETWORKSETUP |
4 | depends ( LIBQPE || LIBQPE-X11 ) && LIBOPIE && NETWORKSETUP && NETWORKSETUP-CORE && INTERFACES | 4 | depends ( LIBQPE || LIBQPE-X11 ) && LIBOPIE && NETWORKSETUP && NETWORKSETUP-CORE && INTERFACES && LIBOPIE2NET |
5 | #comment "opie-networksettingsplugin-wlan needs libopie, libopie2net and networksetup" | ||
6 | #depends !( LIBOPIE2NET && LIBOPIE && NETWORKSETUP) \ No newline at end of file | ||
diff --git a/noncore/settings/networksettings/wlan/opie-networksettingsplugin-wlan.control b/noncore/settings/networksettings/wlan/opie-networksettingsplugin-wlan.control index 719337f..ec3078d 100644 --- a/noncore/settings/networksettings/wlan/opie-networksettingsplugin-wlan.control +++ b/noncore/settings/networksettings/wlan/opie-networksettingsplugin-wlan.control | |||
@@ -1,10 +1,10 @@ | |||
1 | Package: opie-networksettingsplugin-wlan | 1 | Package: opie-networksettingsplugin-wlan |
2 | Files: plugins/networksettings/libwlan.so* | 2 | Files: plugins/networksettings/libwlan.so* |
3 | Priority: optional | 3 | Priority: optional |
4 | Section: opie/settings | 4 | Section: opie/settings |
5 | Maintainer: Patrick S. Vogt <tille@handhelds.org> | 5 | Maintainer: Patrick S. Vogt <tille@handhelds.org> |
6 | Architecture: arm | 6 | Architecture: arm |
7 | Depends: opie-networksettings | 7 | Depends: opie-networksettings, libopie2net (1.8.1) |
8 | Description: Network settings wavelan plugin. | 8 | Description: Network settings wavelan plugin. |
9 | 9 | ||
10 | Version: $QPE_VERSION$EXTRAVERSION | 10 | Version: $QPE_VERSION$EXTRAVERSION |
diff --git a/noncore/settings/networksettings/wlan/wlan.pro b/noncore/settings/networksettings/wlan/wlan.pro index 552c669..82a5b2f 100644 --- a/noncore/settings/networksettings/wlan/wlan.pro +++ b/noncore/settings/networksettings/wlan/wlan.pro | |||
@@ -1,28 +1,28 @@ | |||
1 | # | 1 | # |
2 | TEMPLATE = lib | 2 | TEMPLATE = lib |
3 | #TEMPLATE = app | 3 | #TEMPLATE = app |
4 | CONFIG += qt warn_on release | 4 | CONFIG += qt warn_on release |
5 | #CONFIG += qt warn_on debug | 5 | #CONFIG += qt warn_on debug |
6 | DESTDIR = $(OPIEDIR)/plugins/networksettings | 6 | DESTDIR = $(OPIEDIR)/plugins/networksettings |
7 | HEADERS = infoimp.h wlanmodule.h wextensions.h keyedit.h | 7 | HEADERS = infoimp.h wlanmodule.h wextensions.h keyedit.h |
8 | SOURCES = infoimp.cpp wlanmodule.cpp wextensions.cpp keyedit.cpp | 8 | SOURCES = infoimp.cpp wlanmodule.cpp wextensions.cpp keyedit.cpp |
9 | INCLUDEPATH+= $(OPIEDIR)/include ../ ../interfaces/ | 9 | INCLUDEPATH+= $(OPIEDIR)/include ../ ../interfaces/ |
10 | DEPENDPATH+= $(OPIEDIR)/include | 10 | DEPENDPATH+= $(OPIEDIR)/include |
11 | LIBS += -lqpe -L../interfaces/ -linterfaces | 11 | LIBS += -lqpe -L../interfaces/ -linterfaces -lopienet2 |
12 | INTERFACES= wlan.ui info.ui | 12 | INTERFACES= wlan.ui info.ui |
13 | TARGET = wlan | 13 | TARGET = wlan |
14 | VERSION = 1.0.0 | 14 | VERSION = 1.0.0 |
15 | 15 | ||
16 | #CONFIG += wirelessopts | 16 | #CONFIG += wirelessopts |
17 | 17 | ||
18 | wirelessopts { | 18 | wirelessopts { |
19 | HEADERS+= wlanimp.h | 19 | HEADERS+= wlanimp.h |
20 | SOURCES+= wlanimp.cpp | 20 | SOURCES+= wlanimp.cpp |
21 | } | 21 | } |
22 | 22 | ||
23 | ! wirelessopts { | 23 | ! wirelessopts { |
24 | HEADERS+= wlanimp2.h | 24 | HEADERS+= wlanimp2.h |
25 | SOURCES += wlanimp2.cpp | 25 | SOURCES += wlanimp2.cpp |
26 | } | 26 | } |
27 | 27 | ||
28 | include ( $(OPIEDIR)/include.pro ) | 28 | include ( $(OPIEDIR)/include.pro ) |
diff --git a/noncore/settings/networksettings/wlan/wlan.ui b/noncore/settings/networksettings/wlan/wlan.ui index 7e39e23..195ead9 100644 --- a/noncore/settings/networksettings/wlan/wlan.ui +++ b/noncore/settings/networksettings/wlan/wlan.ui | |||
@@ -1,724 +1,742 @@ | |||
1 | <!DOCTYPE UI><UI> | 1 | <!DOCTYPE UI><UI> |
2 | <class>WLAN</class> | 2 | <class>WLAN</class> |
3 | <widget> | 3 | <widget> |
4 | <class>QDialog</class> | 4 | <class>QDialog</class> |
5 | <property stdset="1"> | 5 | <property stdset="1"> |
6 | <name>name</name> | 6 | <name>name</name> |
7 | <cstring>WLAN</cstring> | 7 | <cstring>WLAN</cstring> |
8 | </property> | 8 | </property> |
9 | <property stdset="1"> | 9 | <property stdset="1"> |
10 | <name>geometry</name> | 10 | <name>geometry</name> |
11 | <rect> | 11 | <rect> |
12 | <x>0</x> | 12 | <x>0</x> |
13 | <y>0</y> | 13 | <y>0</y> |
14 | <width>247</width> | 14 | <width>216</width> |
15 | <height>299</height> | 15 | <height>342</height> |
16 | </rect> | 16 | </rect> |
17 | </property> | 17 | </property> |
18 | <property stdset="1"> | 18 | <property stdset="1"> |
19 | <name>caption</name> | 19 | <name>caption</name> |
20 | <string>Wireless Configuration</string> | 20 | <string>Wireless Configuration</string> |
21 | </property> | 21 | </property> |
22 | <property stdset="1"> | 22 | <property stdset="1"> |
23 | <name>sizeGripEnabled</name> | 23 | <name>sizeGripEnabled</name> |
24 | <bool>true</bool> | 24 | <bool>true</bool> |
25 | </property> | 25 | </property> |
26 | <property> | 26 | <property> |
27 | <name>layoutMargin</name> | 27 | <name>layoutMargin</name> |
28 | </property> | 28 | </property> |
29 | <vbox> | 29 | <vbox> |
30 | <property stdset="1"> | 30 | <property stdset="1"> |
31 | <name>margin</name> | 31 | <name>margin</name> |
32 | <number>0</number> | 32 | <number>0</number> |
33 | </property> | 33 | </property> |
34 | <property stdset="1"> | 34 | <property stdset="1"> |
35 | <name>spacing</name> | 35 | <name>spacing</name> |
36 | <number>6</number> | 36 | <number>6</number> |
37 | </property> | 37 | </property> |
38 | <widget> | 38 | <widget> |
39 | <class>QTabWidget</class> | 39 | <class>QTabWidget</class> |
40 | <property stdset="1"> | 40 | <property stdset="1"> |
41 | <name>name</name> | 41 | <name>name</name> |
42 | <cstring>tabWidget</cstring> | 42 | <cstring>tabWidget</cstring> |
43 | </property> | 43 | </property> |
44 | <property stdset="1"> | 44 | <property stdset="1"> |
45 | <name>enabled</name> | 45 | <name>enabled</name> |
46 | <bool>true</bool> | 46 | <bool>true</bool> |
47 | </property> | 47 | </property> |
48 | <property> | ||
49 | <name>layoutMargin</name> | ||
50 | </property> | ||
51 | <property> | ||
52 | <name>layoutSpacing</name> | ||
53 | </property> | ||
48 | <widget> | 54 | <widget> |
49 | <class>QWidget</class> | 55 | <class>QWidget</class> |
50 | <property stdset="1"> | 56 | <property stdset="1"> |
51 | <name>name</name> | 57 | <name>name</name> |
52 | <cstring>ConfigPage</cstring> | 58 | <cstring>ConfigPage</cstring> |
53 | </property> | 59 | </property> |
54 | <attribute> | 60 | <attribute> |
55 | <name>title</name> | 61 | <name>title</name> |
56 | <string>General</string> | 62 | <string>General</string> |
57 | </attribute> | 63 | </attribute> |
58 | <spacer> | 64 | <vbox> |
59 | <property> | ||
60 | <name>name</name> | ||
61 | <cstring>Spacer31</cstring> | ||
62 | </property> | ||
63 | <property stdset="1"> | ||
64 | <name>orientation</name> | ||
65 | <enum>Vertical</enum> | ||
66 | </property> | ||
67 | <property stdset="1"> | ||
68 | <name>sizeType</name> | ||
69 | <enum>Expanding</enum> | ||
70 | </property> | ||
71 | <property> | ||
72 | <name>sizeHint</name> | ||
73 | <size> | ||
74 | <width>20</width> | ||
75 | <height>20</height> | ||
76 | </size> | ||
77 | </property> | ||
78 | </spacer> | ||
79 | <widget> | ||
80 | <class>QLabel</class> | ||
81 | <property stdset="1"> | ||
82 | <name>name</name> | ||
83 | <cstring>modeLabel</cstring> | ||
84 | </property> | ||
85 | <property stdset="1"> | ||
86 | <name>enabled</name> | ||
87 | <bool>true</bool> | ||
88 | </property> | ||
89 | <property stdset="1"> | ||
90 | <name>geometry</name> | ||
91 | <rect> | ||
92 | <x>11</x> | ||
93 | <y>11</y> | ||
94 | <width>84</width> | ||
95 | <height>29</height> | ||
96 | </rect> | ||
97 | </property> | ||
98 | <property stdset="1"> | ||
99 | <name>sizePolicy</name> | ||
100 | <sizepolicy> | ||
101 | <hsizetype>1</hsizetype> | ||
102 | <vsizetype>1</vsizetype> | ||
103 | </sizepolicy> | ||
104 | </property> | ||
105 | <property stdset="1"> | ||
106 | <name>text</name> | ||
107 | <string>Mode</string> | ||
108 | </property> | ||
109 | </widget> | ||
110 | <widget> | ||
111 | <class>QLabel</class> | ||
112 | <property stdset="1"> | ||
113 | <name>name</name> | ||
114 | <cstring>essidLabel</cstring> | ||
115 | </property> | ||
116 | <property stdset="1"> | ||
117 | <name>enabled</name> | ||
118 | <bool>true</bool> | ||
119 | </property> | ||
120 | <property stdset="1"> | ||
121 | <name>geometry</name> | ||
122 | <rect> | ||
123 | <x>11</x> | ||
124 | <y>46</y> | ||
125 | <width>84</width> | ||
126 | <height>29</height> | ||
127 | </rect> | ||
128 | </property> | ||
129 | <property stdset="1"> | ||
130 | <name>sizePolicy</name> | ||
131 | <sizepolicy> | ||
132 | <hsizetype>1</hsizetype> | ||
133 | <vsizetype>1</vsizetype> | ||
134 | </sizepolicy> | ||
135 | </property> | ||
136 | <property stdset="1"> | ||
137 | <name>text</name> | ||
138 | <string>ESS-ID</string> | ||
139 | </property> | ||
140 | </widget> | ||
141 | <widget> | ||
142 | <class>QSpinBox</class> | ||
143 | <property stdset="1"> | ||
144 | <name>name</name> | ||
145 | <cstring>networkChannel</cstring> | ||
146 | </property> | ||
147 | <property stdset="1"> | ||
148 | <name>enabled</name> | ||
149 | <bool>false</bool> | ||
150 | </property> | ||
151 | <property stdset="1"> | ||
152 | <name>geometry</name> | ||
153 | <rect> | ||
154 | <x>146</x> | ||
155 | <y>139</y> | ||
156 | <width>58</width> | ||
157 | <height>25</height> | ||
158 | </rect> | ||
159 | </property> | ||
160 | <property stdset="1"> | ||
161 | <name>maxValue</name> | ||
162 | <number>15</number> | ||
163 | </property> | ||
164 | <property stdset="1"> | ||
165 | <name>minValue</name> | ||
166 | <number>1</number> | ||
167 | </property> | ||
168 | <property stdset="1"> | ||
169 | <name>value</name> | ||
170 | <number>1</number> | ||
171 | </property> | ||
172 | </widget> | ||
173 | <widget> | ||
174 | <class>QLineEdit</class> | ||
175 | <property stdset="1"> | ||
176 | <name>name</name> | ||
177 | <cstring>macEdit</cstring> | ||
178 | </property> | ||
179 | <property stdset="1"> | ||
180 | <name>enabled</name> | ||
181 | <bool>false</bool> | ||
182 | </property> | ||
183 | <property stdset="1"> | ||
184 | <name>geometry</name> | ||
185 | <rect> | ||
186 | <x>56</x> | ||
187 | <y>108</y> | ||
188 | <width>182</width> | ||
189 | <height>25</height> | ||
190 | </rect> | ||
191 | </property> | ||
192 | <property stdset="1"> | ||
193 | <name>sizePolicy</name> | ||
194 | <sizepolicy> | ||
195 | <hsizetype>5</hsizetype> | ||
196 | <vsizetype>1</vsizetype> | ||
197 | </sizepolicy> | ||
198 | </property> | ||
199 | </widget> | ||
200 | <widget> | ||
201 | <class>QLabel</class> | ||
202 | <property stdset="1"> | ||
203 | <name>name</name> | ||
204 | <cstring>macLabel</cstring> | ||
205 | </property> | ||
206 | <property stdset="1"> | ||
207 | <name>enabled</name> | ||
208 | <bool>false</bool> | ||
209 | </property> | ||
210 | <property stdset="1"> | ||
211 | <name>geometry</name> | ||
212 | <rect> | ||
213 | <x>11</x> | ||
214 | <y>108</y> | ||
215 | <width>39</width> | ||
216 | <height>25</height> | ||
217 | </rect> | ||
218 | </property> | ||
219 | <property stdset="1"> | ||
220 | <name>text</name> | ||
221 | <string>MAC</string> | ||
222 | </property> | ||
223 | </widget> | ||
224 | <widget> | ||
225 | <class>QCheckBox</class> | ||
226 | <property stdset="1"> | ||
227 | <name>name</name> | ||
228 | <cstring>specifyAp</cstring> | ||
229 | </property> | ||
230 | <property stdset="1"> | ||
231 | <name>geometry</name> | ||
232 | <rect> | ||
233 | <x>11</x> | ||
234 | <y>81</y> | ||
235 | <width>227</width> | ||
236 | <height>21</height> | ||
237 | </rect> | ||
238 | </property> | ||
239 | <property stdset="1"> | ||
240 | <name>text</name> | ||
241 | <string>Specify &Access Point</string> | ||
242 | </property> | ||
243 | </widget> | ||
244 | <widget> | ||
245 | <class>QCheckBox</class> | ||
246 | <property stdset="1"> | ||
247 | <name>name</name> | ||
248 | <cstring>specifyChan</cstring> | ||
249 | </property> | ||
250 | <property stdset="1"> | ||
251 | <name>geometry</name> | ||
252 | <rect> | ||
253 | <x>11</x> | ||
254 | <y>141</y> | ||
255 | <width>129</width> | ||
256 | <height>21</height> | ||
257 | </rect> | ||
258 | </property> | ||
259 | <property stdset="1"> | ||
260 | <name>text</name> | ||
261 | <string>Specify &Channel</string> | ||
262 | </property> | ||
263 | </widget> | ||
264 | <spacer> | ||
265 | <property> | ||
266 | <name>name</name> | ||
267 | <cstring>Spacer10</cstring> | ||
268 | </property> | ||
269 | <property stdset="1"> | 65 | <property stdset="1"> |
270 | <name>orientation</name> | 66 | <name>margin</name> |
271 | <enum>Horizontal</enum> | 67 | <number>3</number> |
272 | </property> | 68 | </property> |
273 | <property stdset="1"> | 69 | <property stdset="1"> |
274 | <name>sizeType</name> | 70 | <name>spacing</name> |
275 | <enum>Expanding</enum> | 71 | <number>2</number> |
276 | </property> | ||
277 | <property> | ||
278 | <name>sizeHint</name> | ||
279 | <size> | ||
280 | <width>20</width> | ||
281 | <height>20</height> | ||
282 | </size> | ||
283 | </property> | 72 | </property> |
284 | </spacer> | 73 | <widget> |
285 | <widget> | 74 | <class>QLayoutWidget</class> |
286 | <class>QComboBox</class> | 75 | <property stdset="1"> |
287 | <item> | 76 | <name>name</name> |
288 | <property> | 77 | <cstring>Layout1</cstring> |
289 | <name>text</name> | ||
290 | <string>any</string> | ||
291 | </property> | 78 | </property> |
292 | </item> | 79 | <grid> |
293 | <property stdset="1"> | 80 | <property stdset="1"> |
294 | <name>name</name> | 81 | <name>margin</name> |
295 | <cstring>essid</cstring> | 82 | <number>0</number> |
296 | </property> | 83 | </property> |
297 | <property stdset="1"> | 84 | <property stdset="1"> |
298 | <name>geometry</name> | 85 | <name>spacing</name> |
299 | <rect> | 86 | <number>6</number> |
300 | <x>101</x> | 87 | </property> |
301 | <y>46</y> | 88 | <widget row="1" column="1" > |
302 | <width>103</width> | 89 | <class>QComboBox</class> |
303 | <height>29</height> | 90 | <item> |
304 | </rect> | 91 | <property> |
305 | </property> | 92 | <name>text</name> |
306 | <property stdset="1"> | 93 | <string>any</string> |
307 | <name>sizePolicy</name> | 94 | </property> |
308 | <sizepolicy> | 95 | </item> |
309 | <hsizetype>7</hsizetype> | 96 | <property stdset="1"> |
310 | <vsizetype>0</vsizetype> | 97 | <name>name</name> |
311 | </sizepolicy> | 98 | <cstring>essid</cstring> |
312 | </property> | 99 | </property> |
313 | <property stdset="1"> | 100 | <property stdset="1"> |
314 | <name>editable</name> | 101 | <name>sizePolicy</name> |
315 | <bool>true</bool> | 102 | <sizepolicy> |
316 | </property> | 103 | <hsizetype>7</hsizetype> |
317 | <property stdset="1"> | 104 | <vsizetype>0</vsizetype> |
318 | <name>currentItem</name> | 105 | </sizepolicy> |
319 | <number>0</number> | 106 | </property> |
320 | </property> | 107 | <property stdset="1"> |
321 | <property stdset="1"> | 108 | <name>editable</name> |
322 | <name>sizeLimit</name> | 109 | <bool>true</bool> |
323 | <number>5</number> | 110 | </property> |
324 | </property> | 111 | <property stdset="1"> |
325 | <property stdset="1"> | 112 | <name>currentItem</name> |
326 | <name>autoCompletion</name> | 113 | <number>0</number> |
327 | <bool>true</bool> | 114 | </property> |
328 | </property> | 115 | <property stdset="1"> |
329 | <property stdset="1"> | 116 | <name>sizeLimit</name> |
330 | <name>duplicatesEnabled</name> | 117 | <number>5</number> |
331 | <bool>false</bool> | 118 | </property> |
332 | </property> | 119 | <property stdset="1"> |
333 | </widget> | 120 | <name>autoCompletion</name> |
334 | <widget> | 121 | <bool>true</bool> |
335 | <class>QComboBox</class> | 122 | </property> |
336 | <item> | 123 | <property stdset="1"> |
337 | <property> | 124 | <name>duplicatesEnabled</name> |
338 | <name>text</name> | 125 | <bool>false</bool> |
339 | <string>Infrastructure</string> | 126 | </property> |
127 | </widget> | ||
128 | <widget row="1" column="0" > | ||
129 | <class>QLabel</class> | ||
130 | <property stdset="1"> | ||
131 | <name>name</name> | ||
132 | <cstring>essidLabel</cstring> | ||
133 | </property> | ||
134 | <property stdset="1"> | ||
135 | <name>enabled</name> | ||
136 | <bool>true</bool> | ||
137 | </property> | ||
138 | <property stdset="1"> | ||
139 | <name>sizePolicy</name> | ||
140 | <sizepolicy> | ||
141 | <hsizetype>1</hsizetype> | ||
142 | <vsizetype>1</vsizetype> | ||
143 | </sizepolicy> | ||
144 | </property> | ||
145 | <property stdset="1"> | ||
146 | <name>text</name> | ||
147 | <string>SSID</string> | ||
148 | </property> | ||
149 | </widget> | ||
150 | <widget row="0" column="1" > | ||
151 | <class>QComboBox</class> | ||
152 | <item> | ||
153 | <property> | ||
154 | <name>text</name> | ||
155 | <string>Infrastructure</string> | ||
156 | </property> | ||
157 | </item> | ||
158 | <item> | ||
159 | <property> | ||
160 | <name>text</name> | ||
161 | <string>Auto</string> | ||
162 | </property> | ||
163 | </item> | ||
164 | <item> | ||
165 | <property> | ||
166 | <name>text</name> | ||
167 | <string>Managed</string> | ||
168 | </property> | ||
169 | </item> | ||
170 | <item> | ||
171 | <property> | ||
172 | <name>text</name> | ||
173 | <string>Ad-Hoc</string> | ||
174 | </property> | ||
175 | </item> | ||
176 | <property stdset="1"> | ||
177 | <name>name</name> | ||
178 | <cstring>mode</cstring> | ||
179 | </property> | ||
180 | <property stdset="1"> | ||
181 | <name>enabled</name> | ||
182 | <bool>true</bool> | ||
183 | </property> | ||
184 | <property stdset="1"> | ||
185 | <name>sizePolicy</name> | ||
186 | <sizepolicy> | ||
187 | <hsizetype>7</hsizetype> | ||
188 | <vsizetype>0</vsizetype> | ||
189 | </sizepolicy> | ||
190 | </property> | ||
191 | </widget> | ||
192 | <widget row="0" column="0" > | ||
193 | <class>QLabel</class> | ||
194 | <property stdset="1"> | ||
195 | <name>name</name> | ||
196 | <cstring>modeLabel</cstring> | ||
197 | </property> | ||
198 | <property stdset="1"> | ||
199 | <name>enabled</name> | ||
200 | <bool>true</bool> | ||
201 | </property> | ||
202 | <property stdset="1"> | ||
203 | <name>sizePolicy</name> | ||
204 | <sizepolicy> | ||
205 | <hsizetype>1</hsizetype> | ||
206 | <vsizetype>1</vsizetype> | ||
207 | </sizepolicy> | ||
208 | </property> | ||
209 | <property stdset="1"> | ||
210 | <name>text</name> | ||
211 | <string>Mode</string> | ||
212 | </property> | ||
213 | </widget> | ||
214 | </grid> | ||
215 | </widget> | ||
216 | <widget> | ||
217 | <class>QCheckBox</class> | ||
218 | <property stdset="1"> | ||
219 | <name>name</name> | ||
220 | <cstring>specifyAp</cstring> | ||
340 | </property> | 221 | </property> |
341 | </item> | 222 | <property stdset="1"> |
342 | <item> | ||
343 | <property> | ||
344 | <name>text</name> | 223 | <name>text</name> |
345 | <string>Auto</string> | 224 | <string>Specify &Access Point</string> |
346 | </property> | 225 | </property> |
347 | </item> | 226 | </widget> |
348 | <item> | 227 | <widget> |
349 | <property> | 228 | <class>QLayoutWidget</class> |
350 | <name>text</name> | 229 | <property stdset="1"> |
351 | <string>Managed</string> | 230 | <name>name</name> |
231 | <cstring>Layout3</cstring> | ||
352 | </property> | 232 | </property> |
353 | </item> | 233 | <hbox> |
354 | <item> | 234 | <property stdset="1"> |
355 | <property> | 235 | <name>margin</name> |
236 | <number>0</number> | ||
237 | </property> | ||
238 | <property stdset="1"> | ||
239 | <name>spacing</name> | ||
240 | <number>6</number> | ||
241 | </property> | ||
242 | <widget> | ||
243 | <class>QLabel</class> | ||
244 | <property stdset="1"> | ||
245 | <name>name</name> | ||
246 | <cstring>macLabel</cstring> | ||
247 | </property> | ||
248 | <property stdset="1"> | ||
249 | <name>enabled</name> | ||
250 | <bool>false</bool> | ||
251 | </property> | ||
252 | <property stdset="1"> | ||
253 | <name>text</name> | ||
254 | <string>MAC</string> | ||
255 | </property> | ||
256 | </widget> | ||
257 | <widget> | ||
258 | <class>QLineEdit</class> | ||
259 | <property stdset="1"> | ||
260 | <name>name</name> | ||
261 | <cstring>macEdit</cstring> | ||
262 | </property> | ||
263 | <property stdset="1"> | ||
264 | <name>enabled</name> | ||
265 | <bool>false</bool> | ||
266 | </property> | ||
267 | <property stdset="1"> | ||
268 | <name>sizePolicy</name> | ||
269 | <sizepolicy> | ||
270 | <hsizetype>7</hsizetype> | ||
271 | <vsizetype>1</vsizetype> | ||
272 | </sizepolicy> | ||
273 | </property> | ||
274 | </widget> | ||
275 | </hbox> | ||
276 | </widget> | ||
277 | <widget> | ||
278 | <class>QLayoutWidget</class> | ||
279 | <property stdset="1"> | ||
280 | <name>name</name> | ||
281 | <cstring>Layout4</cstring> | ||
282 | </property> | ||
283 | <hbox> | ||
284 | <property stdset="1"> | ||
285 | <name>margin</name> | ||
286 | <number>0</number> | ||
287 | </property> | ||
288 | <property stdset="1"> | ||
289 | <name>spacing</name> | ||
290 | <number>6</number> | ||
291 | </property> | ||
292 | <widget> | ||
293 | <class>QCheckBox</class> | ||
294 | <property stdset="1"> | ||
295 | <name>name</name> | ||
296 | <cstring>specifyChan</cstring> | ||
297 | </property> | ||
298 | <property stdset="1"> | ||
299 | <name>text</name> | ||
300 | <string>Specify &Channel</string> | ||
301 | </property> | ||
302 | </widget> | ||
303 | <widget> | ||
304 | <class>QSpinBox</class> | ||
305 | <property stdset="1"> | ||
306 | <name>name</name> | ||
307 | <cstring>networkChannel</cstring> | ||
308 | </property> | ||
309 | <property stdset="1"> | ||
310 | <name>enabled</name> | ||
311 | <bool>false</bool> | ||
312 | </property> | ||
313 | <property stdset="1"> | ||
314 | <name>maxValue</name> | ||
315 | <number>15</number> | ||
316 | </property> | ||
317 | <property stdset="1"> | ||
318 | <name>minValue</name> | ||
319 | <number>1</number> | ||
320 | </property> | ||
321 | <property stdset="1"> | ||
322 | <name>value</name> | ||
323 | <number>1</number> | ||
324 | </property> | ||
325 | </widget> | ||
326 | </hbox> | ||
327 | </widget> | ||
328 | <widget> | ||
329 | <class>QPushButton</class> | ||
330 | <property stdset="1"> | ||
331 | <name>name</name> | ||
332 | <cstring>rescanButton</cstring> | ||
333 | </property> | ||
334 | <property stdset="1"> | ||
356 | <name>text</name> | 335 | <name>text</name> |
357 | <string>Ad-Hoc</string> | 336 | <string>Rescan Neighbourhood</string> |
358 | </property> | 337 | </property> |
359 | </item> | 338 | </widget> |
360 | <property stdset="1"> | 339 | <widget> |
361 | <name>name</name> | 340 | <class>QListView</class> |
362 | <cstring>mode</cstring> | 341 | <column> |
363 | </property> | 342 | <property> |
364 | <property stdset="1"> | 343 | <name>text</name> |
365 | <name>enabled</name> | 344 | <string></string> |
366 | <bool>true</bool> | 345 | </property> |
367 | </property> | 346 | <property> |
368 | <property stdset="1"> | 347 | <name>clickable</name> |
369 | <name>geometry</name> | 348 | <bool>true</bool> |
370 | <rect> | 349 | </property> |
371 | <x>101</x> | 350 | <property> |
372 | <y>11</y> | 351 | <name>resizeable</name> |
373 | <width>103</width> | 352 | <bool>true</bool> |
374 | <height>29</height> | 353 | </property> |
375 | </rect> | 354 | </column> |
376 | </property> | 355 | <column> |
377 | <property stdset="1"> | 356 | <property> |
378 | <name>sizePolicy</name> | 357 | <name>text</name> |
379 | <sizepolicy> | 358 | <string>SSID</string> |
380 | <hsizetype>1</hsizetype> | 359 | </property> |
381 | <vsizetype>0</vsizetype> | 360 | <property> |
382 | </sizepolicy> | 361 | <name>clickable</name> |
383 | </property> | 362 | <bool>true</bool> |
384 | </widget> | 363 | </property> |
364 | <property> | ||
365 | <name>resizeable</name> | ||
366 | <bool>true</bool> | ||
367 | </property> | ||
368 | </column> | ||
369 | <column> | ||
370 | <property> | ||
371 | <name>text</name> | ||
372 | <string>Chn</string> | ||
373 | </property> | ||
374 | <property> | ||
375 | <name>clickable</name> | ||
376 | <bool>true</bool> | ||
377 | </property> | ||
378 | <property> | ||
379 | <name>resizeable</name> | ||
380 | <bool>true</bool> | ||
381 | </property> | ||
382 | </column> | ||
383 | <column> | ||
384 | <property> | ||
385 | <name>text</name> | ||
386 | <string>MAC</string> | ||
387 | </property> | ||
388 | <property> | ||
389 | <name>clickable</name> | ||
390 | <bool>true</bool> | ||
391 | </property> | ||
392 | <property> | ||
393 | <name>resizeable</name> | ||
394 | <bool>true</bool> | ||
395 | </property> | ||
396 | </column> | ||
397 | <property stdset="1"> | ||
398 | <name>name</name> | ||
399 | <cstring>netView</cstring> | ||
400 | </property> | ||
401 | </widget> | ||
402 | </vbox> | ||
385 | </widget> | 403 | </widget> |
386 | <widget> | 404 | <widget> |
387 | <class>QWidget</class> | 405 | <class>QWidget</class> |
388 | <property stdset="1"> | 406 | <property stdset="1"> |
389 | <name>name</name> | 407 | <name>name</name> |
390 | <cstring>WepPage</cstring> | 408 | <cstring>WepPage</cstring> |
391 | </property> | 409 | </property> |
392 | <attribute> | 410 | <attribute> |
393 | <name>title</name> | 411 | <name>title</name> |
394 | <string>Encryption</string> | 412 | <string>Encryption</string> |
395 | </attribute> | 413 | </attribute> |
396 | <grid> | 414 | <grid> |
397 | <property stdset="1"> | 415 | <property stdset="1"> |
398 | <name>margin</name> | 416 | <name>margin</name> |
399 | <number>11</number> | 417 | <number>7</number> |
400 | </property> | 418 | </property> |
401 | <property stdset="1"> | 419 | <property stdset="1"> |
402 | <name>spacing</name> | 420 | <name>spacing</name> |
403 | <number>6</number> | 421 | <number>3</number> |
404 | </property> | 422 | </property> |
405 | <widget row="0" column="0" > | 423 | <widget row="0" column="0" > |
406 | <class>QCheckBox</class> | 424 | <class>QCheckBox</class> |
407 | <property stdset="1"> | 425 | <property stdset="1"> |
408 | <name>name</name> | 426 | <name>name</name> |
409 | <cstring>wepEnabled</cstring> | 427 | <cstring>wepEnabled</cstring> |
410 | </property> | 428 | </property> |
411 | <property stdset="1"> | 429 | <property stdset="1"> |
412 | <name>text</name> | 430 | <name>text</name> |
413 | <string>&Enable Encryption</string> | 431 | <string>&Enable Encryption</string> |
414 | </property> | 432 | </property> |
415 | </widget> | 433 | </widget> |
416 | <widget row="1" column="0" > | 434 | <widget row="1" column="0" > |
417 | <class>QButtonGroup</class> | 435 | <class>QButtonGroup</class> |
418 | <property stdset="1"> | 436 | <property stdset="1"> |
419 | <name>name</name> | 437 | <name>name</name> |
420 | <cstring>KeyButtonGroup</cstring> | 438 | <cstring>KeyButtonGroup</cstring> |
421 | </property> | 439 | </property> |
422 | <property stdset="1"> | 440 | <property stdset="1"> |
423 | <name>enabled</name> | 441 | <name>enabled</name> |
424 | <bool>false</bool> | 442 | <bool>false</bool> |
425 | </property> | 443 | </property> |
426 | <property stdset="1"> | 444 | <property stdset="1"> |
427 | <name>title</name> | 445 | <name>title</name> |
428 | <string>&Key Setting</string> | 446 | <string>&Key Setting</string> |
429 | </property> | 447 | </property> |
430 | <grid> | 448 | <grid> |
431 | <property stdset="1"> | 449 | <property stdset="1"> |
432 | <name>margin</name> | 450 | <name>margin</name> |
433 | <number>11</number> | 451 | <number>11</number> |
434 | </property> | 452 | </property> |
435 | <property stdset="1"> | 453 | <property stdset="1"> |
436 | <name>spacing</name> | 454 | <name>spacing</name> |
437 | <number>6</number> | 455 | <number>6</number> |
438 | </property> | 456 | </property> |
439 | <widget row="0" column="0" > | 457 | <widget row="0" column="0" > |
440 | <class>QRadioButton</class> | 458 | <class>QRadioButton</class> |
441 | <property stdset="1"> | 459 | <property stdset="1"> |
442 | <name>name</name> | 460 | <name>name</name> |
443 | <cstring>keyRadio0</cstring> | 461 | <cstring>keyRadio0</cstring> |
444 | </property> | 462 | </property> |
445 | <property stdset="1"> | 463 | <property stdset="1"> |
446 | <name>text</name> | 464 | <name>text</name> |
447 | <string>Key &1</string> | 465 | <string>Key &1</string> |
448 | </property> | 466 | </property> |
449 | <property stdset="1"> | 467 | <property stdset="1"> |
450 | <name>checked</name> | 468 | <name>checked</name> |
451 | <bool>true</bool> | 469 | <bool>true</bool> |
452 | </property> | 470 | </property> |
453 | </widget> | 471 | </widget> |
454 | <widget row="1" column="0" > | 472 | <widget row="1" column="0" > |
455 | <class>QRadioButton</class> | 473 | <class>QRadioButton</class> |
456 | <property stdset="1"> | 474 | <property stdset="1"> |
457 | <name>name</name> | 475 | <name>name</name> |
458 | <cstring>keyRadio1</cstring> | 476 | <cstring>keyRadio1</cstring> |
459 | </property> | 477 | </property> |
460 | <property stdset="1"> | 478 | <property stdset="1"> |
461 | <name>text</name> | 479 | <name>text</name> |
462 | <string>Key &2</string> | 480 | <string>Key &2</string> |
463 | </property> | 481 | </property> |
464 | </widget> | 482 | </widget> |
465 | <widget row="2" column="0" > | 483 | <widget row="2" column="0" > |
466 | <class>QRadioButton</class> | 484 | <class>QRadioButton</class> |
467 | <property stdset="1"> | 485 | <property stdset="1"> |
468 | <name>name</name> | 486 | <name>name</name> |
469 | <cstring>keyRadio2</cstring> | 487 | <cstring>keyRadio2</cstring> |
470 | </property> | 488 | </property> |
471 | <property stdset="1"> | 489 | <property stdset="1"> |
472 | <name>text</name> | 490 | <name>text</name> |
473 | <string>Key &3</string> | 491 | <string>Key &3</string> |
474 | </property> | 492 | </property> |
475 | </widget> | 493 | </widget> |
476 | <widget row="3" column="0" > | 494 | <widget row="3" column="0" > |
477 | <class>QRadioButton</class> | 495 | <class>QRadioButton</class> |
478 | <property stdset="1"> | 496 | <property stdset="1"> |
479 | <name>name</name> | 497 | <name>name</name> |
480 | <cstring>keyRadio3</cstring> | 498 | <cstring>keyRadio3</cstring> |
481 | </property> | 499 | </property> |
482 | <property stdset="1"> | 500 | <property stdset="1"> |
483 | <name>text</name> | 501 | <name>text</name> |
484 | <string>Key &4</string> | 502 | <string>Key &4</string> |
485 | </property> | 503 | </property> |
486 | </widget> | 504 | </widget> |
487 | <widget row="0" column="1" > | 505 | <widget row="0" column="1" > |
488 | <class>KeyEdit</class> | 506 | <class>KeyEdit</class> |
489 | <property stdset="1"> | 507 | <property stdset="1"> |
490 | <name>name</name> | 508 | <name>name</name> |
491 | <cstring>keyLineEdit0</cstring> | 509 | <cstring>keyLineEdit0</cstring> |
492 | </property> | 510 | </property> |
493 | <property stdset="1"> | 511 | <property stdset="1"> |
494 | <name>sizePolicy</name> | 512 | <name>sizePolicy</name> |
495 | <sizepolicy> | 513 | <sizepolicy> |
496 | <hsizetype>3</hsizetype> | 514 | <hsizetype>3</hsizetype> |
497 | <vsizetype>5</vsizetype> | 515 | <vsizetype>5</vsizetype> |
498 | </sizepolicy> | 516 | </sizepolicy> |
499 | </property> | 517 | </property> |
500 | <property stdset="1"> | 518 | <property stdset="1"> |
501 | <name>focusPolicy</name> | 519 | <name>focusPolicy</name> |
502 | <enum>StrongFocus</enum> | 520 | <enum>StrongFocus</enum> |
503 | </property> | 521 | </property> |
504 | </widget> | 522 | </widget> |
505 | <widget row="1" column="1" > | 523 | <widget row="1" column="1" > |
506 | <class>KeyEdit</class> | 524 | <class>KeyEdit</class> |
507 | <property stdset="1"> | 525 | <property stdset="1"> |
508 | <name>name</name> | 526 | <name>name</name> |
509 | <cstring>keyLineEdit1</cstring> | 527 | <cstring>keyLineEdit1</cstring> |
510 | </property> | 528 | </property> |
511 | <property stdset="1"> | 529 | <property stdset="1"> |
512 | <name>sizePolicy</name> | 530 | <name>sizePolicy</name> |
513 | <sizepolicy> | 531 | <sizepolicy> |
514 | <hsizetype>3</hsizetype> | 532 | <hsizetype>3</hsizetype> |
515 | <vsizetype>5</vsizetype> | 533 | <vsizetype>5</vsizetype> |
516 | </sizepolicy> | 534 | </sizepolicy> |
517 | </property> | 535 | </property> |
518 | <property stdset="1"> | 536 | <property stdset="1"> |
519 | <name>focusPolicy</name> | 537 | <name>focusPolicy</name> |
520 | <enum>StrongFocus</enum> | 538 | <enum>StrongFocus</enum> |
521 | </property> | 539 | </property> |
522 | </widget> | 540 | </widget> |
523 | <widget row="2" column="1" > | 541 | <widget row="2" column="1" > |
524 | <class>KeyEdit</class> | 542 | <class>KeyEdit</class> |
525 | <property stdset="1"> | 543 | <property stdset="1"> |
526 | <name>name</name> | 544 | <name>name</name> |
527 | <cstring>keyLineEdit2</cstring> | 545 | <cstring>keyLineEdit2</cstring> |
528 | </property> | 546 | </property> |
529 | <property stdset="1"> | 547 | <property stdset="1"> |
530 | <name>sizePolicy</name> | 548 | <name>sizePolicy</name> |
531 | <sizepolicy> | 549 | <sizepolicy> |
532 | <hsizetype>3</hsizetype> | 550 | <hsizetype>3</hsizetype> |
533 | <vsizetype>5</vsizetype> | 551 | <vsizetype>5</vsizetype> |
534 | </sizepolicy> | 552 | </sizepolicy> |
535 | </property> | 553 | </property> |
536 | <property stdset="1"> | 554 | <property stdset="1"> |
537 | <name>focusPolicy</name> | 555 | <name>focusPolicy</name> |
538 | <enum>StrongFocus</enum> | 556 | <enum>StrongFocus</enum> |
539 | </property> | 557 | </property> |
540 | </widget> | 558 | </widget> |
541 | <widget row="3" column="1" > | 559 | <widget row="3" column="1" > |
542 | <class>KeyEdit</class> | 560 | <class>KeyEdit</class> |
543 | <property stdset="1"> | 561 | <property stdset="1"> |
544 | <name>name</name> | 562 | <name>name</name> |
545 | <cstring>keyLineEdit3</cstring> | 563 | <cstring>keyLineEdit3</cstring> |
546 | </property> | 564 | </property> |
547 | <property stdset="1"> | 565 | <property stdset="1"> |
548 | <name>sizePolicy</name> | 566 | <name>sizePolicy</name> |
549 | <sizepolicy> | 567 | <sizepolicy> |
550 | <hsizetype>3</hsizetype> | 568 | <hsizetype>3</hsizetype> |
551 | <vsizetype>5</vsizetype> | 569 | <vsizetype>5</vsizetype> |
552 | </sizepolicy> | 570 | </sizepolicy> |
553 | </property> | 571 | </property> |
554 | <property stdset="1"> | 572 | <property stdset="1"> |
555 | <name>focusPolicy</name> | 573 | <name>focusPolicy</name> |
556 | <enum>StrongFocus</enum> | 574 | <enum>StrongFocus</enum> |
557 | </property> | 575 | </property> |
558 | </widget> | 576 | </widget> |
559 | </grid> | 577 | </grid> |
560 | </widget> | 578 | </widget> |
561 | <widget row="2" column="0" > | 579 | <widget row="2" column="0" > |
562 | <class>QButtonGroup</class> | 580 | <class>QButtonGroup</class> |
563 | <property stdset="1"> | 581 | <property stdset="1"> |
564 | <name>name</name> | 582 | <name>name</name> |
565 | <cstring>NonEncButtonGroup</cstring> | 583 | <cstring>NonEncButtonGroup</cstring> |
566 | </property> | 584 | </property> |
567 | <property stdset="1"> | 585 | <property stdset="1"> |
568 | <name>enabled</name> | 586 | <name>enabled</name> |
569 | <bool>false</bool> | 587 | <bool>false</bool> |
570 | </property> | 588 | </property> |
571 | <property stdset="1"> | 589 | <property stdset="1"> |
572 | <name>title</name> | 590 | <name>title</name> |
573 | <string>Non-encrypted Packets</string> | 591 | <string>Non-encrypted Packets</string> |
574 | </property> | 592 | </property> |
575 | <property stdset="1"> | 593 | <property stdset="1"> |
576 | <name>radioButtonExclusive</name> | 594 | <name>radioButtonExclusive</name> |
577 | <bool>true</bool> | 595 | <bool>true</bool> |
578 | </property> | 596 | </property> |
579 | <grid> | 597 | <grid> |
580 | <property stdset="1"> | 598 | <property stdset="1"> |
581 | <name>margin</name> | 599 | <name>margin</name> |
582 | <number>11</number> | 600 | <number>11</number> |
583 | </property> | 601 | </property> |
584 | <property stdset="1"> | 602 | <property stdset="1"> |
585 | <name>spacing</name> | 603 | <name>spacing</name> |
586 | <number>6</number> | 604 | <number>6</number> |
587 | </property> | 605 | </property> |
588 | <widget row="0" column="0" > | 606 | <widget row="0" column="0" > |
589 | <class>QRadioButton</class> | 607 | <class>QRadioButton</class> |
590 | <property stdset="1"> | 608 | <property stdset="1"> |
591 | <name>name</name> | 609 | <name>name</name> |
592 | <cstring>acceptNonEnc</cstring> | 610 | <cstring>acceptNonEnc</cstring> |
593 | </property> | 611 | </property> |
594 | <property stdset="1"> | 612 | <property stdset="1"> |
595 | <name>text</name> | 613 | <name>text</name> |
596 | <string>&Accept</string> | 614 | <string>&Accept</string> |
597 | </property> | 615 | </property> |
598 | <property stdset="1"> | 616 | <property stdset="1"> |
599 | <name>checked</name> | 617 | <name>checked</name> |
600 | <bool>true</bool> | 618 | <bool>true</bool> |
601 | </property> | 619 | </property> |
602 | <property stdset="1"> | 620 | <property stdset="1"> |
603 | <name>buttonGroupId</name> | 621 | <name>buttonGroupId</name> |
604 | <number>0</number> | 622 | <number>0</number> |
605 | </property> | 623 | </property> |
606 | </widget> | 624 | </widget> |
607 | <widget row="0" column="1" > | 625 | <widget row="0" column="1" > |
608 | <class>QRadioButton</class> | 626 | <class>QRadioButton</class> |
609 | <property stdset="1"> | 627 | <property stdset="1"> |
610 | <name>name</name> | 628 | <name>name</name> |
611 | <cstring>rejectNonEnc</cstring> | 629 | <cstring>rejectNonEnc</cstring> |
612 | </property> | 630 | </property> |
613 | <property stdset="1"> | 631 | <property stdset="1"> |
614 | <name>text</name> | 632 | <name>text</name> |
615 | <string>&Reject</string> | 633 | <string>&Reject</string> |
616 | </property> | 634 | </property> |
617 | <property stdset="1"> | 635 | <property stdset="1"> |
618 | <name>buttonGroupId</name> | 636 | <name>buttonGroupId</name> |
619 | <number>1</number> | 637 | <number>1</number> |
620 | </property> | 638 | </property> |
621 | </widget> | 639 | </widget> |
622 | </grid> | 640 | </grid> |
623 | </widget> | 641 | </widget> |
624 | <spacer row="3" column="0" > | 642 | <spacer row="3" column="0" > |
625 | <property> | 643 | <property> |
626 | <name>name</name> | 644 | <name>name</name> |
627 | <cstring>Spacer30</cstring> | 645 | <cstring>Spacer30</cstring> |
628 | </property> | 646 | </property> |
629 | <property stdset="1"> | 647 | <property stdset="1"> |
630 | <name>orientation</name> | 648 | <name>orientation</name> |
631 | <enum>Vertical</enum> | 649 | <enum>Vertical</enum> |
632 | </property> | 650 | </property> |
633 | <property stdset="1"> | 651 | <property stdset="1"> |
634 | <name>sizeType</name> | 652 | <name>sizeType</name> |
635 | <enum>Expanding</enum> | 653 | <enum>Expanding</enum> |
636 | </property> | 654 | </property> |
637 | <property> | 655 | <property> |
638 | <name>sizeHint</name> | 656 | <name>sizeHint</name> |
639 | <size> | 657 | <size> |
640 | <width>20</width> | 658 | <width>20</width> |
641 | <height>20</height> | 659 | <height>20</height> |
642 | </size> | 660 | </size> |
643 | </property> | 661 | </property> |
644 | </spacer> | 662 | </spacer> |
645 | </grid> | 663 | </grid> |
646 | </widget> | 664 | </widget> |
647 | </widget> | 665 | </widget> |
648 | </vbox> | 666 | </vbox> |
649 | </widget> | 667 | </widget> |
650 | <customwidgets> | 668 | <customwidgets> |
651 | <customwidget> | 669 | <customwidget> |
652 | <class>KeyEdit</class> | 670 | <class>KeyEdit</class> |
653 | <header location="local">keyedit.h</header> | 671 | <header location="local">keyedit.h</header> |
654 | <sizehint> | 672 | <sizehint> |
655 | <width>-1</width> | 673 | <width>-1</width> |
656 | <height>-1</height> | 674 | <height>-1</height> |
657 | </sizehint> | 675 | </sizehint> |
658 | <container>0</container> | 676 | <container>0</container> |
659 | <sizepolicy> | 677 | <sizepolicy> |
660 | <hordata>5</hordata> | 678 | <hordata>5</hordata> |
661 | <verdata>5</verdata> | 679 | <verdata>5</verdata> |
662 | </sizepolicy> | 680 | </sizepolicy> |
663 | <pixmap>image0</pixmap> | 681 | <pixmap>image0</pixmap> |
664 | <slot access="public">setEnabled(bool)</slot> | 682 | <slot access="public">setEnabled(bool)</slot> |
665 | </customwidget> | 683 | </customwidget> |
666 | </customwidgets> | 684 | </customwidgets> |
667 | <images> | 685 | <images> |
668 | <image> | 686 | <image> |
669 | <name>image0</name> | 687 | <name>image0</name> |
670 | <data format="XPM.GZ" length="646">789c6dd2c10ac2300c00d07bbf2234b7229d1ddec44f503c0ae2a154410f53d0ed20e2bf6bdb656dd6861dd23d9a66591b0587fd1654235ebded6f0edcd53e419d87ae7b1f4f9b8f906d0bfe012317426a70b07bdc2f3ec77f8ed6b89559061a0343d06a124cc105596482585094bc0ae599b04646c9018926491b2205e140c485cace25755c175d0a967b622ff900b8cc9c7d29af594ea722d589167f813aa852ba07d94b9dce296e883fe7bb163f23896753</data> | 688 | <data format="XPM.GZ" length="646">789c6dd2c10ac2300c00d07bbf2234b7229d1ddec44f503c0ae2a154410f53d0ed20e2bf6bdb656dd6861dd23d9a66591b0587fd1654235ebded6f0edcd53e419d87ae7b1f4f9b8f906d0bfe012317426a70b07bdc2f3ec77f8ed6b89559061a0343d06a124cc105596482585094bc0ae599b04646c9018926491b2205e140c485cace25755c175d0a967b622ff900b8cc9c7d29af594ea722d589167f813aa852ba07d94b9dce296e883fe7bb163f23896753</data> |
671 | </image> | 689 | </image> |
672 | </images> | 690 | </images> |
673 | <connections> | 691 | <connections> |
674 | <connection> | 692 | <connection> |
675 | <sender>specifyAp</sender> | 693 | <sender>specifyAp</sender> |
676 | <signal>toggled(bool)</signal> | 694 | <signal>toggled(bool)</signal> |
677 | <receiver>macLabel</receiver> | 695 | <receiver>macLabel</receiver> |
678 | <slot>setEnabled(bool)</slot> | 696 | <slot>setEnabled(bool)</slot> |
679 | </connection> | 697 | </connection> |
680 | <connection> | 698 | <connection> |
681 | <sender>specifyAp</sender> | 699 | <sender>specifyAp</sender> |
682 | <signal>toggled(bool)</signal> | 700 | <signal>toggled(bool)</signal> |
683 | <receiver>macEdit</receiver> | 701 | <receiver>macEdit</receiver> |
684 | <slot>setEnabled(bool)</slot> | 702 | <slot>setEnabled(bool)</slot> |
685 | </connection> | 703 | </connection> |
686 | <connection> | 704 | <connection> |
687 | <sender>specifyChan</sender> | 705 | <sender>specifyChan</sender> |
688 | <signal>toggled(bool)</signal> | 706 | <signal>toggled(bool)</signal> |
689 | <receiver>networkChannel</receiver> | 707 | <receiver>networkChannel</receiver> |
690 | <slot>setEnabled(bool)</slot> | 708 | <slot>setEnabled(bool)</slot> |
691 | </connection> | 709 | </connection> |
692 | <connection> | 710 | <connection> |
693 | <sender>wepEnabled</sender> | 711 | <sender>wepEnabled</sender> |
694 | <signal>toggled(bool)</signal> | 712 | <signal>toggled(bool)</signal> |
695 | <receiver>KeyButtonGroup</receiver> | 713 | <receiver>KeyButtonGroup</receiver> |
696 | <slot>setEnabled(bool)</slot> | 714 | <slot>setEnabled(bool)</slot> |
697 | </connection> | 715 | </connection> |
698 | <connection> | 716 | <connection> |
699 | <sender>wepEnabled</sender> | 717 | <sender>wepEnabled</sender> |
700 | <signal>toggled(bool)</signal> | 718 | <signal>toggled(bool)</signal> |
701 | <receiver>NonEncButtonGroup</receiver> | 719 | <receiver>NonEncButtonGroup</receiver> |
702 | <slot>setEnabled(bool)</slot> | 720 | <slot>setEnabled(bool)</slot> |
703 | </connection> | 721 | </connection> |
704 | </connections> | 722 | </connections> |
705 | <tabstops> | 723 | <tabstops> |
706 | <tabstop>tabWidget</tabstop> | 724 | <tabstop>tabWidget</tabstop> |
707 | <tabstop>wepEnabled</tabstop> | 725 | <tabstop>wepEnabled</tabstop> |
708 | <tabstop>keyRadio0</tabstop> | 726 | <tabstop>keyRadio0</tabstop> |
709 | <tabstop>keyLineEdit0</tabstop> | 727 | <tabstop>keyLineEdit0</tabstop> |
710 | <tabstop>keyRadio1</tabstop> | 728 | <tabstop>keyRadio1</tabstop> |
711 | <tabstop>keyLineEdit1</tabstop> | 729 | <tabstop>keyLineEdit1</tabstop> |
712 | <tabstop>keyRadio2</tabstop> | 730 | <tabstop>keyRadio2</tabstop> |
713 | <tabstop>keyLineEdit2</tabstop> | 731 | <tabstop>keyLineEdit2</tabstop> |
714 | <tabstop>keyRadio3</tabstop> | 732 | <tabstop>keyRadio3</tabstop> |
715 | <tabstop>keyLineEdit3</tabstop> | 733 | <tabstop>keyLineEdit3</tabstop> |
716 | <tabstop>acceptNonEnc</tabstop> | 734 | <tabstop>acceptNonEnc</tabstop> |
717 | <tabstop>mode</tabstop> | 735 | <tabstop>mode</tabstop> |
718 | <tabstop>essid</tabstop> | 736 | <tabstop>essid</tabstop> |
719 | <tabstop>specifyAp</tabstop> | 737 | <tabstop>specifyAp</tabstop> |
720 | <tabstop>macEdit</tabstop> | 738 | <tabstop>macEdit</tabstop> |
721 | <tabstop>specifyChan</tabstop> | 739 | <tabstop>specifyChan</tabstop> |
722 | <tabstop>networkChannel</tabstop> | 740 | <tabstop>networkChannel</tabstop> |
723 | </tabstops> | 741 | </tabstops> |
724 | </UI> | 742 | </UI> |
diff --git a/noncore/settings/networksettings/wlan/wlanimp.cpp b/noncore/settings/networksettings/wlan/wlanimp.cpp index 8bf004f..719be1b 100644 --- a/noncore/settings/networksettings/wlan/wlanimp.cpp +++ b/noncore/settings/networksettings/wlan/wlanimp.cpp | |||
@@ -1,244 +1,244 @@ | |||
1 | #include "wlanimp.h" | 1 | #include "wlanimp.h" |
2 | #include "interfacesetupimp.h" | 2 | #include "interfacesetupimp.h" |
3 | 3 | ||
4 | #include <qfile.h> | 4 | #include <qfile.h> |
5 | #include <qdir.h> | 5 | #include <qdir.h> |
6 | #include <qtextstream.h> | 6 | #include <qtextstream.h> |
7 | #include <qmessagebox.h> | 7 | #include <qmessagebox.h> |
8 | #include <qlineedit.h> | 8 | #include <qlineedit.h> |
9 | #include <qlabel.h> | 9 | #include <qlabel.h> |
10 | #include <qspinbox.h> | 10 | #include <qspinbox.h> |
11 | #include <qradiobutton.h> | 11 | #include <qradiobutton.h> |
12 | #include <qcheckbox.h> | 12 | #include <qcheckbox.h> |
13 | #include <qtabwidget.h> | 13 | #include <qtabwidget.h> |
14 | #include <qcombobox.h> | 14 | #include <qcombobox.h> |
15 | 15 | ||
16 | #ifdef QWS | 16 | #ifdef QWS |
17 | #include <opie/oprocess.h> | 17 | #include <opie/oprocess.h> |
18 | #else | 18 | #else |
19 | #define OProcess KProcess | 19 | #define OProcess KProcess |
20 | #include <kprocess.h> | 20 | #include <kprocess.h> |
21 | #endif | 21 | #endif |
22 | 22 | ||
23 | #define WIRELESS_OPTS "/etc/pcmcia/wireless.opts" | 23 | #define WIRELESS_OPTS "/etc/pcmcia/wireless.opts" |
24 | 24 | ||
25 | /** | 25 | /** |
26 | * Constructor, read in the wireless.opts file for parsing later. | 26 | * Constructor, read in the wireless.opts file for parsing later. |
27 | */ | 27 | */ |
28 | WLANImp::WLANImp( QWidget* parent, const char* name, Interface *i, bool modal, WFlags fl):WLAN(parent, name, modal, fl), currentProfile("*") { | 28 | WLANImp::WLANImp( QWidget* parent, const char* name, Interface *i, bool modal, WFlags fl):WLAN(parent, name, modal, fl), currentProfile("*") { |
29 | interfaceSetup = new InterfaceSetupImp(tabWidget, "InterfaceSetupImp", i); | 29 | interfaceSetup = new InterfaceSetupImp(tabWidget, "InterfaceSetupImp", i); |
30 | tabWidget->insertTab(interfaceSetup, "TCP/IP"); | 30 | tabWidget->insertTab(interfaceSetup, "TCP/IP"); |
31 | 31 | ||
32 | // Read in the config file. | 32 | // Read in the config file. |
33 | QString wlanFile = WIRELESS_OPTS; | 33 | QString wlanFile = WIRELESS_OPTS; |
34 | QFile file(wlanFile); | 34 | QFile file(wlanFile); |
35 | if (file.open(IO_ReadOnly)){ | 35 | if (file.open(IO_ReadOnly)){ |
36 | QTextStream stream( &file ); | 36 | QTextStream stream( &file ); |
37 | QString line = ""; | 37 | QString line = ""; |
38 | while ( !stream.eof() ) { | 38 | while ( !stream.eof() ) { |
39 | line += stream.readLine(); | 39 | line += stream.readLine(); |
40 | line += "\n"; | 40 | line += "\n"; |
41 | } | 41 | } |
42 | file.close(); | 42 | file.close(); |
43 | settingsFileText = QStringList::split("\n", line, true); | 43 | settingsFileText = QStringList::split("\n", line, true); |
44 | parseSettingFile(); | 44 | parseSettingFile(); |
45 | } | 45 | } |
46 | else | 46 | else |
47 | qDebug(QString("WLANImp: Can't open file: %1 for reading.").arg(wlanFile).latin1()); | 47 | qDebug(QString("WLANImp: Can't open file: %1 for reading.").arg(wlanFile).latin1()); |
48 | connect(networkType, SIGNAL(activated(int)), this, SLOT(typeChanged(int))); | 48 | connect(networkType, SIGNAL(activated(int)), this, SLOT(typeChanged(int))); |
49 | } | 49 | } |
50 | 50 | ||
51 | void WLANImp::typeChanged(int mod){ | 51 | void WLANImp::typeChanged(int mod){ |
52 | networkChannel->setEnabled(mod); | 52 | networkChannel->setEnabled(mod); |
53 | channelLabel->setEnabled(mod); | 53 | channelLabel->setEnabled(mod); |
54 | } | 54 | } |
55 | 55 | ||
56 | /** | 56 | /** |
57 | * Change the profile for both wireless settings and network settings. | 57 | * Change the profile for both wireless settings and network settings. |
58 | */ | 58 | */ |
59 | void WLANImp::setProfile(const QString &profile){ | 59 | void WLANImp::setProfile(const QString &profile){ |
60 | interfaceSetup->setProfile(profile); | 60 | interfaceSetup->setProfile(profile); |
61 | parseSettingFile(); | 61 | parseSettingFile(); |
62 | } | 62 | } |
63 | 63 | ||
64 | /** | 64 | /** |
65 | * Parses the settings file that was read in and gets any setting from it. | 65 | * Parses the settings file that was read in and gets any setting from it. |
66 | */ | 66 | */ |
67 | void WLANImp::parseSettingFile(){ | 67 | void WLANImp::parseSettingFile(){ |
68 | bool foundCase = false; | 68 | bool foundCase = false; |
69 | bool found = false; | 69 | bool found = false; |
70 | for ( QStringList::Iterator it = settingsFileText.begin(); it != settingsFileText.end(); ++it ) { | 70 | for ( QStringList::Iterator it = settingsFileText.begin(); it != settingsFileText.end(); ++it ) { |
71 | QString line = (*it).simplifyWhiteSpace(); | 71 | QString line = (*it).simplifyWhiteSpace(); |
72 | if(line.contains("case")) | 72 | if(line.contains("case")) |
73 | foundCase = true; | 73 | foundCase = true; |
74 | // See if we found our scheme to write or the sceme couldn't be found | 74 | // See if we found our scheme to write or the sceme couldn't be found |
75 | if((foundCase && line.contains("esac")) || | 75 | if((foundCase && line.contains("esac")) || |
76 | (foundCase && line.left(currentProfile.length()+7) == currentProfile + ",*,*,*)" && line.at(0) != '#')) | 76 | (foundCase && line.left(currentProfile.length()+7) == currentProfile + ",*,*,*)" && line.at(0) != '#')) |
77 | found = true; | 77 | found = true; |
78 | 78 | ||
79 | if(line.contains(";;")) | 79 | if(line.contains(";;")) |
80 | found = false; | 80 | found = false; |
81 | if(found){ | 81 | if(found){ |
82 | // write out scheme | 82 | // write out scheme |
83 | if(line.contains("ESSID=")){ | 83 | if(line.contains("ESSID=")){ |
84 | QString id = line.mid(line.find("ESSID=")+6, line.length()); | 84 | QString id = line.mid(line.find("ESSID=")+6, line.length()); |
85 | if(id == "any"){ | 85 | if(id == "any"){ |
86 | essAny->setChecked(false); | 86 | essAny->setChecked(false); |
87 | }else{ | 87 | }else{ |
88 | essAny->setChecked(true); | 88 | essAny->setChecked(true); |
89 | essSpecificLineEdit->setText(id); | 89 | essSpecificLineEdit->setText(id); |
90 | } | 90 | } |
91 | } | 91 | } |
92 | if(line.contains("MODE=")){ | 92 | if(line.contains("MODE=")){ |
93 | QString mode = line.mid(line.find("MODE=")+5, line.length()); | 93 | QString mode = line.mid(line.find("MODE=")+5, line.length()); |
94 | if(mode == "Managed"){ | 94 | if(mode == "Managed"){ |
95 | networkType->setCurrentItem(0); | 95 | networkType->setCurrentItem(0); |
96 | channelLabel->setEnabled(false); | 96 | channelLabel->setEnabled(false); |
97 | networkChannel->setEnabled(false); | 97 | networkChannel->setEnabled(false); |
98 | } | 98 | } |
99 | else{ | 99 | else{ |
100 | networkType->setCurrentItem(1); | 100 | networkType->setCurrentItem(1); |
101 | networkChannel->setEnabled(true); | 101 | networkChannel->setEnabled(true); |
102 | channelLabel->setEnabled(true); | 102 | channelLabel->setEnabled(true); |
103 | } | 103 | } |
104 | } | 104 | } |
105 | if(line.contains("#KEY0=")) | 105 | if(line.contains("#KEY0=")) |
106 | keyLineEdit0->setText(line.mid(6, line.length())); | 106 | keyLineEdit0->setText(line.mid(6, line.length())); |
107 | if(line.contains("#KEY1=")) | 107 | if(line.contains("#KEY1=")) |
108 | keyLineEdit1->setText(line.mid(6, line.length())); | 108 | keyLineEdit1->setText(line.mid(6, line.length())); |
109 | if(line.contains("#KEY2=")) | 109 | if(line.contains("#KEY2=")) |
110 | keyLineEdit2->setText(line.mid(6, line.length())); | 110 | keyLineEdit2->setText(line.mid(6, line.length())); |
111 | if(line.contains("#KEY3=")) | 111 | if(line.contains("#KEY3=")) |
112 | keyLineEdit3->setText(line.mid(6, line.length())); | 112 | keyLineEdit3->setText(line.mid(6, line.length())); |
113 | 113 | ||
114 | if(line.contains("KEY=")){ | 114 | if(line.contains("KEY=")){ |
115 | wepEnabled->setChecked(true); | 115 | wepEnabled->setChecked(true); |
116 | QString key; | 116 | QString key; |
117 | if(line.right(5) == (" open")){ | 117 | if(line.right(5) == (" open")){ |
118 | key = line.mid(4, line.length()-5); | 118 | key = line.mid(4, line.length()-5); |
119 | authOpen->setChecked(true); | 119 | authOpen->setChecked(true); |
120 | authShared->setChecked(false); | 120 | authShared->setChecked(false); |
121 | } | 121 | } |
122 | else{ | 122 | else{ |
123 | authOpen->setChecked(false); | 123 | authOpen->setChecked(false); |
124 | authShared->setChecked(true); | 124 | authShared->setChecked(true); |
125 | key = line.mid(4, line.length()); | 125 | key = line.mid(4, line.length()); |
126 | } | 126 | } |
127 | if(key == keyLineEdit0->text()) keyRadio0->setChecked(true); | 127 | if(key == keyLineEdit0->text()) keyRadio0->setChecked(true); |
128 | if(key == keyLineEdit1->text()) keyRadio1->setChecked(true); | 128 | if(key == keyLineEdit1->text()) keyRadio1->setChecked(true); |
129 | if(key == keyLineEdit2->text()) keyRadio2->setChecked(true); | 129 | if(key == keyLineEdit2->text()) keyRadio2->setChecked(true); |
130 | if(key == keyLineEdit3->text()) keyRadio3->setChecked(true); | 130 | if(key == keyLineEdit3->text()) keyRadio3->setChecked(true); |
131 | } | 131 | } |
132 | if(line.contains("CHANNEL=")){ | 132 | if(line.contains("CHANNEL=")){ |
133 | networkChannel->setValue(line.mid(line.find("CHANNEL=")+8, line.length()).toInt()); | 133 | networkChannel->setValue(line.mid(line.find("CHANNEL=")+8, line.length()).toInt()); |
134 | } | 134 | } |
135 | } | 135 | } |
136 | } | 136 | } |
137 | } | 137 | } |
138 | 138 | ||
139 | /** | 139 | /** |
140 | * Saves settings to the wireless.opts file using the current profile | 140 | * Saves settings to the wireless.opts file using the current profile |
141 | */ | 141 | */ |
142 | void WLANImp::changeAndSaveSettingFile(){ | 142 | void WLANImp::changeAndSaveSettingFile(){ |
143 | QString wlanFile = WIRELESS_OPTS; | 143 | QString wlanFile = WIRELESS_OPTS; |
144 | QFile::remove(wlanFile); | 144 | QFile::remove(wlanFile); |
145 | QFile file(wlanFile); | 145 | QFile file(wlanFile); |
146 | 146 | ||
147 | if (!file.open(IO_ReadWrite)){ | 147 | if (!file.open(IO_ReadWrite)){ |
148 | qDebug(QString("WLANImp::changeAndSaveSettingFile(): Can't open file: %1 for writing.").arg(wlanFile).latin1()); | 148 | qDebug(QString("WLANImp::changeAndSaveSettingFile(): Can't open file: %1 for writing.").arg(wlanFile).latin1()); |
149 | return; | 149 | return; |
150 | } | 150 | } |
151 | 151 | ||
152 | QTextStream stream( &file ); | 152 | QTextStream stream( &file ); |
153 | bool foundCase = false; | 153 | bool foundCase = false; |
154 | bool found = false; | 154 | bool found = false; |
155 | bool output = true; | 155 | bool output = true; |
156 | for ( QStringList::Iterator it = settingsFileText.begin(); it != settingsFileText.end(); ++it ) { | 156 | for ( QStringList::Iterator it = settingsFileText.begin(); it != settingsFileText.end(); ++it ) { |
157 | QString line = (*it).simplifyWhiteSpace(); | 157 | QString line = (*it).simplifyWhiteSpace(); |
158 | if(line.contains("case")) | 158 | if(line.contains("case")) |
159 | foundCase = true; | 159 | foundCase = true; |
160 | // See if we found our scheme to write or the sceme couldn't be found | 160 | // See if we found our scheme to write or the sceme couldn't be found |
161 | if((foundCase && line.contains("esac") && !found) || | 161 | if((foundCase && line.contains("esac") && !found) || |
162 | (foundCase && line.left(currentProfile.length()+7) == currentProfile + ",*,*,*)" && line.at(0) != '#')){ | 162 | (foundCase && line.left(currentProfile.length()+7) == currentProfile + ",*,*,*)" && line.at(0) != '#')){ |
163 | // write out scheme | 163 | // write out scheme |
164 | found = true; | 164 | found = true; |
165 | output = false; | 165 | output = false; |
166 | 166 | ||
167 | if(!line.contains("esac")) | 167 | if(!line.contains("esac")) |
168 | stream << line << "\n"; | 168 | stream << line << "\n"; |
169 | if(!essAny->isChecked() == true){ | 169 | if(!essAny->isChecked() == true){ |
170 | stream << "\tESSID=any\n"; | 170 | stream << "\tESSID=any\n"; |
171 | stream << "\tMODE=Managed\n"; | 171 | stream << "\tMODE=Managed\n"; |
172 | } | 172 | } |
173 | else{ | 173 | else{ |
174 | stream << "\tESSID=" << essSpecificLineEdit->text() << '\n'; | 174 | stream << "\tESSID=" << essSpecificLineEdit->text() << '\n'; |
175 | stream << "\tMODE=" << ( networkType->currentItem() == 0 ? "Managed" : "ad-hoc") << '\n'; | 175 | stream << "\tMODE=" << ( networkType->currentItem() == 0 ? "Managed" : "ad-hoc") << '\n'; |
176 | stream << "\tCHANNEL=" << networkChannel->value() << "\n"; | 176 | stream << "\tCHANNEL=" << networkChannel->value() << "\n"; |
177 | } | 177 | } |
178 | 178 | ||
179 | stream << "\t#KEY0=" << keyLineEdit0->text() << "\n"; | 179 | stream << "\t#KEY0=" << keyLineEdit0->text() << "\n"; |
180 | stream << "\t#KEY1=" << keyLineEdit1->text() << "\n"; | 180 | stream << "\t#KEY1=" << keyLineEdit1->text() << "\n"; |
181 | stream << "\t#KEY2=" << keyLineEdit2->text() << "\n"; | 181 | stream << "\t#KEY2=" << keyLineEdit2->text() << "\n"; |
182 | stream << "\t#KEY3=" << keyLineEdit3->text() << "\n"; | 182 | stream << "\t#KEY3=" << keyLineEdit3->text() << "\n"; |
183 | 183 | ||
184 | if(wepEnabled->isChecked()){ | 184 | if(wepEnabled->isChecked()){ |
185 | stream << "\tKEY=\""; | 185 | stream << "\tKEY=\""; |
186 | if(keyRadio0->isChecked()) stream << keyLineEdit0->text(); | 186 | if(keyRadio0->isChecked()) stream << keyLineEdit0->text(); |
187 | if(keyRadio1->isChecked()) stream << keyLineEdit1->text(); | 187 | if(keyRadio1->isChecked()) stream << keyLineEdit1->text(); |
188 | if(keyRadio2->isChecked()) stream << keyLineEdit2->text(); | 188 | if(keyRadio2->isChecked()) stream << keyLineEdit2->text(); |
189 | if(keyRadio3->isChecked()) stream << keyLineEdit3->text(); | 189 | if(keyRadio3->isChecked()) stream << keyLineEdit3->text(); |
190 | if(authOpen->isChecked()) | 190 | if(authOpen->isChecked()) |
191 | stream << " open"; | 191 | stream << " open"; |
192 | else | 192 | else |
193 | stream << " restricted"; | 193 | stream << " restricted"; |
194 | stream << "\"\n"; | 194 | stream << "\"\n"; |
195 | } | 195 | } |
196 | stream << "\tRATE=auto\n"; | 196 | stream << "\tRATE=auto\n"; |
197 | if(line.contains("esac")) | 197 | if(line.contains("esac")) |
198 | stream << line << "\n"; | 198 | stream << line << "\n"; |
199 | } | 199 | } |
200 | if(line.contains(";;")) | 200 | if(line.contains(";;")) |
201 | output = true; | 201 | output = true; |
202 | if(output && (*it).length() ) | 202 | if(output && (*it).length() ) |
203 | stream << (*it) << '\n'; | 203 | stream << (*it) << '\n'; |
204 | } | 204 | } |
205 | file.close(); | 205 | file.close(); |
206 | } | 206 | } |
207 | 207 | ||
208 | /** | 208 | /** |
209 | * Check to see if the current config is valid | 209 | * Check to see if the current config is valid |
210 | * Save wireless.opts, save interfaces | 210 | * Save wireless.opts, save interfaces |
211 | */ | 211 | */ |
212 | void WLANImp::accept(){ | 212 | void WLANImp::accept(){ |
213 | if(wepEnabled->isChecked()){ | 213 | if(wepEnabled->isChecked()){ |
214 | if(keyLineEdit0->text().isEmpty() && keyLineEdit1->text().isEmpty() && keyLineEdit2->text().isEmpty() && keyLineEdit3->text().isEmpty() ){ | 214 | if(keyLineEdit0->text().isEmpty() && keyLineEdit1->text().isEmpty() && keyLineEdit2->text().isEmpty() && keyLineEdit3->text().isEmpty() ){ |
215 | QMessageBox::information(this, "Error", "Please enter a key for WEP.", QMessageBox::Ok); | 215 | QMessageBox::information(this, "Error", "Please enter a key for WEP.", QMessageBox::Ok); |
216 | return; | 216 | return; |
217 | } | 217 | } |
218 | } | 218 | } |
219 | 219 | ||
220 | if(essAny->isChecked() && essSpecificLineEdit->text().isEmpty()){ | 220 | if(essAny->isChecked() && essSpecificLineEdit->text().isEmpty()){ |
221 | QMessageBox::information(this, "Error", "Please enter a ESS-ID.", QMessageBox::Ok); | 221 | QMessageBox::information(this, "Error", "Please enter a SSID.", QMessageBox::Ok); |
222 | return; | 222 | return; |
223 | } | 223 | } |
224 | 224 | ||
225 | // Ok settings are good here, save | 225 | // Ok settings are good here, save |
226 | changeAndSaveSettingFile(); | 226 | changeAndSaveSettingFile(); |
227 | 227 | ||
228 | // Try to save the interfaces settings. | 228 | // Try to save the interfaces settings. |
229 | if(!interfaceSetup->saveChanges()) | 229 | if(!interfaceSetup->saveChanges()) |
230 | return; | 230 | return; |
231 | 231 | ||
232 | OProcess insert; | 232 | OProcess insert; |
233 | insert << "sh"; | 233 | insert << "sh"; |
234 | insert << "-c"; | 234 | insert << "-c"; |
235 | insert << "cardctl eject && cardctl insert"; | 235 | insert << "cardctl eject && cardctl insert"; |
236 | 236 | ||
237 | if (!insert.start(OProcess::DontCare, OProcess::NoCommunication) ) { | 237 | if (!insert.start(OProcess::DontCare, OProcess::NoCommunication) ) { |
238 | qWarning("could not start cardctl"); | 238 | qWarning("could not start cardctl"); |
239 | } | 239 | } |
240 | 240 | ||
241 | // Close out the dialog | 241 | // Close out the dialog |
242 | QDialog::accept(); | 242 | QDialog::accept(); |
243 | } | 243 | } |
244 | 244 | ||
diff --git a/noncore/settings/networksettings/wlan/wlanimp2.cpp b/noncore/settings/networksettings/wlan/wlanimp2.cpp index 26e3aa9..7ce096f 100644 --- a/noncore/settings/networksettings/wlan/wlanimp2.cpp +++ b/noncore/settings/networksettings/wlan/wlanimp2.cpp | |||
@@ -1,276 +1,490 @@ | |||
1 | #include "wlanimp2.h" | 1 | #include "wlanimp2.h" |
2 | #include "keyedit.h" | 2 | #include "keyedit.h" |
3 | #include "interfacesetupimp.h" | 3 | #include "interfacesetupimp.h" |
4 | 4 | ||
5 | #include "../interfaces/interface.h" | ||
6 | |||
7 | #include <assert.h> | ||
8 | #include <errno.h> | ||
9 | #include <string.h> | ||
10 | |||
11 | #include <qapplication.h> | ||
5 | #include <qfile.h> | 12 | #include <qfile.h> |
6 | #include <qdir.h> | 13 | #include <qdir.h> |
14 | #include <qdialog.h> | ||
7 | #include <qtextstream.h> | 15 | #include <qtextstream.h> |
8 | #include <qmessagebox.h> | 16 | #include <qmessagebox.h> |
9 | #include <qlineedit.h> | 17 | #include <qlineedit.h> |
10 | #include <qlabel.h> | 18 | #include <qlabel.h> |
11 | #include <qspinbox.h> | 19 | #include <qspinbox.h> |
12 | #include <qradiobutton.h> | 20 | #include <qradiobutton.h> |
21 | #include <qpushbutton.h> | ||
13 | #include <qcheckbox.h> | 22 | #include <qcheckbox.h> |
14 | #include <qtabwidget.h> | 23 | #include <qtabwidget.h> |
15 | #include <qcombobox.h> | 24 | #include <qcombobox.h> |
25 | #include <qlistview.h> | ||
26 | #include <qvbox.h> | ||
27 | #include <qprogressbar.h> | ||
16 | 28 | ||
17 | #ifdef QWS | 29 | #ifdef QWS |
30 | #include <qpe/resource.h> | ||
18 | #include <opie/oprocess.h> | 31 | #include <opie/oprocess.h> |
32 | #include <opie2/onetwork.h> | ||
33 | #include <opie2/opcap.h> | ||
19 | #else | 34 | #else |
20 | #define OProcess KProcess | 35 | #define OProcess KProcess |
21 | #include <kprocess.h> | 36 | #include <kprocess.h> |
22 | #endif | 37 | #endif |
23 | 38 | ||
24 | #define WIRELESS_OPTS "/etc/pcmcia/wireless.opts" | 39 | #define WIRELESS_OPTS "/etc/pcmcia/wireless.opts" |
25 | #define PREUP "/etc/netwrok/if-pre-up.d/wireless-tools" | 40 | #define PREUP "/etc/network/if-pre-up.d/wireless-tools" |
26 | 41 | ||
27 | /** | 42 | /** |
28 | * Constructor, read in the wireless.opts file for parsing later. | 43 | * Constructor, read in the wireless.opts file for parsing later. |
29 | */ | 44 | */ |
30 | WLANImp::WLANImp( QWidget* parent, const char* name, Interface *i, bool modal, WFlags fl) : WLAN(parent, name, modal, fl), interface(i), currentProfile("*") { | 45 | WLANImp::WLANImp( QWidget* parent, const char* name, Interface *i, bool modal, WFlags fl) : WLAN(parent, name, modal, fl), interface(i), currentProfile("*") { |
31 | interfaces = new Interfaces(); | 46 | interfaces = new Interfaces(); |
32 | interfaceSetup = new InterfaceSetupImp(tabWidget, "InterfaceSetupImp", i, interfaces); | 47 | interfaceSetup = new InterfaceSetupImp(tabWidget, "InterfaceSetupImp", i, interfaces); |
33 | tabWidget->insertTab(interfaceSetup, "TCP/IP"); | 48 | tabWidget->insertTab(interfaceSetup, "TCP/IP"); |
34 | 49 | ||
35 | // Check sanity - the existance of the wireless-tools if-pre-up script | 50 | // Check sanity - the existance of the wireless-tools if-pre-up script |
36 | QFile file(QString(PREUP)); | 51 | QFile file(QString(PREUP)); |
37 | if (file.exists()) { | 52 | if (file.exists()) { |
38 | qWarning(QString("WLANImp: Unable to open /etc/network/if-pre-up.d/wireless-tools")); | 53 | qWarning(QString("WLANImp: Unable to open /etc/network/if-pre-up.d/wireless-tools")); |
39 | } | 54 | } |
55 | |||
56 | connect( rescanButton, SIGNAL( clicked() ), this, SLOT( rescanNeighbourhood() ) ); | ||
57 | connect( netView, SIGNAL( clicked( QListViewItem* ) ), this, SLOT( selectNetwork( QListViewItem* ) ) ); | ||
58 | netView->setColumnAlignment( col_chn, AlignCenter ); | ||
59 | netView->setItemMargin( 3 ); | ||
60 | netView->setAllColumnsShowFocus( true ); | ||
61 | |||
40 | } | 62 | } |
41 | 63 | ||
42 | WLANImp::~WLANImp() { | 64 | WLANImp::~WLANImp() { |
43 | //FIXME: delete interfaces; | 65 | //FIXME: delete interfaces; |
44 | } | 66 | } |
45 | 67 | ||
46 | /** | 68 | /** |
47 | * Change the profile for both wireless settings and network settings. | 69 | * Change the profile for both wireless settings and network settings. |
48 | */ | 70 | */ |
49 | void WLANImp::setProfile(const QString &profile){ | 71 | void WLANImp::setProfile(const QString &profile){ |
50 | interfaceSetup->setProfile(profile); | 72 | interfaceSetup->setProfile(profile); |
51 | parseOpts(); | 73 | parseOpts(); |
52 | } | 74 | } |
53 | 75 | ||
54 | void WLANImp::parseOpts() { | 76 | void WLANImp::parseOpts() { |
55 | bool error; | 77 | bool error; |
56 | QString opt; | 78 | QString opt; |
57 | 79 | ||
58 | if (! interfaces->isInterfaceSet()) | 80 | if (! interfaces->isInterfaceSet()) |
59 | return; | 81 | return; |
60 | 82 | ||
61 | 83 | ||
62 | opt = interfaces->getInterfaceOption("wireless_essid", error); | 84 | opt = interfaces->getInterfaceOption("wireless_essid", error); |
63 | if(opt == "any" || opt == "off" || opt.isNull()){ | 85 | if(opt == "any" || opt == "off" || opt.isNull()){ |
64 | essid->setEditText("any"); | 86 | essid->setEditText("any"); |
65 | } else { | 87 | } else { |
66 | essid->setEditText(opt); | 88 | essid->setEditText(opt); |
67 | } | 89 | } |
68 | 90 | ||
69 | opt = interfaces->getInterfaceOption("wireless_mode", error).simplifyWhiteSpace(); | 91 | opt = interfaces->getInterfaceOption("wireless_mode", error).simplifyWhiteSpace(); |
70 | 92 | ||
71 | for ( int i = 0; i < mode->count(); i++) | 93 | for ( int i = 0; i < mode->count(); i++) |
72 | if ( mode->text( i ) == opt ) mode->setCurrentItem( i ); | 94 | if ( mode->text( i ) == opt ) mode->setCurrentItem( i ); |
73 | 95 | ||
74 | opt = interfaces->getInterfaceOption("wireless_ap", error).simplifyWhiteSpace(); | 96 | opt = interfaces->getInterfaceOption("wireless_ap", error).simplifyWhiteSpace(); |
75 | if (! opt.isNull()) { | 97 | if (! opt.isNull()) { |
76 | specifyAp->setChecked(true); | 98 | specifyAp->setChecked(true); |
77 | macEdit->setText(opt); | 99 | macEdit->setText(opt); |
78 | } | 100 | } |
79 | 101 | ||
80 | opt = interfaces->getInterfaceOption("wireless_channel", error).simplifyWhiteSpace(); | 102 | opt = interfaces->getInterfaceOption("wireless_channel", error).simplifyWhiteSpace(); |
81 | if (! opt.isNull()) { | 103 | if (! opt.isNull()) { |
82 | specifyChan->setChecked(true); | 104 | specifyChan->setChecked(true); |
83 | networkChannel->setValue(opt.toInt()); | 105 | networkChannel->setValue(opt.toInt()); |
84 | } | 106 | } |
85 | 107 | ||
86 | opt = interfaces->getInterfaceOption("wireless_key", error).simplifyWhiteSpace(); | 108 | opt = interfaces->getInterfaceOption("wireless_key", error).simplifyWhiteSpace(); |
87 | if (opt.isNull()) | 109 | if (opt.isNull()) |
88 | opt = interfaces->getInterfaceOption("wireless_enc", error).simplifyWhiteSpace(); | 110 | opt = interfaces->getInterfaceOption("wireless_enc", error).simplifyWhiteSpace(); |
89 | parseKeyStr(opt); | 111 | parseKeyStr(opt); |
90 | } | 112 | } |
91 | 113 | ||
92 | void WLANImp::parseKeyStr(QString keystr) { | 114 | void WLANImp::parseKeyStr(QString keystr) { |
93 | int loc = 0; | 115 | int loc = 0; |
94 | int index = 1; | 116 | int index = 1; |
95 | QString key; | 117 | QString key; |
96 | QStringList keys = QStringList::split(QRegExp("\\s+"), keystr); | 118 | QStringList keys = QStringList::split(QRegExp("\\s+"), keystr); |
97 | int enc = -1; // encryption state | 119 | int enc = -1; // encryption state |
98 | 120 | ||
99 | for (QStringList::Iterator it = keys.begin(); it != keys.end(); ++it) { | 121 | for (QStringList::Iterator it = keys.begin(); it != keys.end(); ++it) { |
100 | if ((*it).left(3) == "off") { | 122 | if ((*it).left(3) == "off") { |
101 | // encryption disabled | 123 | // encryption disabled |
102 | enc = 0; | 124 | enc = 0; |
103 | } else if ((*it).left(2) == "on") { | 125 | } else if ((*it).left(2) == "on") { |
104 | // encryption enabled | 126 | // encryption enabled |
105 | enc = 1; | 127 | enc = 1; |
106 | } else if ((*it).left(4) == "open") { | 128 | } else if ((*it).left(4) == "open") { |
107 | // open mode, accept non encrypted packets | 129 | // open mode, accept non encrypted packets |
108 | acceptNonEnc->setChecked(true); | 130 | acceptNonEnc->setChecked(true); |
109 | } else if ((*it).left(10) == "restricted") { | 131 | } else if ((*it).left(10) == "restricted") { |
110 | // restricted mode, only accept encrypted packets | 132 | // restricted mode, only accept encrypted packets |
111 | rejectNonEnc->setChecked(true); | 133 | rejectNonEnc->setChecked(true); |
112 | } else if ((*it).left(3) == "key") { | 134 | } else if ((*it).left(3) == "key") { |
113 | // new set of options | 135 | // new set of options |
114 | } else if ((*it).left(1) == "[") { | 136 | } else if ((*it).left(1) == "[") { |
115 | index = (*it).mid(1, 1).toInt(); | 137 | index = (*it).mid(1, 1).toInt(); |
116 | // switch current key to index | 138 | // switch current key to index |
117 | switch (index) { | 139 | switch (index) { |
118 | case 1: | 140 | case 1: |
119 | keyRadio0->setChecked(true); | 141 | keyRadio0->setChecked(true); |
120 | break; | 142 | break; |
121 | case 2: | 143 | case 2: |
122 | keyRadio1->setChecked(true); | 144 | keyRadio1->setChecked(true); |
123 | break; | 145 | break; |
124 | case 3: | 146 | case 3: |
125 | keyRadio2->setChecked(true); | 147 | keyRadio2->setChecked(true); |
126 | break; | 148 | break; |
127 | case 4: | 149 | case 4: |
128 | keyRadio3->setChecked(true); | 150 | keyRadio3->setChecked(true); |
129 | break; | 151 | break; |
130 | } | 152 | } |
131 | } else { | 153 | } else { |
132 | // key | 154 | // key |
133 | key = (*it); | 155 | key = (*it); |
134 | } | 156 | } |
135 | if (! key.isNull()) { | 157 | if (! key.isNull()) { |
136 | if (enc == -1) | 158 | if (enc == -1) |
137 | enc = 1; | 159 | enc = 1; |
138 | QStringList::Iterator next = ++it; | 160 | QStringList::Iterator next = ++it; |
139 | if (it == keys.end()) { | 161 | if (it == keys.end()) { |
140 | break; | 162 | break; |
141 | } | 163 | } |
142 | if ((*(next)).left(1) == "[") { | 164 | if ((*(next)).left(1) == "[") { |
143 | // set key at index | 165 | // set key at index |
144 | index = (*(next)).mid(1, 1).toInt(); | 166 | index = (*(next)).mid(1, 1).toInt(); |
145 | } else { | 167 | } else { |
146 | index = 1; | 168 | index = 1; |
147 | } | 169 | } |
148 | switch (index) { | 170 | switch (index) { |
149 | case 1: | 171 | case 1: |
150 | keyLineEdit0->setText(key); | 172 | keyLineEdit0->setText(key); |
151 | break; | 173 | break; |
152 | case 2: | 174 | case 2: |
153 | keyLineEdit1->setText(key); | 175 | keyLineEdit1->setText(key); |
154 | break; | 176 | break; |
155 | case 3: | 177 | case 3: |
156 | keyLineEdit2->setText(key); | 178 | keyLineEdit2->setText(key); |
157 | break; | 179 | break; |
158 | case 4: | 180 | case 4: |
159 | keyLineEdit3->setText(key); | 181 | keyLineEdit3->setText(key); |
160 | break; | 182 | break; |
161 | } | 183 | } |
162 | key = QString::null; | 184 | key = QString::null; |
163 | } | 185 | } |
164 | } | 186 | } |
165 | if (enc == 1) { | 187 | if (enc == 1) { |
166 | wepEnabled->setChecked(true); | 188 | wepEnabled->setChecked(true); |
167 | } else { | 189 | } else { |
168 | wepEnabled->setChecked(false); | 190 | wepEnabled->setChecked(false); |
169 | } | 191 | } |
170 | } | 192 | } |
171 | 193 | ||
172 | /** | 194 | /** |
173 | * Check to see if the current config is valid | 195 | * Check to see if the current config is valid |
174 | * Save interfaces | 196 | * Save interfaces |
175 | */ | 197 | */ |
176 | void WLANImp::accept() { | 198 | void WLANImp::accept() { |
177 | if (wepEnabled->isChecked()) { | 199 | if (wepEnabled->isChecked()) { |
178 | if ((keyRadio0->isChecked() && keyLineEdit0->text().isEmpty()) || | 200 | if ((keyRadio0->isChecked() && keyLineEdit0->text().isEmpty()) || |
179 | (keyRadio1->isChecked() && keyLineEdit1->text().isEmpty()) || | 201 | (keyRadio1->isChecked() && keyLineEdit1->text().isEmpty()) || |
180 | (keyRadio2->isChecked() && keyLineEdit2->text().isEmpty()) || | 202 | (keyRadio2->isChecked() && keyLineEdit2->text().isEmpty()) || |
181 | (keyRadio3->isChecked() && keyLineEdit3->text().isEmpty())) { | 203 | (keyRadio3->isChecked() && keyLineEdit3->text().isEmpty())) { |
182 | QMessageBox::information(this, "Error", "Please enter a WEP key.", QMessageBox::Ok); | 204 | QMessageBox::information(this, "Error", "Please enter a WEP key.", QMessageBox::Ok); |
183 | return; | 205 | return; |
184 | } | 206 | } |
185 | } | 207 | } |
186 | 208 | ||
187 | if (essid->currentText().isEmpty()) { | 209 | if (essid->currentText().isEmpty()) { |
188 | QMessageBox::information(this, "Error", "Please select/enter an ESSID.", QMessageBox::Ok); | 210 | QMessageBox::information(this, "Error", "Please select/enter an ESSID.", QMessageBox::Ok); |
189 | return; | 211 | return; |
190 | } | 212 | } |
191 | 213 | ||
192 | if (specifyAp->isChecked() && macEdit->text().isEmpty()) { | 214 | if (specifyAp->isChecked() && macEdit->text().isEmpty()) { |
193 | QMessageBox::information(this, "Error", "Please enter the MAC address of the Access Point.", QMessageBox::Ok); | 215 | QMessageBox::information(this, "Error", "Please enter the MAC address of the Access Point.", QMessageBox::Ok); |
194 | return; | 216 | return; |
195 | } | 217 | } |
196 | 218 | ||
197 | // Try to save the interfaces settings. | 219 | // Try to save the interfaces settings. |
198 | writeOpts(); | 220 | writeOpts(); |
199 | 221 | ||
200 | // Close out the dialog | 222 | // Close out the dialog |
201 | // FIXME: QDialog::accept(); | 223 | // FIXME: QDialog::accept(); |
202 | } | 224 | } |
203 | 225 | ||
204 | void WLANImp::writeOpts() { | 226 | void WLANImp::writeOpts() { |
205 | // eh can't really do anything about it other then return. :-D | 227 | // eh can't really do anything about it other then return. :-D |
206 | if(!interfaces->isInterfaceSet()){ | 228 | if(!interfaces->isInterfaceSet()){ |
207 | QMessageBox::warning(0,"Inface not set","should not happen!!!"); | 229 | QMessageBox::warning(0,"Inface not set","should not happen!!!"); |
208 | return; | 230 | return; |
209 | } | 231 | } |
210 | bool error = false; | 232 | bool error = false; |
211 | 233 | ||
212 | qDebug("setting wlan interface %s", interfaces->getInterfaceName( error ).latin1() ); | 234 | qDebug("setting wlan interface %s", interfaces->getInterfaceName( error ).latin1() ); |
213 | 235 | ||
214 | if (error) QMessageBox::warning(0,"Inface not set","should not happen!!!"); | 236 | if (error) QMessageBox::warning(0,"Inface not set","should not happen!!!"); |
215 | 237 | ||
216 | interfaces->setInterfaceOption(QString("wireless_mode"), mode->currentText()); | 238 | interfaces->setInterfaceOption(QString("wireless_mode"), mode->currentText()); |
217 | interfaces->setInterfaceOption(QString("wireless_essid"), essid->currentText()); | 239 | interfaces->setInterfaceOption(QString("wireless_essid"), essid->currentText()); |
218 | 240 | ||
219 | if (specifyAp->isChecked()) { | 241 | if (specifyAp->isChecked()) { |
220 | interfaces->setInterfaceOption(QString("wireless_ap"), macEdit->text()); | 242 | interfaces->setInterfaceOption(QString("wireless_ap"), macEdit->text()); |
221 | } else { | 243 | } else { |
222 | interfaces->removeInterfaceOption(QString("wireless_ap")); | 244 | interfaces->removeInterfaceOption(QString("wireless_ap")); |
223 | } | 245 | } |
224 | 246 | ||
225 | if (specifyChan->isChecked()) { | 247 | if (specifyChan->isChecked()) { |
226 | interfaces->setInterfaceOption(QString("wireless_channel"), networkChannel->text()); | 248 | interfaces->setInterfaceOption(QString("wireless_channel"), networkChannel->text()); |
227 | } else { | 249 | } else { |
228 | interfaces->removeInterfaceOption(QString("wireless_channel")); | 250 | interfaces->removeInterfaceOption(QString("wireless_channel")); |
229 | } | 251 | } |
230 | 252 | ||
231 | if (wepEnabled->isChecked()) { | 253 | if (wepEnabled->isChecked()) { |
232 | QStringList keyList; | 254 | QStringList keyList; |
233 | 255 | ||
234 | if (! keyLineEdit0->text().isNull()) { | 256 | if (! keyLineEdit0->text().isNull()) { |
235 | keyList += keyLineEdit0->text(); | 257 | keyList += keyLineEdit0->text(); |
236 | keyList += "[1]"; | 258 | keyList += "[1]"; |
237 | } //else | 259 | } //else |
238 | if (! keyLineEdit1->text().isNull()) { | 260 | if (! keyLineEdit1->text().isNull()) { |
239 | keyList += keyLineEdit1->text(); | 261 | keyList += keyLineEdit1->text(); |
240 | keyList += "[2]"; | 262 | keyList += "[2]"; |
241 | } //else | 263 | } //else |
242 | if (! keyLineEdit2->text().isNull()) { | 264 | if (! keyLineEdit2->text().isNull()) { |
243 | keyList += keyLineEdit2->text(); | 265 | keyList += keyLineEdit2->text(); |
244 | keyList += "[3]"; | 266 | keyList += "[3]"; |
245 | } //else | 267 | } //else |
246 | if (! keyLineEdit3->text().isNull()) { | 268 | if (! keyLineEdit3->text().isNull()) { |
247 | keyList += keyLineEdit3->text(); | 269 | keyList += keyLineEdit3->text(); |
248 | keyList += "[4]"; | 270 | keyList += "[4]"; |
249 | } | 271 | } |
250 | if (acceptNonEnc->isChecked()) { | 272 | if (acceptNonEnc->isChecked()) { |
251 | keyList += "open"; | 273 | keyList += "open"; |
252 | } else { | 274 | } else { |
253 | keyList += "restricted"; | 275 | keyList += "restricted"; |
254 | } | 276 | } |
255 | 277 | ||
256 | keyList += "key"; | 278 | keyList += "key"; |
257 | if (keyRadio0->isChecked()) { | 279 | if (keyRadio0->isChecked()) { |
258 | keyList += "[1]"; | 280 | keyList += "[1]"; |
259 | } else if (keyRadio1->isChecked()) { | 281 | } else if (keyRadio1->isChecked()) { |
260 | keyList += "[2]"; | 282 | keyList += "[2]"; |
261 | } else if (keyRadio2->isChecked()) { | 283 | } else if (keyRadio2->isChecked()) { |
262 | keyList += "[3]"; | 284 | keyList += "[3]"; |
263 | } else if (keyRadio3->isChecked()) { | 285 | } else if (keyRadio3->isChecked()) { |
264 | keyList += "[4]"; | 286 | keyList += "[4]"; |
265 | } | 287 | } |
266 | interfaces->setInterfaceOption(QString("wireless_key"), keyList.join(QString(" "))); | 288 | interfaces->setInterfaceOption(QString("wireless_key"), keyList.join(QString(" "))); |
267 | } else { | 289 | } else { |
268 | interfaces->removeInterfaceOption(QString("wireless_key")); | 290 | interfaces->removeInterfaceOption(QString("wireless_key")); |
269 | } | 291 | } |
270 | interfaces->removeInterfaceOption(QString("wireless_enc")); | 292 | interfaces->removeInterfaceOption(QString("wireless_enc")); |
271 | 293 | ||
272 | if(!interfaceSetup->saveChanges()) | 294 | if(!interfaceSetup->saveChanges()) |
273 | return; | 295 | return; |
274 | 296 | ||
275 | QDialog::accept(); | 297 | QDialog::accept(); |
276 | } | 298 | } |
299 | |||
300 | /* | ||
301 | * Scan for possible wireless networks around... | ||
302 | * ... powered by Wellenreiter II technology (C) Michael 'Mickey' Lauer <mickeyl@handhelds.org> | ||
303 | */ | ||
304 | |||
305 | void WLANImp::rescanNeighbourhood() | ||
306 | { | ||
307 | QString name = interface->getInterfaceName(); | ||
308 | qDebug( "rescanNeighbourhood via '%s'", (const char*) name ); | ||
309 | |||
310 | OWirelessNetworkInterface* wiface = static_cast<OWirelessNetworkInterface*>( ONetwork::instance()->interface( name ) ); | ||
311 | assert( wiface ); | ||
312 | |||
313 | // try to guess device type | ||
314 | QString devicetype; | ||
315 | QFile m( "/proc/modules" ); | ||
316 | if ( m.open( IO_ReadOnly ) ) | ||
317 | { | ||
318 | QString line; | ||
319 | QTextStream modules( &m ); | ||
320 | while( !modules.atEnd() && !devicetype ) | ||
321 | { | ||
322 | modules >> line; | ||
323 | if ( line.contains( "cisco" ) ) devicetype = "cisco"; | ||
324 | else if ( line.contains( "hostap" ) ) devicetype = "hostap"; | ||
325 | else if ( line.contains( "prism" ) ) devicetype = "wlan-ng"; /* puke */ | ||
326 | else if ( line.contains( "orinoco" ) ) devicetype = "orinoco"; | ||
327 | } | ||
328 | } | ||
329 | if ( devicetype.isEmpty() ) | ||
330 | { | ||
331 | qWarning( "rescanNeighbourhood(): couldn't guess device type :(" ); | ||
332 | return; | ||
333 | } | ||
334 | else | ||
335 | { | ||
336 | qDebug( "rescanNeighbourhood(): device type seems to be '%s'", (const char*) devicetype ); | ||
337 | } | ||
338 | |||
339 | // configure interface to receive 802.11 management frames | ||
340 | |||
341 | wiface->setUp( true ); | ||
342 | wiface->setPromiscuousMode( true ); | ||
343 | |||
344 | if ( devicetype == "cisco" ) wiface->setMonitoring( new OCiscoMonitoringInterface( wiface, false ) ); | ||
345 | else if ( devicetype == "hostap" ) wiface->setMonitoring( new OHostAPMonitoringInterface( wiface, false ) ); | ||
346 | else if ( devicetype == "wlan-ng" ) wiface->setMonitoring( new OWlanNGMonitoringInterface( wiface, false ) ); | ||
347 | else if ( devicetype == "orinoco" ) wiface->setMonitoring( new OOrinocoMonitoringInterface( wiface, false ) ); | ||
348 | else | ||
349 | { | ||
350 | qDebug( "rescanNeighbourhood(): unsupported device type for monitoring :(" ); | ||
351 | return; | ||
352 | } | ||
353 | |||
354 | wiface->setMonitorMode( true ); | ||
355 | if ( !wiface->monitorMode() ) | ||
356 | { | ||
357 | qWarning( "rescanNeighbourhood(): Unable to bring device into monitor mode (%s).", strerror( errno ) ); | ||
358 | return; | ||
359 | } | ||
360 | |||
361 | // open a packet capturer | ||
362 | OPacketCapturer* cap = new OPacketCapturer(); | ||
363 | cap->open( name ); | ||
364 | if ( !cap->isOpen() ) | ||
365 | { | ||
366 | qWarning( "rescanNeighbourhood(): Unable to open libpcap (%s).", strerror( errno ) ); | ||
367 | return; | ||
368 | } | ||
369 | |||
370 | // display splash screen | ||
371 | QFrame* splash = new QFrame( this, "splash", false, WStyle_StaysOnTop | WStyle_DialogBorder | WStyle_Customize ); | ||
372 | splash->setLineWidth( 2 ); | ||
373 | splash->setFrameStyle( QFrame::Panel | QFrame::Raised ); | ||
374 | QVBoxLayout* vbox = new QVBoxLayout( splash, 4, 4 ); | ||
375 | QLabel* lab = new QLabel( "<center><b>Scanning...</b><br>Please Wait...</center>", splash ); | ||
376 | QProgressBar* pb = new QProgressBar( wiface->channels(), splash ); | ||
377 | vbox->addWidget( lab ); | ||
378 | vbox->addWidget( pb ); | ||
379 | pb->setCenterIndicator( true ); | ||
380 | pb->setFixedHeight( pb->sizeHint().height() ); | ||
381 | QWidget* widgetDesktop = qApp->desktop(); | ||
382 | int dw = widgetDesktop->width(); | ||
383 | int dh = widgetDesktop->height(); | ||
384 | int pw = vbox->sizeHint().width(); | ||
385 | int ph = vbox->sizeHint().height(); | ||
386 | splash->setGeometry((dw-pw)/2,(dh-ph)/2,pw,ph); | ||
387 | splash->show(); | ||
388 | splash->raise(); | ||
389 | qApp->processEvents(); | ||
390 | |||
391 | // set capturer to non-blocking mode | ||
392 | cap->setBlocking( false ); | ||
393 | |||
394 | for ( int i = 1; i <= wiface->channels(); ++i ) | ||
395 | { | ||
396 | wiface->setChannel( i ); | ||
397 | pb->setProgress( i ); | ||
398 | qApp->processEvents(); | ||
399 | qDebug( "rescanNeighbourhood(): listening on channel %d...", i ); | ||
400 | OPacket* p = cap->next( 1000 ); | ||
401 | if ( !p ) | ||
402 | { | ||
403 | qDebug( "rescanNeighbourhood(): nothing received on channel %d", i ); | ||
404 | } | ||
405 | else | ||
406 | { | ||
407 | qDebug( "rescanNeighbourhood(): TADAA - something came in on channel %d", i ); | ||
408 | handlePacket( p ); | ||
409 | } | ||
410 | } | ||
411 | |||
412 | cap->close(); | ||
413 | wiface->setMonitorMode( false ); | ||
414 | wiface->setPromiscuousMode( true ); | ||
415 | |||
416 | splash->hide(); | ||
417 | delete splash; | ||
418 | |||
419 | } | ||
420 | |||
421 | void WLANImp::handlePacket( OPacket* p ) | ||
422 | { | ||
423 | |||
424 | // check if we received a beacon frame | ||
425 | OWaveLanManagementPacket* beacon = static_cast<OWaveLanManagementPacket*>( p->child( "802.11 Management" ) ); | ||
426 | if ( beacon && beacon->managementType() == "Beacon" ) | ||
427 | { | ||
428 | |||
429 | QString type; | ||
430 | if ( beacon->canIBSS() ) | ||
431 | { | ||
432 | type = "adhoc"; | ||
433 | } | ||
434 | else if ( beacon->canESS() ) | ||
435 | { | ||
436 | type = "managed"; | ||
437 | } | ||
438 | else | ||
439 | { | ||
440 | qWarning( "handlePacket(): invalid frame [possibly noise] detected!" ); | ||
441 | return; | ||
442 | } | ||
443 | |||
444 | OWaveLanManagementSSID* ssid = static_cast<OWaveLanManagementSSID*>( p->child( "802.11 SSID" ) ); | ||
445 | QString essid = ssid ? ssid->ID() : QString("<unknown>"); | ||
446 | OWaveLanManagementDS* ds = static_cast<OWaveLanManagementDS*>( p->child( "802.11 DS" ) ); | ||
447 | int channel = ds ? ds->channel() : -1; | ||
448 | OWaveLanPacket* header = static_cast<OWaveLanPacket*>( p->child( "802.11" ) ); | ||
449 | displayFoundNetwork( type, channel, essid, header->macAddress2() ); | ||
450 | } | ||
451 | } | ||
452 | |||
453 | |||
454 | void WLANImp::displayFoundNetwork( const QString& mode, int channel, const QString& ssid, const OMacAddress& mac ) | ||
455 | { | ||
456 | |||
457 | qDebug( "found network: <%s>, chn %d, ssid '%s', mac '%s'", (const char*) mode, channel, | ||
458 | (const char*) ssid, | ||
459 | (const char*) mac.toString() ); | ||
460 | |||
461 | QListViewItemIterator it( netView ); | ||
462 | while ( it.current() && it.current()->text( col_ssid ) != ssid ) ++it; | ||
463 | if ( !it.current() ) // ssid didn't show up yet | ||
464 | { | ||
465 | QListViewItem* item = new QListViewItem( netView, mode.left( 1 ).upper(), ssid, QString::number( channel ), mac.toString() ); | ||
466 | QString name; | ||
467 | name.sprintf( "networksettings/%s", (const char*) mode ); | ||
468 | item->setPixmap( col_mode, Resource::loadPixmap( name ) ); | ||
469 | qApp->processEvents(); | ||
470 | } | ||
471 | |||
472 | } | ||
473 | |||
474 | |||
475 | void WLANImp::selectNetwork( QListViewItem* item ) | ||
476 | { | ||
477 | bool ok; | ||
478 | if ( item ) | ||
479 | { | ||
480 | specifyAp->setChecked(true); | ||
481 | macEdit->setText( item->text( col_mac ) ); | ||
482 | specifyChan->setChecked( item->text( col_mode ) == "A" ); | ||
483 | networkChannel->setValue( item->text( col_chn ).toInt( &ok ) ); | ||
484 | essid->setEditText( item->text( col_ssid ) ); | ||
485 | if ( item->text( col_mode ) == "A" ) | ||
486 | mode->setCurrentItem( 3 ); | ||
487 | else | ||
488 | mode->setCurrentItem( 2 ); | ||
489 | } | ||
490 | } | ||
diff --git a/noncore/settings/networksettings/wlan/wlanimp2.h b/noncore/settings/networksettings/wlan/wlanimp2.h index 992d09a..a777203 100644 --- a/noncore/settings/networksettings/wlan/wlanimp2.h +++ b/noncore/settings/networksettings/wlan/wlanimp2.h | |||
@@ -1,37 +1,52 @@ | |||
1 | #ifndef WLANIMP_H | 1 | #ifndef WLANIMP_H |
2 | #define WLANIMP_H | 2 | #define WLANIMP_H |
3 | 3 | ||
4 | #include "wlan.h" | 4 | #include "wlan.h" |
5 | #include "interfaces.h" | 5 | #include "interfaces.h" |
6 | #include <qstringlist.h> | 6 | #include <qstringlist.h> |
7 | #include <opie2/onetutils.h> | ||
7 | 8 | ||
8 | class InterfaceSetupImp; | 9 | class InterfaceSetupImp; |
9 | class Interface; | 10 | class Interface; |
10 | class Config; | 11 | class Config; |
12 | class OPacket; | ||
13 | class QListViewItem; | ||
11 | 14 | ||
12 | class WLANImp : public WLAN { | 15 | const int col_mode= 0; |
16 | const int col_ssid = 1; | ||
17 | const int col_chn = 2; | ||
18 | const int col_mac = 3; | ||
19 | |||
20 | class WLANImp : public WLAN { | ||
13 | Q_OBJECT | 21 | Q_OBJECT |
14 | 22 | ||
15 | public: | 23 | public: |
16 | WLANImp( QWidget* parent = 0, const char* name = 0, Interface *i=0, bool modal = FALSE, WFlags fl = 0 ); | 24 | WLANImp( QWidget* parent = 0, const char* name = 0, Interface *i=0, bool modal = FALSE, WFlags fl = 0 ); |
17 | ~WLANImp(); | 25 | ~WLANImp(); |
18 | void setProfile(const QString &profile); | 26 | void setProfile(const QString &profile); |
19 | 27 | ||
28 | public slots: | ||
29 | void rescanNeighbourhood(); | ||
30 | void selectNetwork( QListViewItem* ); | ||
31 | |||
20 | protected: | 32 | protected: |
21 | void accept(); | 33 | void accept(); |
22 | 34 | ||
23 | private: | 35 | private: |
24 | void parseOpts(); | 36 | void parseOpts(); |
25 | void writeOpts(); | 37 | void writeOpts(); |
26 | 38 | ||
27 | void parseKeyStr(QString keystr); | 39 | void parseKeyStr(QString keystr); |
28 | 40 | ||
41 | void handlePacket( OPacket* ); | ||
42 | void displayFoundNetwork( const QString& mode, int channel, const QString& ssid, const OMacAddress& mac ); | ||
43 | |||
29 | InterfaceSetupImp *interfaceSetup; | 44 | InterfaceSetupImp *interfaceSetup; |
30 | Interfaces *interfaces; | 45 | Interfaces *interfaces; |
31 | Interface *interface; | 46 | Interface *interface; |
32 | 47 | ||
33 | QString currentProfile; | 48 | QString currentProfile; |
34 | }; | 49 | }; |
35 | 50 | ||
36 | #endif | 51 | #endif |
37 | 52 | ||
diff --git a/pics/networksettings/adhoc.png b/pics/networksettings/adhoc.png new file mode 100644 index 0000000..dcf5ad2 --- a/dev/null +++ b/pics/networksettings/adhoc.png | |||
Binary files differ | |||
diff --git a/pics/networksettings/managed.png b/pics/networksettings/managed.png new file mode 100644 index 0000000..4554533 --- a/dev/null +++ b/pics/networksettings/managed.png | |||
Binary files differ | |||