author | mickeyl <mickeyl> | 2003-04-16 22:24:29 (UTC) |
---|---|---|
committer | mickeyl <mickeyl> | 2003-04-16 22:24:29 (UTC) |
commit | 0ac702419b3b8450b689e0ee2500f34b577f1a72 (patch) (unidiff) | |
tree | ef9e8101430c1429992b43a780bd68ca10daa77f /libopie2/opienet | |
parent | 14db7d7d1ea99b8d9715f11daaa3ca9f4d8a554a (diff) | |
download | opie-0ac702419b3b8450b689e0ee2500f34b577f1a72.zip opie-0ac702419b3b8450b689e0ee2500f34b577f1a72.tar.gz opie-0ac702419b3b8450b689e0ee2500f34b577f1a72.tar.bz2 |
add some missing APIs to ONetworkInterface
-rw-r--r-- | libopie2/opienet/onetwork.cpp | 41 | ||||
-rw-r--r-- | libopie2/opienet/onetwork.h | 49 |
2 files changed, 75 insertions, 15 deletions
diff --git a/libopie2/opienet/onetwork.cpp b/libopie2/opienet/onetwork.cpp index f0094c7..be2736a 100644 --- a/libopie2/opienet/onetwork.cpp +++ b/libopie2/opienet/onetwork.cpp | |||
@@ -1,439 +1,478 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the Opie Project | 2 | This file is part of the Opie Project |
3 | Copyright (C) 2003 by the Wellenreiter team: | 3 | Copyright (C) 2003 by the Wellenreiter team: |
4 | Martin J. Muench <mjm@remote-exploit.org> | 4 | Martin J. Muench <mjm@remote-exploit.org> |
5 | Max Moser <mmo@remote-exploit.org | 5 | Max Moser <mmo@remote-exploit.org |
6 | Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> | 6 | Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> |
7 | =. | 7 | =. |
8 | .=l. | 8 | .=l. |
9 | .>+-= | 9 | .>+-= |
10 | _;:, .> :=|. This program is free software; you can | 10 | _;:, .> :=|. This program is free software; you can |
11 | .> <`_, > . <= redistribute it and/or modify it under | 11 | .> <`_, > . <= redistribute it and/or modify it under |
12 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 12 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
13 | .="- .-=="i, .._ License as published by the Free Software | 13 | .="- .-=="i, .._ License as published by the Free Software |
14 | - . .-<_> .<> Foundation; either version 2 of the License, | 14 | - . .-<_> .<> Foundation; either version 2 of the License, |
15 | ._= =} : or (at your option) any later version. | 15 | ._= =} : or (at your option) any later version. |
16 | .%`+i> _;_. | 16 | .%`+i> _;_. |
17 | .i_,=:_. -<s. This program is distributed in the hope that | 17 | .i_,=:_. -<s. This program is distributed in the hope that |
18 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 18 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
19 | : .. .:, . . . without even the implied warranty of | 19 | : .. .:, . . . without even the implied warranty of |
20 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 20 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
21 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU | 21 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU |
22 | ..}^=.= = ; Library General Public License for more | 22 | ..}^=.= = ; Library General Public License for more |
23 | ++= -. .` .: details. | 23 | ++= -. .` .: details. |
24 | : = ...= . :.=- | 24 | : = ...= . :.=- |
25 | -. .:....=;==+<; You should have received a copy of the GNU | 25 | -. .:....=;==+<; You should have received a copy of the GNU |
26 | -_. . . )=. = Library General Public License along with | 26 | -_. . . )=. = Library General Public License along with |
27 | -- :-=` this library; see the file COPYING.LIB. | 27 | -- :-=` this library; see the file COPYING.LIB. |
28 | If not, write to the Free Software Foundation, | 28 | If not, write to the Free Software Foundation, |
29 | Inc., 59 Temple Place - Suite 330, | 29 | Inc., 59 Temple Place - Suite 330, |
30 | Boston, MA 02111-1307, USA. | 30 | Boston, MA 02111-1307, USA. |
31 | 31 | ||
32 | */ | 32 | */ |
33 | 33 | ||
34 | /* OPIE */ | 34 | /* OPIE */ |
35 | 35 | ||
36 | #include <opie2/onetwork.h> | 36 | #include <opie2/onetwork.h> |
37 | 37 | ||
38 | /* QT */ | 38 | /* QT */ |
39 | 39 | ||
40 | #include <qfile.h> | 40 | #include <qfile.h> |
41 | #include <qtextstream.h> | 41 | #include <qtextstream.h> |
42 | 42 | ||
43 | /* UNIX */ | 43 | /* UNIX */ |
44 | 44 | ||
45 | #include <arpa/inet.h> | 45 | #include <arpa/inet.h> |
46 | #include <cerrno> | 46 | #include <cerrno> |
47 | #include <cstring> | 47 | #include <cstring> |
48 | #include <cstdlib> | 48 | #include <cstdlib> |
49 | #include <math.h> | 49 | #include <math.h> |
50 | #include <sys/ioctl.h> | 50 | #include <sys/ioctl.h> |
51 | #include <sys/socket.h> | 51 | #include <sys/socket.h> |
52 | #include <sys/types.h> | 52 | #include <sys/types.h> |
53 | #include <unistd.h> | 53 | #include <unistd.h> |
54 | #include <linux/sockios.h> | 54 | #include <linux/sockios.h> |
55 | #include <net/if_arp.h> | 55 | #include <net/if_arp.h> |
56 | #include <stdarg.h> | 56 | #include <stdarg.h> |
57 | 57 | ||
58 | using namespace std; | 58 | using namespace std; |
59 | 59 | ||
60 | /*====================================================================================== | 60 | /*====================================================================================== |
61 | * ONetwork | 61 | * ONetwork |
62 | *======================================================================================*/ | 62 | *======================================================================================*/ |
63 | 63 | ||
64 | ONetwork* ONetwork::_instance = 0; | 64 | ONetwork* ONetwork::_instance = 0; |
65 | 65 | ||
66 | ONetwork::ONetwork() | 66 | ONetwork::ONetwork() |
67 | { | 67 | { |
68 | qDebug( "ONetwork::ONetwork()" ); | 68 | qDebug( "ONetwork::ONetwork()" ); |
69 | synchronize(); | 69 | synchronize(); |
70 | } | 70 | } |
71 | 71 | ||
72 | void ONetwork::synchronize() | 72 | void ONetwork::synchronize() |
73 | { | 73 | { |
74 | // gather available interfaces by inspecting /proc/net/dev | 74 | // gather available interfaces by inspecting /proc/net/dev |
75 | //FIXME: we could use SIOCGIFCONF here, but we aren't interested in virtual (e.g. eth0:0) devices | 75 | //FIXME: we could use SIOCGIFCONF here, but we aren't interested in virtual (e.g. eth0:0) devices |
76 | //FIXME: Use SIOCGIFCONF anway, because we can disable listing of aliased devices | 76 | //FIXME: Use SIOCGIFCONF anway, because we can disable listing of aliased devices |
77 | 77 | ||
78 | _interfaces.clear(); | 78 | _interfaces.clear(); |
79 | QString str; | 79 | QString str; |
80 | QFile f( "/proc/net/dev" ); | 80 | QFile f( "/proc/net/dev" ); |
81 | bool hasFile = f.open( IO_ReadOnly ); | 81 | bool hasFile = f.open( IO_ReadOnly ); |
82 | if ( !hasFile ) | 82 | if ( !hasFile ) |
83 | { | 83 | { |
84 | qDebug( "ONetwork: /proc/net/dev not existing. No network devices available" ); | 84 | qDebug( "ONetwork: /proc/net/dev not existing. No network devices available" ); |
85 | return; | 85 | return; |
86 | } | 86 | } |
87 | QTextStream s( &f ); | 87 | QTextStream s( &f ); |
88 | s.readLine(); | 88 | s.readLine(); |
89 | s.readLine(); | 89 | s.readLine(); |
90 | while ( !s.atEnd() ) | 90 | while ( !s.atEnd() ) |
91 | { | 91 | { |
92 | s >> str; | 92 | s >> str; |
93 | str.truncate( str.find( ':' ) ); | 93 | str.truncate( str.find( ':' ) ); |
94 | qDebug( "ONetwork: found interface '%s'", (const char*) str ); | 94 | qDebug( "ONetwork: found interface '%s'", (const char*) str ); |
95 | ONetworkInterface* iface; | 95 | ONetworkInterface* iface; |
96 | if ( isWirelessInterface( str ) ) | 96 | if ( isWirelessInterface( str ) ) |
97 | { | 97 | { |
98 | iface = new OWirelessNetworkInterface( this, (const char*) str ); | 98 | iface = new OWirelessNetworkInterface( this, (const char*) str ); |
99 | qDebug( "ONetwork: interface '%s' has Wireless Extensions", (const char*) str ); | 99 | qDebug( "ONetwork: interface '%s' has Wireless Extensions", (const char*) str ); |
100 | } | 100 | } |
101 | else | 101 | else |
102 | { | 102 | { |
103 | iface = new ONetworkInterface( this, (const char*) str ); | 103 | iface = new ONetworkInterface( this, (const char*) str ); |
104 | } | 104 | } |
105 | _interfaces.insert( str, iface ); | 105 | _interfaces.insert( str, iface ); |
106 | s.readLine(); | 106 | s.readLine(); |
107 | } | 107 | } |
108 | } | 108 | } |
109 | 109 | ||
110 | 110 | ||
111 | int ONetwork::count() const | ||
112 | { | ||
113 | return _interfaces.count(); | ||
114 | } | ||
115 | |||
116 | |||
111 | ONetworkInterface* ONetwork::interface( const QString& iface ) const | 117 | ONetworkInterface* ONetwork::interface( const QString& iface ) const |
112 | { | 118 | { |
113 | return _interfaces[iface]; | 119 | return _interfaces[iface]; |
114 | } | 120 | } |
115 | 121 | ||
116 | 122 | ||
117 | ONetwork* ONetwork::instance() | 123 | ONetwork* ONetwork::instance() |
118 | { | 124 | { |
119 | if ( !_instance ) _instance = new ONetwork(); | 125 | if ( !_instance ) _instance = new ONetwork(); |
120 | return _instance; | 126 | return _instance; |
121 | } | 127 | } |
122 | 128 | ||
123 | 129 | ||
124 | ONetwork::InterfaceIterator ONetwork::iterator() const | 130 | ONetwork::InterfaceIterator ONetwork::iterator() const |
125 | { | 131 | { |
126 | return ONetwork::InterfaceIterator( _interfaces ); | 132 | return ONetwork::InterfaceIterator( _interfaces ); |
127 | } | 133 | } |
128 | 134 | ||
129 | 135 | ||
130 | bool ONetwork::isWirelessInterface( const char* name ) const | 136 | bool ONetwork::isWirelessInterface( const char* name ) const |
131 | { | 137 | { |
132 | int sfd = socket( AF_INET, SOCK_STREAM, 0 ); | 138 | int sfd = socket( AF_INET, SOCK_STREAM, 0 ); |
133 | struct iwreq iwr; | 139 | struct iwreq iwr; |
134 | memset( &iwr, 0, sizeof( struct iwreq ) ); | 140 | memset( &iwr, 0, sizeof( struct iwreq ) ); |
135 | strcpy( (char*) &iwr.ifr_name, name ); | 141 | strcpy( (char*) &iwr.ifr_name, name ); |
136 | int result = ::ioctl( sfd, SIOCGIWNAME, &iwr ); | 142 | int result = ::ioctl( sfd, SIOCGIWNAME, &iwr ); |
137 | return result != -1; | 143 | return result != -1; |
138 | } | 144 | } |
139 | 145 | ||
140 | /*====================================================================================== | 146 | /*====================================================================================== |
141 | * ONetworkInterface | 147 | * ONetworkInterface |
142 | *======================================================================================*/ | 148 | *======================================================================================*/ |
143 | 149 | ||
144 | ONetworkInterface::ONetworkInterface( QObject* parent, const char* name ) | 150 | ONetworkInterface::ONetworkInterface( QObject* parent, const char* name ) |
145 | :QObject( parent, name ), | 151 | :QObject( parent, name ), |
146 | _sfd( socket( AF_INET, SOCK_DGRAM, 0 ) ), _mon( 0 ) | 152 | _sfd( socket( AF_INET, SOCK_DGRAM, 0 ) ), _mon( 0 ) |
147 | { | 153 | { |
148 | qDebug( "ONetworkInterface::ONetworkInterface()" ); | 154 | qDebug( "ONetworkInterface::ONetworkInterface()" ); |
149 | init(); | 155 | init(); |
150 | } | 156 | } |
151 | 157 | ||
152 | 158 | ||
153 | struct ifreq& ONetworkInterface::ifr() const | 159 | struct ifreq& ONetworkInterface::ifr() const |
154 | { | 160 | { |
155 | return _ifr; | 161 | return _ifr; |
156 | } | 162 | } |
157 | 163 | ||
158 | 164 | ||
159 | void ONetworkInterface::init() | 165 | void ONetworkInterface::init() |
160 | { | 166 | { |
161 | qDebug( "ONetworkInterface::init()" ); | 167 | qDebug( "ONetworkInterface::init()" ); |
162 | 168 | ||
163 | memset( &_ifr, 0, sizeof( struct ifreq ) ); | 169 | memset( &_ifr, 0, sizeof( struct ifreq ) ); |
164 | 170 | ||
165 | if ( _sfd == -1 ) | 171 | if ( _sfd == -1 ) |
166 | { | 172 | { |
167 | qDebug( "ONetworkInterface::init(): Warning - can't get socket for device '%s'", name() ); | 173 | qDebug( "ONetworkInterface::init(): Warning - can't get socket for device '%s'", name() ); |
168 | return; | 174 | return; |
169 | } | 175 | } |
170 | } | 176 | } |
171 | 177 | ||
172 | 178 | ||
173 | bool ONetworkInterface::ioctl( int call, struct ifreq& ifreq ) const | 179 | bool ONetworkInterface::ioctl( int call, struct ifreq& ifreq ) const |
174 | { | 180 | { |
175 | int result = ::ioctl( _sfd, call, &ifreq ); | 181 | int result = ::ioctl( _sfd, call, &ifreq ); |
176 | if ( result == -1 ) | 182 | if ( result == -1 ) |
177 | qDebug( "ONetworkInterface::ioctl (%s) call %d - Status: Failed: %d (%s)", name(), call, result, strerror( errno ) ); | 183 | qDebug( "ONetworkInterface::ioctl (%s) call %d - Status: Failed: %d (%s)", name(), call, result, strerror( errno ) ); |
178 | else | 184 | else |
179 | qDebug( "ONetworkInterface::ioctl (%s) call %d - Status: Ok.", name(), call ); | 185 | qDebug( "ONetworkInterface::ioctl (%s) call %d - Status: Ok.", name(), call ); |
180 | return ( result != -1 ); | 186 | return ( result != -1 ); |
181 | } | 187 | } |
182 | 188 | ||
183 | 189 | ||
184 | bool ONetworkInterface::ioctl( int call ) const | 190 | bool ONetworkInterface::ioctl( int call ) const |
185 | { | 191 | { |
186 | strcpy( _ifr.ifr_name, name() ); | 192 | strcpy( _ifr.ifr_name, name() ); |
187 | return ioctl( call, _ifr ); | 193 | return ioctl( call, _ifr ); |
188 | } | 194 | } |
189 | 195 | ||
190 | 196 | ||
191 | bool ONetworkInterface::isLoopback() const | 197 | bool ONetworkInterface::isLoopback() const |
192 | { | 198 | { |
193 | ioctl( SIOCGIFFLAGS ); | 199 | ioctl( SIOCGIFFLAGS ); |
194 | return _ifr.ifr_flags & IFF_LOOPBACK; | 200 | return _ifr.ifr_flags & IFF_LOOPBACK; |
195 | } | 201 | } |
196 | 202 | ||
197 | 203 | ||
198 | bool ONetworkInterface::setUp( bool b ) | 204 | bool ONetworkInterface::setUp( bool b ) |
199 | { | 205 | { |
200 | ioctl( SIOCGIFFLAGS ); | 206 | ioctl( SIOCGIFFLAGS ); |
201 | if ( b ) _ifr.ifr_flags |= IFF_UP; | 207 | if ( b ) _ifr.ifr_flags |= IFF_UP; |
202 | else _ifr.ifr_flags &= (~IFF_UP); | 208 | else _ifr.ifr_flags &= (~IFF_UP); |
203 | return ioctl( SIOCSIFFLAGS ); | 209 | return ioctl( SIOCSIFFLAGS ); |
204 | } | 210 | } |
205 | 211 | ||
206 | 212 | ||
207 | bool ONetworkInterface::isUp() const | 213 | bool ONetworkInterface::isUp() const |
208 | { | 214 | { |
209 | ioctl( SIOCGIFFLAGS ); | 215 | ioctl( SIOCGIFFLAGS ); |
210 | return _ifr.ifr_flags & IFF_UP; | 216 | return _ifr.ifr_flags & IFF_UP; |
211 | } | 217 | } |
212 | 218 | ||
213 | 219 | ||
220 | void ONetworkInterface::setIPV4Address( const QHostAddress& addr ) | ||
221 | { | ||
222 | struct sockaddr_in *sa = (struct sockaddr_in *) &_ifr.ifr_addr; | ||
223 | sa->sin_family = AF_INET; | ||
224 | sa->sin_port = 0; | ||
225 | sa->sin_addr.s_addr = htonl( addr.ip4Addr() ); | ||
226 | ioctl( SIOCSIFADDR ); | ||
227 | } | ||
228 | |||
229 | |||
214 | QString ONetworkInterface::ipV4Address() const | 230 | QString ONetworkInterface::ipV4Address() const |
215 | { | 231 | { |
216 | if ( ioctl( SIOCGIFADDR ) ) | 232 | if ( ioctl( SIOCGIFADDR ) ) |
217 | { | 233 | { |
218 | struct sockaddr_in *sa = (struct sockaddr_in *) &_ifr.ifr_addr; | 234 | struct sockaddr_in* sa = (struct sockaddr_in *) &_ifr.ifr_addr; |
219 | //FIXME: Use QHostAddress here | 235 | //FIXME: Use QHostAddress here |
220 | return QString( inet_ntoa( sa->sin_addr ) ); | 236 | return QString( inet_ntoa( sa->sin_addr ) ); |
221 | } | 237 | } |
222 | else | 238 | else |
223 | return "<unknown>"; | 239 | return "<unknown>"; |
224 | } | 240 | } |
225 | 241 | ||
226 | 242 | ||
227 | void ONetworkInterface::setMacAddress( const OMacAddress& addr ) | 243 | void ONetworkInterface::setMacAddress( const OMacAddress& addr ) |
228 | { | 244 | { |
229 | _ifr.ifr_hwaddr.sa_family = ARPHRD_ETHER; | 245 | _ifr.ifr_hwaddr.sa_family = ARPHRD_ETHER; |
230 | memcpy( &_ifr.ifr_hwaddr.sa_data, addr.native(), 6 ); | 246 | memcpy( &_ifr.ifr_hwaddr.sa_data, addr.native(), 6 ); |
231 | ioctl( SIOCSIFHWADDR ); | 247 | ioctl( SIOCSIFHWADDR ); |
232 | } | 248 | } |
233 | 249 | ||
234 | 250 | ||
235 | OMacAddress ONetworkInterface::macAddress() const | 251 | OMacAddress ONetworkInterface::macAddress() const |
236 | { | 252 | { |
237 | if ( ioctl( SIOCGIFHWADDR ) ) | 253 | if ( ioctl( SIOCGIFHWADDR ) ) |
238 | { | 254 | { |
239 | return OMacAddress( _ifr ); | 255 | return OMacAddress( _ifr ); |
240 | } | 256 | } |
241 | else | 257 | else |
242 | { | 258 | { |
243 | return OMacAddress::unknown; | 259 | return OMacAddress::unknown; |
244 | } | 260 | } |
245 | } | 261 | } |
246 | 262 | ||
247 | 263 | ||
264 | void ONetworkInterface::setIPV4Netmask( const QHostAddress& addr ) | ||
265 | { | ||
266 | struct sockaddr_in *sa = (struct sockaddr_in *) &_ifr.ifr_addr; | ||
267 | sa->sin_family = AF_INET; | ||
268 | sa->sin_port = 0; | ||
269 | sa->sin_addr.s_addr = htonl( addr.ip4Addr() ); | ||
270 | ioctl( SIOCSIFNETMASK ); | ||
271 | } | ||
272 | |||
273 | |||
274 | QString ONetworkInterface::ipV4Netmask() const | ||
275 | { | ||
276 | if ( ioctl( SIOCGIFNETMASK ) ) | ||
277 | { | ||
278 | struct sockaddr_in* sa = (struct sockaddr_in *) &_ifr.ifr_addr; | ||
279 | //FIXME: Use QHostAddress here | ||
280 | return QString( inet_ntoa( sa->sin_addr ) ); | ||
281 | } | ||
282 | else | ||
283 | return "<unknown>"; | ||
284 | } | ||
285 | |||
286 | |||
248 | int ONetworkInterface::dataLinkType() const | 287 | int ONetworkInterface::dataLinkType() const |
249 | { | 288 | { |
250 | if ( ioctl( SIOCGIFHWADDR ) ) | 289 | if ( ioctl( SIOCGIFHWADDR ) ) |
251 | { | 290 | { |
252 | return _ifr.ifr_hwaddr.sa_family; | 291 | return _ifr.ifr_hwaddr.sa_family; |
253 | } | 292 | } |
254 | else | 293 | else |
255 | { | 294 | { |
256 | return -1; | 295 | return -1; |
257 | } | 296 | } |
258 | } | 297 | } |
259 | 298 | ||
260 | 299 | ||
261 | void ONetworkInterface::setMonitoring( OMonitoringInterface* m ) | 300 | void ONetworkInterface::setMonitoring( OMonitoringInterface* m ) |
262 | { | 301 | { |
263 | _mon = m; | 302 | _mon = m; |
264 | qDebug( "ONetwork::setMonitoring(): Installed monitoring driver '%s' on interface '%s'", (const char*) m->name(), name() ); | 303 | qDebug( "ONetwork::setMonitoring(): Installed monitoring driver '%s' on interface '%s'", (const char*) m->name(), name() ); |
265 | } | 304 | } |
266 | 305 | ||
267 | 306 | ||
268 | OMonitoringInterface* ONetworkInterface::monitoring() const | 307 | OMonitoringInterface* ONetworkInterface::monitoring() const |
269 | { | 308 | { |
270 | return _mon; | 309 | return _mon; |
271 | } | 310 | } |
272 | 311 | ||
273 | 312 | ||
274 | ONetworkInterface::~ONetworkInterface() | 313 | ONetworkInterface::~ONetworkInterface() |
275 | { | 314 | { |
276 | qDebug( "ONetworkInterface::~ONetworkInterface()" ); | 315 | qDebug( "ONetworkInterface::~ONetworkInterface()" ); |
277 | if ( _sfd != -1 ) ::close( _sfd ); | 316 | if ( _sfd != -1 ) ::close( _sfd ); |
278 | } | 317 | } |
279 | 318 | ||
280 | 319 | ||
281 | bool ONetworkInterface::setPromiscuousMode( bool b ) | 320 | bool ONetworkInterface::setPromiscuousMode( bool b ) |
282 | { | 321 | { |
283 | ioctl( SIOCGIFFLAGS ); | 322 | ioctl( SIOCGIFFLAGS ); |
284 | if ( b ) _ifr.ifr_flags |= IFF_PROMISC; | 323 | if ( b ) _ifr.ifr_flags |= IFF_PROMISC; |
285 | else _ifr.ifr_flags &= (~IFF_PROMISC); | 324 | else _ifr.ifr_flags &= (~IFF_PROMISC); |
286 | return ioctl( SIOCSIFFLAGS ); | 325 | return ioctl( SIOCSIFFLAGS ); |
287 | } | 326 | } |
288 | 327 | ||
289 | 328 | ||
290 | bool ONetworkInterface::promiscuousMode() const | 329 | bool ONetworkInterface::promiscuousMode() const |
291 | { | 330 | { |
292 | ioctl( SIOCGIFFLAGS ); | 331 | ioctl( SIOCGIFFLAGS ); |
293 | return _ifr.ifr_flags & IFF_PROMISC; | 332 | return _ifr.ifr_flags & IFF_PROMISC; |
294 | } | 333 | } |
295 | 334 | ||
296 | 335 | ||
297 | bool ONetworkInterface::isWireless() const | 336 | bool ONetworkInterface::isWireless() const |
298 | { | 337 | { |
299 | return ioctl( SIOCGIWNAME ); | 338 | return ioctl( SIOCGIWNAME ); |
300 | } | 339 | } |
301 | 340 | ||
302 | 341 | ||
303 | /*====================================================================================== | 342 | /*====================================================================================== |
304 | * OChannelHopper | 343 | * OChannelHopper |
305 | *======================================================================================*/ | 344 | *======================================================================================*/ |
306 | 345 | ||
307 | OChannelHopper::OChannelHopper( OWirelessNetworkInterface* iface ) | 346 | OChannelHopper::OChannelHopper( OWirelessNetworkInterface* iface ) |
308 | :QObject( 0, "Mickey's funky hopper" ), | 347 | :QObject( 0, "Mickey's funky hopper" ), |
309 | _iface( iface ), _interval( 0 ), _tid( 0 ) | 348 | _iface( iface ), _interval( 0 ), _tid( 0 ) |
310 | { | 349 | { |
311 | int _maxChannel = iface->channels()+1; | 350 | int _maxChannel = iface->channels()+1; |
312 | // generate fancy hopping sequence honoring the device capabilities | 351 | // generate fancy hopping sequence honoring the device capabilities |
313 | if ( _maxChannel >= 1 ) _channels.append( 1 ); | 352 | if ( _maxChannel >= 1 ) _channels.append( 1 ); |
314 | if ( _maxChannel >= 7 ) _channels.append( 7 ); | 353 | if ( _maxChannel >= 7 ) _channels.append( 7 ); |
315 | if ( _maxChannel >= 13 ) _channels.append( 13 ); | 354 | if ( _maxChannel >= 13 ) _channels.append( 13 ); |
316 | if ( _maxChannel >= 2 ) _channels.append( 2 ); | 355 | if ( _maxChannel >= 2 ) _channels.append( 2 ); |
317 | if ( _maxChannel >= 8 ) _channels.append( 8 ); | 356 | if ( _maxChannel >= 8 ) _channels.append( 8 ); |
318 | if ( _maxChannel >= 3 ) _channels.append( 3 ); | 357 | if ( _maxChannel >= 3 ) _channels.append( 3 ); |
319 | if ( _maxChannel >= 14 ) _channels.append( 14 ); | 358 | if ( _maxChannel >= 14 ) _channels.append( 14 ); |
320 | if ( _maxChannel >= 9 ) _channels.append( 9 ); | 359 | if ( _maxChannel >= 9 ) _channels.append( 9 ); |
321 | if ( _maxChannel >= 4 ) _channels.append( 4 ); | 360 | if ( _maxChannel >= 4 ) _channels.append( 4 ); |
322 | if ( _maxChannel >= 10 ) _channels.append( 10 ); | 361 | if ( _maxChannel >= 10 ) _channels.append( 10 ); |
323 | if ( _maxChannel >= 5 ) _channels.append( 5 ); | 362 | if ( _maxChannel >= 5 ) _channels.append( 5 ); |
324 | if ( _maxChannel >= 11 ) _channels.append( 11 ); | 363 | if ( _maxChannel >= 11 ) _channels.append( 11 ); |
325 | if ( _maxChannel >= 6 ) _channels.append( 6 ); | 364 | if ( _maxChannel >= 6 ) _channels.append( 6 ); |
326 | if ( _maxChannel >= 12 ) _channels.append( 12 ); | 365 | if ( _maxChannel >= 12 ) _channels.append( 12 ); |
327 | _channel = _channels.begin(); | 366 | _channel = _channels.begin(); |
328 | 367 | ||
329 | } | 368 | } |
330 | 369 | ||
331 | 370 | ||
332 | OChannelHopper::~OChannelHopper() | 371 | OChannelHopper::~OChannelHopper() |
333 | { | 372 | { |
334 | } | 373 | } |
335 | 374 | ||
336 | 375 | ||
337 | bool OChannelHopper::isActive() const | 376 | bool OChannelHopper::isActive() const |
338 | { | 377 | { |
339 | return _tid; | 378 | return _tid; |
340 | } | 379 | } |
341 | 380 | ||
342 | 381 | ||
343 | int OChannelHopper::channel() const | 382 | int OChannelHopper::channel() const |
344 | { | 383 | { |
345 | return *_channel; | 384 | return *_channel; |
346 | } | 385 | } |
347 | 386 | ||
348 | 387 | ||
349 | void OChannelHopper::timerEvent( QTimerEvent* ) | 388 | void OChannelHopper::timerEvent( QTimerEvent* ) |
350 | { | 389 | { |
351 | _iface->setChannel( *_channel ); | 390 | _iface->setChannel( *_channel ); |
352 | emit( hopped( *_channel ) ); | 391 | emit( hopped( *_channel ) ); |
353 | qDebug( "OChannelHopper::timerEvent(): set channel %d on interface '%s'", | 392 | qDebug( "OChannelHopper::timerEvent(): set channel %d on interface '%s'", |
354 | *_channel, (const char*) _iface->name() ); | 393 | *_channel, (const char*) _iface->name() ); |
355 | if ( ++_channel == _channels.end() ) _channel = _channels.begin(); | 394 | if ( ++_channel == _channels.end() ) _channel = _channels.begin(); |
356 | } | 395 | } |
357 | 396 | ||
358 | 397 | ||
359 | void OChannelHopper::setInterval( int interval ) | 398 | void OChannelHopper::setInterval( int interval ) |
360 | { | 399 | { |
361 | if ( interval == _interval ) | 400 | if ( interval == _interval ) |
362 | return; | 401 | return; |
363 | 402 | ||
364 | if ( _interval ) | 403 | if ( _interval ) |
365 | killTimer( _tid ); | 404 | killTimer( _tid ); |
366 | 405 | ||
367 | _tid = 0; | 406 | _tid = 0; |
368 | _interval = interval; | 407 | _interval = interval; |
369 | 408 | ||
370 | if ( _interval ) | 409 | if ( _interval ) |
371 | { | 410 | { |
372 | _tid = startTimer( interval ); | 411 | _tid = startTimer( interval ); |
373 | } | 412 | } |
374 | } | 413 | } |
375 | 414 | ||
376 | 415 | ||
377 | int OChannelHopper::interval() const | 416 | int OChannelHopper::interval() const |
378 | { | 417 | { |
379 | return _interval; | 418 | return _interval; |
380 | } | 419 | } |
381 | 420 | ||
382 | 421 | ||
383 | /*====================================================================================== | 422 | /*====================================================================================== |
384 | * OWirelessNetworkInterface | 423 | * OWirelessNetworkInterface |
385 | *======================================================================================*/ | 424 | *======================================================================================*/ |
386 | 425 | ||
387 | OWirelessNetworkInterface::OWirelessNetworkInterface( QObject* parent, const char* name ) | 426 | OWirelessNetworkInterface::OWirelessNetworkInterface( QObject* parent, const char* name ) |
388 | :ONetworkInterface( parent, name ), _hopper( 0 ) | 427 | :ONetworkInterface( parent, name ), _hopper( 0 ) |
389 | { | 428 | { |
390 | qDebug( "OWirelessNetworkInterface::OWirelessNetworkInterface()" ); | 429 | qDebug( "OWirelessNetworkInterface::OWirelessNetworkInterface()" ); |
391 | init(); | 430 | init(); |
392 | } | 431 | } |
393 | 432 | ||
394 | 433 | ||
395 | OWirelessNetworkInterface::~OWirelessNetworkInterface() | 434 | OWirelessNetworkInterface::~OWirelessNetworkInterface() |
396 | { | 435 | { |
397 | } | 436 | } |
398 | 437 | ||
399 | 438 | ||
400 | struct iwreq& OWirelessNetworkInterface::iwr() const | 439 | struct iwreq& OWirelessNetworkInterface::iwr() const |
401 | { | 440 | { |
402 | return _iwr; | 441 | return _iwr; |
403 | } | 442 | } |
404 | 443 | ||
405 | 444 | ||
406 | void OWirelessNetworkInterface::init() | 445 | void OWirelessNetworkInterface::init() |
407 | { | 446 | { |
408 | qDebug( "OWirelessNetworkInterface::init()" ); | 447 | qDebug( "OWirelessNetworkInterface::init()" ); |
409 | memset( &_iwr, 0, sizeof( struct iwreq ) ); | 448 | memset( &_iwr, 0, sizeof( struct iwreq ) ); |
410 | buildChannelList(); | 449 | buildChannelList(); |
411 | buildPrivateList(); | 450 | buildPrivateList(); |
412 | } | 451 | } |
413 | 452 | ||
414 | 453 | ||
415 | QString OWirelessNetworkInterface::associatedAP() const | 454 | QString OWirelessNetworkInterface::associatedAP() const |
416 | { | 455 | { |
417 | //FIXME: use OMacAddress | 456 | //FIXME: use OMacAddress |
418 | QString mac; | 457 | QString mac; |
419 | 458 | ||
420 | if ( ioctl( SIOCGIWAP ) ) | 459 | if ( ioctl( SIOCGIWAP ) ) |
421 | { | 460 | { |
422 | mac.sprintf( "%.2X:%.2X:%.2X:%.2X:%.2X:%.2X", | 461 | mac.sprintf( "%.2X:%.2X:%.2X:%.2X:%.2X:%.2X", |
423 | _ifr.ifr_hwaddr.sa_data[0]&0xff, | 462 | _ifr.ifr_hwaddr.sa_data[0]&0xff, |
424 | _ifr.ifr_hwaddr.sa_data[1]&0xff, | 463 | _ifr.ifr_hwaddr.sa_data[1]&0xff, |
425 | _ifr.ifr_hwaddr.sa_data[2]&0xff, | 464 | _ifr.ifr_hwaddr.sa_data[2]&0xff, |
426 | _ifr.ifr_hwaddr.sa_data[3]&0xff, | 465 | _ifr.ifr_hwaddr.sa_data[3]&0xff, |
427 | _ifr.ifr_hwaddr.sa_data[4]&0xff, | 466 | _ifr.ifr_hwaddr.sa_data[4]&0xff, |
428 | _ifr.ifr_hwaddr.sa_data[5]&0xff ); | 467 | _ifr.ifr_hwaddr.sa_data[5]&0xff ); |
429 | } | 468 | } |
430 | else | 469 | else |
431 | { | 470 | { |
432 | mac = "<Unknown>"; | 471 | mac = "<Unknown>"; |
433 | } | 472 | } |
434 | return mac; | 473 | return mac; |
435 | } | 474 | } |
436 | 475 | ||
437 | 476 | ||
438 | void OWirelessNetworkInterface::buildChannelList() | 477 | void OWirelessNetworkInterface::buildChannelList() |
439 | { | 478 | { |
diff --git a/libopie2/opienet/onetwork.h b/libopie2/opienet/onetwork.h index db8e702..2348bbc 100644 --- a/libopie2/opienet/onetwork.h +++ b/libopie2/opienet/onetwork.h | |||
@@ -1,392 +1,413 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the Opie Project | 2 | This file is part of the Opie Project |
3 | Copyright (C) 2003 by the Wellenreiter team: | 3 | Copyright (C) 2003 by the Wellenreiter team: |
4 | Martin J. Muench <mjm@remote-exploit.org> | 4 | Martin J. Muench <mjm@remote-exploit.org> |
5 | Max Moser <mmo@remote-exploit.org | 5 | Max Moser <mmo@remote-exploit.org |
6 | Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> | 6 | Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> |
7 | =. | 7 | =. |
8 | .=l. | 8 | .=l. |
9 | .>+-= | 9 | .>+-= |
10 | _;:, .> :=|. This program is free software; you can | 10 | _;:, .> :=|. This program is free software; you can |
11 | .> <`_, > . <= redistribute it and/or modify it under | 11 | .> <`_, > . <= redistribute it and/or modify it under |
12 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public | 12 | :`=1 )Y*s>-.-- : the terms of the GNU Library General Public |
13 | .="- .-=="i, .._ License as published by the Free Software | 13 | .="- .-=="i, .._ License as published by the Free Software |
14 | - . .-<_> .<> Foundation; either version 2 of the License, | 14 | - . .-<_> .<> Foundation; either version 2 of the License, |
15 | ._= =} : or (at your option) any later version. | 15 | ._= =} : or (at your option) any later version. |
16 | .%`+i> _;_. | 16 | .%`+i> _;_. |
17 | .i_,=:_. -<s. This program is distributed in the hope that | 17 | .i_,=:_. -<s. This program is distributed in the hope that |
18 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; | 18 | + . -:. = it will be useful, but WITHOUT ANY WARRANTY; |
19 | : .. .:, . . . without even the implied warranty of | 19 | : .. .:, . . . without even the implied warranty of |
20 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A | 20 | =_ + =;=|` MERCHANTABILITY or FITNESS FOR A |
21 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU | 21 | _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU |
22 | ..}^=.= = ; Library General Public License for more | 22 | ..}^=.= = ; Library General Public License for more |
23 | ++= -. .` .: details. | 23 | ++= -. .` .: details. |
24 | : = ...= . :.=- | 24 | : = ...= . :.=- |
25 | -. .:....=;==+<; You should have received a copy of the GNU | 25 | -. .:....=;==+<; You should have received a copy of the GNU |
26 | -_. . . )=. = Library General Public License along with | 26 | -_. . . )=. = Library General Public License along with |
27 | -- :-=` this library; see the file COPYING.LIB. | 27 | -- :-=` this library; see the file COPYING.LIB. |
28 | If not, write to the Free Software Foundation, | 28 | If not, write to the Free Software Foundation, |
29 | Inc., 59 Temple Place - Suite 330, | 29 | Inc., 59 Temple Place - Suite 330, |
30 | Boston, MA 02111-1307, USA. | 30 | Boston, MA 02111-1307, USA. |
31 | 31 | ||
32 | */ | 32 | */ |
33 | 33 | ||
34 | #ifndef ONETWORK_H | 34 | #ifndef ONETWORK_H |
35 | #define ONETWORK_H | 35 | #define ONETWORK_H |
36 | 36 | ||
37 | /* QT */ | 37 | /* QT */ |
38 | 38 | ||
39 | #include <qvaluelist.h> | 39 | #include <qvaluelist.h> |
40 | #include <qdict.h> | 40 | #include <qdict.h> |
41 | #include <qmap.h> | 41 | #include <qmap.h> |
42 | #include <qobject.h> | 42 | #include <qobject.h> |
43 | #include <qhostaddress.h> | 43 | #include <qhostaddress.h> |
44 | 44 | ||
45 | /* OPIE */ | 45 | /* OPIE */ |
46 | 46 | ||
47 | #include <opie2/onetutils.h> | 47 | #include <opie2/onetutils.h> |
48 | 48 | ||
49 | #ifndef IFNAMSIZ | 49 | #ifndef IFNAMSIZ |
50 | #define IFNAMSIZ 16 | 50 | #define IFNAMSIZ 16 |
51 | #endif | 51 | #endif |
52 | #ifndef IW_MAX_PRIV_DEF | 52 | #ifndef IW_MAX_PRIV_DEF |
53 | #define IW_MAX_PRIV_DEF 128 | 53 | #define IW_MAX_PRIV_DEF 128 |
54 | #endif | 54 | #endif |
55 | 55 | ||
56 | // ML: Yeah, I hate to include kernel headers, but it's necessary here | 56 | // ML: Yeah, I hate to include kernel headers, but it's necessary here |
57 | // ML: Here comes an ugly hack to prevent <linux/wireless.h> including <linux/if.h> | 57 | // ML: Here comes an ugly hack to prevent <linux/wireless.h> including <linux/if.h> |
58 | // ML: which conflicts with the user header <net/if.h> | 58 | // ML: which conflicts with the user header <net/if.h> |
59 | // ML: We really a user header for the Wireless Extensions, something like <net/wireless.h> | 59 | // ML: We really need a user header for the Wireless Extensions, something like <net/wireless.h> |
60 | // ML: I will drop Jean an mail on that subject | 60 | // ML: I will drop Jean a mail on that subject |
61 | 61 | ||
62 | #include <net/if.h> | 62 | #include <net/if.h> |
63 | #define _LINUX_IF_H | 63 | #define _LINUX_IF_H |
64 | #include <linux/wireless.h> | 64 | #include <linux/wireless.h> |
65 | 65 | ||
66 | class ONetworkInterface; | 66 | class ONetworkInterface; |
67 | class OWirelessNetworkInterface; | 67 | class OWirelessNetworkInterface; |
68 | class OChannelHopper; | 68 | class OChannelHopper; |
69 | class OMonitoringInterface; | 69 | class OMonitoringInterface; |
70 | 70 | ||
71 | /*====================================================================================== | 71 | /*====================================================================================== |
72 | * ONetwork | 72 | * ONetwork |
73 | *======================================================================================*/ | 73 | *======================================================================================*/ |
74 | 74 | ||
75 | /** | 75 | /** |
76 | * @brief A container class for all network devices. | 76 | * @brief A container class for all network interfaces |
77 | * | 77 | * |
78 | * This class provides access to all available network devices of your computer. | 78 | * This class provides access to all available network interfaces of your computer. |
79 | * @author Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> | 79 | * @author Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> |
80 | */ | 80 | */ |
81 | class ONetwork : public QObject | 81 | class ONetwork : public QObject |
82 | { | 82 | { |
83 | Q_OBJECT | 83 | Q_OBJECT |
84 | 84 | ||
85 | public: | 85 | public: |
86 | typedef QDict<ONetworkInterface> InterfaceMap; | 86 | typedef QDict<ONetworkInterface> InterfaceMap; |
87 | typedef QDictIterator<ONetworkInterface> InterfaceIterator; | 87 | typedef QDictIterator<ONetworkInterface> InterfaceIterator; |
88 | 88 | ||
89 | public: | 89 | public: |
90 | /** | 90 | /** |
91 | * @returns the number of available interfaces | ||
92 | */ | ||
93 | int count() const; | ||
94 | /** | ||
91 | * @returns a pointer to the (one and only) @ref ONetwork instance. | 95 | * @returns a pointer to the (one and only) @ref ONetwork instance. |
92 | */ | 96 | */ |
93 | static ONetwork* instance(); | 97 | static ONetwork* instance(); |
94 | /** | 98 | /** |
95 | * @returns an iterator usable for iterating through all network interfaces. | 99 | * @returns an iterator usable for iterating through all network interfaces. |
96 | */ | 100 | */ |
97 | InterfaceIterator iterator() const; | 101 | InterfaceIterator iterator() const; |
98 | /** | 102 | /** |
99 | * @returns true, if the @p interface supports the wireless extension protocol. | 103 | * @returns true, if the @p interface supports the wireless extension protocol. |
100 | */ | 104 | */ |
101 | // FIXME QString? -zecke | 105 | // FIXME QString? -zecke |
102 | bool isWirelessInterface( const char* interface ) const; | 106 | bool isWirelessInterface( const char* interface ) const; |
103 | /** | 107 | /** |
104 | * @returns a pointer to the @ref ONetworkInterface object for the specified @p interface or 0, if not found | 108 | * @returns a pointer to the @ref ONetworkInterface object for the specified @p interface or 0, if not found |
105 | * @see ONetworkInterface | 109 | * @see ONetworkInterface |
106 | */ | 110 | */ |
107 | // FIXME: const QString& is prefered over QString!!! -zecke | 111 | // FIXME: const QString& is prefered over QString!!! -zecke |
108 | ONetworkInterface* interface( const QString& interface ) const; | 112 | ONetworkInterface* interface( const QString& interface ) const; |
113 | /** | ||
114 | * @internal Rebuild the internal interface database | ||
115 | * @note Sometimes it might be useful to call this from client code, | ||
116 | * e.g. after cardctl insert | ||
117 | */ | ||
118 | void synchronize(); | ||
109 | 119 | ||
110 | protected: | 120 | protected: |
111 | ONetwork(); | 121 | ONetwork(); |
112 | void synchronize(); | ||
113 | 122 | ||
114 | private: | 123 | private: |
115 | static ONetwork* _instance; | 124 | static ONetwork* _instance; |
116 | InterfaceMap _interfaces; | 125 | InterfaceMap _interfaces; |
117 | }; | 126 | }; |
118 | 127 | ||
119 | 128 | ||
120 | /*====================================================================================== | 129 | /*====================================================================================== |
121 | * ONetworkInterface | 130 | * ONetworkInterface |
122 | *======================================================================================*/ | 131 | *======================================================================================*/ |
123 | 132 | ||
124 | /** | 133 | /** |
125 | * @brief A network interface wrapper. | 134 | * @brief A network interface wrapper. |
126 | * | 135 | * |
127 | * This class provides a wrapper for a network interface. All the cumbersume details of | 136 | * This class provides a wrapper for a network interface. All the cumbersume details of |
128 | * Linux ioctls are hidden under a convenient high-level interface. | 137 | * Linux ioctls are hidden under a convenient high-level interface. |
129 | * @warning Most of the setting methods contained in this class require the appropriate | 138 | * @warning Most of the setting methods contained in this class require the appropriate |
130 | * process permissions to work. | 139 | * process permissions to work. |
131 | * @author Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> | 140 | * @author Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> |
132 | */ | 141 | */ |
133 | class ONetworkInterface : public QObject | 142 | class ONetworkInterface : public QObject |
134 | { | 143 | { |
135 | friend class OMonitoringInterface; | 144 | friend class OMonitoringInterface; |
136 | friend class OCiscoMonitoringInterface; | 145 | friend class OCiscoMonitoringInterface; |
137 | friend class OWlanNGMonitoringInterface; | 146 | friend class OWlanNGMonitoringInterface; |
138 | friend class OHostAPMonitoringInterface; | 147 | friend class OHostAPMonitoringInterface; |
139 | friend class OOrinocoMonitoringInterface; | 148 | friend class OOrinocoMonitoringInterface; |
140 | 149 | ||
141 | public: | 150 | public: |
142 | /** | 151 | /** |
143 | * Constructor. Normally you don't create @ref ONetworkInterface objects yourself, | 152 | * Constructor. Normally you don't create @ref ONetworkInterface objects yourself, |
144 | * but access them via @ref ONetwork::interface(). | 153 | * but access them via @ref ONetwork::interface(). |
145 | */ | 154 | */ |
146 | ONetworkInterface( QObject* parent, const char* name ); | 155 | ONetworkInterface( QObject* parent, const char* name ); |
147 | /** | 156 | /** |
148 | * Destructor. | 157 | * Destructor. |
149 | */ | 158 | */ |
150 | virtual ~ONetworkInterface(); | 159 | virtual ~ONetworkInterface(); |
151 | /** | 160 | /** |
152 | * Associates a @a monitoring interface with this network interface. | 161 | * Associates a @a monitoring interface with this network interface. |
153 | * @note This is currently only useful with @ref OWirelessNetworkInterface objects. | 162 | * @note This is currently only useful with @ref OWirelessNetworkInterface objects. |
154 | */ | 163 | */ |
155 | void setMonitoring( OMonitoringInterface* monitoring ); | 164 | void setMonitoring( OMonitoringInterface* monitoring ); |
156 | /** | 165 | /** |
157 | * @returns the currently associated monitoring interface or 0, if no monitoring is associated. | 166 | * @returns the currently associated monitoring interface or 0, if no monitoring is associated. |
158 | */ | 167 | */ |
159 | OMonitoringInterface* monitoring() const; | 168 | OMonitoringInterface* monitoring() const; |
160 | /** | 169 | /** |
161 | * Setting an interface to promiscuous mode enables the device to receive | 170 | * Setting an interface to promiscuous mode enables the device to receive |
162 | * all packets on the shared medium - as opposed to packets which are addressed to this interface. | 171 | * all packets on the shared medium - as opposed to packets which are addressed to this interface. |
163 | */ | 172 | */ |
164 | bool setPromiscuousMode( bool ); | 173 | bool setPromiscuousMode( bool ); |
165 | /** | 174 | /** |
166 | * @returns true if the interface is set to promiscuous mode. | 175 | * @returns true if the interface is set to promiscuous mode. |
167 | */ | 176 | */ |
168 | bool promiscuousMode() const; | 177 | bool promiscuousMode() const; |
169 | /** | 178 | /** |
170 | * Setting an interface to up enables it to receive packets. | 179 | * Setting an interface to up enables it to receive packets. |
171 | */ | 180 | */ |
172 | bool setUp( bool ); | 181 | bool setUp( bool ); |
173 | /** | 182 | /** |
174 | * @returns true if the interface is up. | 183 | * @returns true if the interface is up. |
175 | */ | 184 | */ |
176 | bool isUp() const; | 185 | bool isUp() const; |
177 | /* | 186 | /** |
178 | * @returns true if the interface is a loopback interface. | 187 | * @returns true if the interface is a loopback interface. |
179 | */ | 188 | */ |
180 | bool isLoopback() const; | 189 | bool isLoopback() const; |
181 | /* | 190 | /** |
182 | * @returns true if the interface is featuring supports the wireless extension protocol. | 191 | * @returns true if the interface is featuring supports the wireless extension protocol. |
183 | */ | 192 | */ |
184 | bool isWireless() const; | 193 | bool isWireless() const; |
185 | /* | 194 | /** |
186 | * @returns the IPv4 address associated with this interface. | 195 | * Associate the IP address @ addr with the interface. |
196 | */ | ||
197 | void setIPV4Address( const QHostAddress& addr ); | ||
198 | /** | ||
199 | * @returns the IPv4 address associated with the interface. | ||
187 | */ | 200 | */ |
188 | QString ipV4Address() const; | 201 | QString ipV4Address() const; |
189 | /* | 202 | /** |
190 | * Associate the MAC address @a addr with the interface. | 203 | * Associate the MAC address @a addr with the interface. |
191 | * @note It can be necessary to shut down the interface prior to calling this method. | 204 | * @note It can be necessary to shut down the interface prior to calling this method. |
192 | * @warning This is not supported by all drivers. | 205 | * @warning This is not supported by all drivers. |
193 | */ | 206 | */ |
194 | void setMacAddress( const OMacAddress& addr ); | 207 | void setMacAddress( const OMacAddress& addr ); |
195 | /* | 208 | /** |
196 | * @returns the MAC address associated with this interface. | 209 | * @returns the MAC address associated with the interface. |
197 | */ | 210 | */ |
198 | OMacAddress macAddress() const; | 211 | OMacAddress macAddress() const; |
199 | /* | 212 | /** |
200 | * @returns the data link type currently associated with this interface. | 213 | * Associate the IPv4 @a netmask with the interface. |
214 | */ | ||
215 | void setIPV4Netmask( const QHostAddress& netmask ); | ||
216 | /** | ||
217 | * @returns the IPv4 netmask associated with the interface. | ||
218 | */ | ||
219 | QString ipV4Netmask() const; | ||
220 | /** | ||
221 | * @returns the data link type currently associated with the interface. | ||
201 | * @see #include <net/if_arp.h> for possible values. | 222 | * @see #include <net/if_arp.h> for possible values. |
202 | */ | 223 | */ |
203 | int dataLinkType() const; | 224 | int dataLinkType() const; |
204 | 225 | ||
205 | protected: | 226 | protected: |
206 | const int _sfd; | 227 | const int _sfd; |
207 | mutable ifreq _ifr; | 228 | mutable ifreq _ifr; |
208 | OMonitoringInterface* _mon; | 229 | OMonitoringInterface* _mon; |
209 | 230 | ||
210 | protected: | 231 | protected: |
211 | struct ifreq& ifr() const; | 232 | struct ifreq& ifr() const; |
212 | virtual void init(); | 233 | virtual void init(); |
213 | bool ioctl( int call ) const; | 234 | bool ioctl( int call ) const; |
214 | bool ioctl( int call, struct ifreq& ) const; | 235 | bool ioctl( int call, struct ifreq& ) const; |
215 | }; | 236 | }; |
216 | 237 | ||
217 | /*====================================================================================== | 238 | /*====================================================================================== |
218 | * OChannelHopper | 239 | * OChannelHopper |
219 | *======================================================================================*/ | 240 | *======================================================================================*/ |
220 | 241 | ||
221 | /** | 242 | /** |
222 | * @brief A radio frequency channel hopper. | 243 | * @brief A radio frequency channel hopper. |
223 | * | 244 | * |
224 | * This class provides a channel hopper for radio frequencies. A channel hopper frequently | 245 | * This class provides a channel hopper for radio frequencies. A channel hopper frequently |
225 | * changes the radio frequency channel of its associated @ref OWirelessNetworkInterface. | 246 | * changes the radio frequency channel of its associated @ref OWirelessNetworkInterface. |
226 | * This is necessary when in monitoring mode and scanning for other devices, because | 247 | * This is necessary when in monitoring mode and scanning for other devices, because |
227 | * the radio frequency hardware can only detect packets sent on the same frequency. | 248 | * the radio frequency hardware can only detect packets sent on the same frequency. |
228 | * @author Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> | 249 | * @author Michael 'Mickey' Lauer <mickey@tm.informatik.uni-frankfurt.de> |
229 | */ | 250 | */ |
230 | class OChannelHopper : public QObject | 251 | class OChannelHopper : public QObject |
231 | { | 252 | { |
232 | Q_OBJECT | 253 | Q_OBJECT |
233 | 254 | ||
234 | public: | 255 | public: |
235 | OChannelHopper( OWirelessNetworkInterface* ); | 256 | OChannelHopper( OWirelessNetworkInterface* ); |
236 | virtual ~OChannelHopper(); | 257 | virtual ~OChannelHopper(); |
237 | bool isActive() const; | 258 | bool isActive() const; |
238 | int channel() const; | 259 | int channel() const; |
239 | virtual void timerEvent( QTimerEvent* ); | 260 | virtual void timerEvent( QTimerEvent* ); |
240 | void setInterval( int ); | 261 | void setInterval( int ); |
241 | int interval() const; | 262 | int interval() const; |
242 | 263 | ||
243 | signals: | 264 | signals: |
244 | void hopped( int ); | 265 | void hopped( int ); |
245 | 266 | ||
246 | private: | 267 | private: |
247 | OWirelessNetworkInterface* _iface; | 268 | OWirelessNetworkInterface* _iface; |
248 | int _interval; | 269 | int _interval; |
249 | int _tid; | 270 | int _tid; |
250 | QValueList<int> _channels; | 271 | QValueList<int> _channels; |
251 | QValueList<int>::Iterator _channel; | 272 | QValueList<int>::Iterator _channel; |
252 | }; | 273 | }; |
253 | 274 | ||
254 | 275 | ||
255 | /*====================================================================================== | 276 | /*====================================================================================== |
256 | * OWirelessNetworkInterface | 277 | * OWirelessNetworkInterface |
257 | *======================================================================================*/ | 278 | *======================================================================================*/ |
258 | 279 | ||
259 | /** | 280 | /** |
260 | * @brief A network interface wrapper for interfaces supporting the wireless extensions protocol. | 281 | * @brief A network interface wrapper for interfaces supporting the wireless extensions protocol. |
261 | * | 282 | * |
262 | * This class provides a high-level encapsulation of the Linux wireless extension API. | 283 | * This class provides a high-level encapsulation of the Linux wireless extension API. |
263 | */ | 284 | */ |
264 | class OWirelessNetworkInterface : public ONetworkInterface | 285 | class OWirelessNetworkInterface : public ONetworkInterface |
265 | { | 286 | { |
266 | friend class OMonitoringInterface; | 287 | friend class OMonitoringInterface; |
267 | friend class OCiscoMonitoringInterface; | 288 | friend class OCiscoMonitoringInterface; |
268 | friend class OWlanNGMonitoringInterface; | 289 | friend class OWlanNGMonitoringInterface; |
269 | friend class OHostAPMonitoringInterface; | 290 | friend class OHostAPMonitoringInterface; |
270 | friend class OOrinocoMonitoringInterface; | 291 | friend class OOrinocoMonitoringInterface; |
271 | 292 | ||
272 | friend class OPrivateIOCTL; | 293 | friend class OPrivateIOCTL; |
273 | 294 | ||
274 | public: | 295 | public: |
275 | enum Mode { AdHoc, Managed, Monitor }; | 296 | enum Mode { AdHoc, Managed, Monitor }; |
276 | 297 | ||
277 | /** | 298 | /** |
278 | * Constructor. | 299 | * Constructor. |
279 | */ | 300 | */ |
280 | OWirelessNetworkInterface( QObject* parent, const char* name ); | 301 | OWirelessNetworkInterface( QObject* parent, const char* name ); |
281 | /** | 302 | /** |
282 | * Destructor. | 303 | * Destructor. |
283 | */ | 304 | */ |
284 | virtual ~OWirelessNetworkInterface(); | 305 | virtual ~OWirelessNetworkInterface(); |
285 | /** | 306 | /** |
286 | * Setting the @a channel of the interface changes the radio frequency (RF) | 307 | * Setting the @a channel of the interface changes the radio frequency (RF) |
287 | * of the corresponding wireless network device. | 308 | * of the corresponding wireless network device. |
288 | */ | 309 | */ |
289 | virtual void setChannel( int channel ) const; | 310 | virtual void setChannel( int channel ) const; |
290 | /** | 311 | /** |
291 | * @returns the channel index of the current radio frequency. | 312 | * @returns the channel index of the current radio frequency. |
292 | */ | 313 | */ |
293 | virtual int channel() const; | 314 | virtual int channel() const; |
294 | /** | 315 | /** |
295 | * @returns the current radio frequency (in MHz). | 316 | * @returns the current radio frequency (in MHz). |
296 | */ | 317 | */ |
297 | virtual double frequency() const; | 318 | virtual double frequency() const; |
298 | /** | 319 | /** |
299 | * @returns the number of radio frequency channels for the | 320 | * @returns the number of radio frequency channels for the |
300 | * corresponding wireless network device. | 321 | * corresponding wireless network device. |
301 | * @note European devices usually have 14 channels, while American typically feature 11 channels. | 322 | * @note European devices usually have 14 channels, while American typically feature 11 channels. |
302 | */ | 323 | */ |
303 | virtual int channels() const; | 324 | virtual int channels() const; |
304 | //virtual double frequency(int) const; | 325 | //virtual double frequency(int) const; |
305 | 326 | ||
306 | virtual void setMode( Mode ) {}; //FIXME: Implement and document this | 327 | virtual void setMode( Mode ) {}; //FIXME: Implement and document this |
307 | virtual bool mode() const {}; //FIXME: Implement and document this | 328 | virtual bool mode() const {}; //FIXME: Implement and document this |
308 | 329 | ||
309 | /** | 330 | /** |
310 | * Setting the monitor mode on a wireless network interface enables | 331 | * Setting the monitor mode on a wireless network interface enables |
311 | * listening to IEEE 802.11 data and management frames which normally | 332 | * listening to IEEE 802.11 data and management frames which normally |
312 | * are handled by the device firmware. This can be used to detect | 333 | * are handled by the device firmware. This can be used to detect |
313 | * other wireless network devices, e.g. Access Points or Ad-hoc stations. | 334 | * other wireless network devices, e.g. Access Points or Ad-hoc stations. |
314 | * @warning Standard wireless network drives don't support the monitor mode. | 335 | * @warning Standard wireless network drives don't support the monitor mode. |
315 | * @warning You need a patched driver for this to work. | 336 | * @warning You need a patched driver for this to work. |
316 | * @note Enabling the monitor mode is highly driver dependent and requires | 337 | * @note Enabling the monitor mode is highly driver dependent and requires |
317 | * the proper @ref OMonitoringInterface to be associated with the interface. | 338 | * the proper @ref OMonitoringInterface to be associated with the interface. |
318 | * @see OMonitoringInterface | 339 | * @see OMonitoringInterface |
319 | */ | 340 | */ |
320 | virtual void setMonitorMode( bool ); | 341 | virtual void setMonitorMode( bool ); |
321 | /** | 342 | /** |
322 | * @returns true if the device is listening in IEEE 802.11 monitor mode | 343 | * @returns true if the device is listening in IEEE 802.11 monitor mode |
323 | */ | 344 | */ |
324 | virtual bool monitorMode() const; | 345 | virtual bool monitorMode() const; |
325 | /** | 346 | /** |
326 | * Set the channel hopping @a interval. An @a interval of 0 disables channel hopping. | 347 | * Set the channel hopping @a interval. An @a interval of 0 disables channel hopping. |
327 | * @see OChannelHopper | 348 | * @see OChannelHopper |
328 | */ | 349 | */ |
329 | virtual void setChannelHopping( int interval = 0 ); | 350 | virtual void setChannelHopping( int interval = 0 ); |
330 | /** | 351 | /** |
331 | * @returns the channel hopping interval or 0, if channel hopping is disabled. | 352 | * @returns the channel hopping interval or 0, if channel hopping is disabled. |
332 | */ | 353 | */ |
333 | virtual int channelHopping() const; | 354 | virtual int channelHopping() const; |
334 | /** | 355 | /** |
335 | * @returns the @ref OChannelHopper of this interface or 0, if channel hopping has not been activated before | 356 | * @returns the @ref OChannelHopper of this interface or 0, if channel hopping has not been activated before |
336 | */ | 357 | */ |
337 | virtual OChannelHopper* channelHopper() const; | 358 | virtual OChannelHopper* channelHopper() const; |
338 | /** | 359 | /** |
339 | * Set the station @a nickname. | 360 | * Set the station @a nickname. |
340 | */ | 361 | */ |
341 | virtual void setNickName( const QString& nickname ) {}; //FIXME: Implement this | 362 | virtual void setNickName( const QString& nickname ) {}; //FIXME: Implement this |
342 | /** | 363 | /** |
343 | * @returns the current station nickname. | 364 | * @returns the current station nickname. |
344 | */ | 365 | */ |
345 | virtual QString nickName() const; | 366 | virtual QString nickName() const; |
346 | /** | 367 | /** |
347 | * Invoke the private IOCTL @a command with a @number of parameters on the network interface. | 368 | * Invoke the private IOCTL @a command with a @number of parameters on the network interface. |
348 | * @see OPrivateIOCTL | 369 | * @see OPrivateIOCTL |
349 | */ | 370 | */ |
350 | virtual void setPrivate( const QString& command, int number, ... ); | 371 | virtual void setPrivate( const QString& command, int number, ... ); |
351 | /** | 372 | /** |
352 | * @returns true if the interface is featuring the private IOCTL @command. | 373 | * @returns true if the interface is featuring the private IOCTL @command. |
353 | */ | 374 | */ |
354 | virtual bool hasPrivate( const QString& command ); | 375 | virtual bool hasPrivate( const QString& command ); |
355 | virtual void getPrivate( const QString& command ); //FIXME: Implement and document this | 376 | virtual void getPrivate( const QString& command ); //FIXME: Implement and document this |
356 | 377 | ||
357 | virtual bool isAssociated() const {}; //FIXME: Implement and document this | 378 | virtual bool isAssociated() const {}; //FIXME: Implement and document this |
358 | virtual QString associatedAP() const; //FIXME: Implement and document this | 379 | virtual QString associatedAP() const; //FIXME: Implement and document this |
359 | 380 | ||
360 | virtual void setSSID( const QString& ); | 381 | virtual void setSSID( const QString& ); |
361 | virtual QString SSID() const; | 382 | virtual QString SSID() const; |
362 | 383 | ||
363 | protected: | 384 | protected: |
364 | void buildChannelList(); | 385 | void buildChannelList(); |
365 | void buildPrivateList(); | 386 | void buildPrivateList(); |
366 | virtual void init(); | 387 | virtual void init(); |
367 | struct iwreq& iwr() const; | 388 | struct iwreq& iwr() const; |
368 | bool wioctl( int call ) const; | 389 | bool wioctl( int call ) const; |
369 | bool wioctl( int call, struct iwreq& ) const; | 390 | bool wioctl( int call, struct iwreq& ) const; |
370 | 391 | ||
371 | protected: | 392 | protected: |
372 | mutable struct iwreq _iwr; | 393 | mutable struct iwreq _iwr; |
373 | QMap<int,int> _channels; | 394 | QMap<int,int> _channels; |
374 | 395 | ||
375 | private: | 396 | private: |
376 | OChannelHopper* _hopper; | 397 | OChannelHopper* _hopper; |
377 | }; | 398 | }; |
378 | 399 | ||
379 | 400 | ||
380 | /*====================================================================================== | 401 | /*====================================================================================== |
381 | * OMonitoringInterface | 402 | * OMonitoringInterface |
382 | *======================================================================================*/ | 403 | *======================================================================================*/ |
383 | 404 | ||
384 | 405 | ||
385 | class OMonitoringInterface | 406 | class OMonitoringInterface |
386 | { | 407 | { |
387 | public: | 408 | public: |
388 | OMonitoringInterface(); | 409 | OMonitoringInterface(); |
389 | OMonitoringInterface( ONetworkInterface* ); | 410 | OMonitoringInterface( ONetworkInterface* ); |
390 | virtual ~OMonitoringInterface(); | 411 | virtual ~OMonitoringInterface(); |
391 | 412 | ||
392 | public: | 413 | public: |