summaryrefslogtreecommitdiff
authorllornkcor <llornkcor>2005-08-15 09:58:06 (UTC)
committer llornkcor <llornkcor>2005-08-15 09:58:06 (UTC)
commite7c0016a970ab1bdf5870a648a7bf07b857fbb11 (patch) (unidiff)
tree3180a13bf982fbb3d908a6a0c5d824bb63a22936
parent75eb12d42636cbd837d49f9c1347387e96e4174b (diff)
downloadopie-e7c0016a970ab1bdf5870a648a7bf07b857fbb11.zip
opie-e7c0016a970ab1bdf5870a648a7bf07b857fbb11.tar.gz
opie-e7c0016a970ab1bdf5870a648a7bf07b857fbb11.tar.bz2
scan better
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/opie-smb/qsmb.cpp80
1 files changed, 25 insertions, 55 deletions
diff --git a/noncore/net/opie-smb/qsmb.cpp b/noncore/net/opie-smb/qsmb.cpp
index d6d1b23..c1ee9a9 100644
--- a/noncore/net/opie-smb/qsmb.cpp
+++ b/noncore/net/opie-smb/qsmb.cpp
@@ -1,406 +1,376 @@
1#include "qsmb.h" 1#include "qsmb.h"
2#include <qpushbutton.h> 2#include <qpushbutton.h>
3#include <qpe/qpeapplication.h> 3#include <qpe/qpeapplication.h>
4 4
5#include <string.h> 5#include <string.h>
6#include <qstring.h> 6#include <qstring.h>
7#include <qstringlist.h> 7#include <qstringlist.h>
8#include <qdir.h> 8#include <qdir.h>
9#include <qfileinfo.h> 9#include <qfileinfo.h>
10 10
11#include <qpe/process.h> 11#include <qpe/process.h>
12#include <qlabel.h> 12#include <qlabel.h>
13#include <qlineedit.h> 13#include <qlineedit.h>
14#include <qcombobox.h> 14#include <qcombobox.h>
15#include <qstringlist.h> 15#include <qstringlist.h>
16#include <qcheckbox.h> 16#include <qcheckbox.h>
17#include <qtextview.h> 17#include <qtextview.h>
18#include <qmessagebox.h> 18#include <qmessagebox.h>
19#include <qtextstream.h>
19 20
20 21
21#include <pthread.h> 22#include <pthread.h>
22#include <signal.h> 23#include <signal.h>
23#include <ctype.h> 24#include <ctype.h>
24 25
25 26
26#include <netinet/in.h> 27#include <netinet/in.h>
27#include <arpa/inet.h> 28#include <arpa/inet.h>
28 29
29#include <rpc/clnt.h> 30#include <rpc/clnt.h>
30 31
31 32
32#include <opie2/odebug.h> 33#include <opie2/odebug.h>
33using namespace Opie::Core; 34using namespace Opie::Core;
34 35
35 36
36Qsmb::Qsmb( QWidget* parent, const char* name, WFlags fl ) 37Qsmb::Qsmb( QWidget* parent, const char* name, WFlags fl )
37 : FormQPESMBBase( parent, name, fl ) 38 : FormQPESMBBase( parent, name, fl )
38{ 39{
39 connect(CBHost, SIGNAL(activated(int)), this, SLOT(hostSelected(int))); 40 connect(CBHost, SIGNAL(activated(int)), this, SLOT(hostSelected(int)));
40 connect(DoItBtn, SIGNAL(clicked()), this, SLOT(DoItClicked())); 41 connect(DoItBtn, SIGNAL(clicked()), this, SLOT(DoItClicked()));
41 connect(BtnScan, SIGNAL(clicked()), this, SLOT(scanClicked())); 42 connect(BtnScan, SIGNAL(clicked()), this, SLOT(scanClicked()));
42 connect(BtnClear, SIGNAL(clicked()), this, SLOT(clear())); 43 connect(BtnClear, SIGNAL(clicked()), this, SLOT(clear()));
43 44
44 mountpt->insertItem("/mnt/samba1",-1); 45 mountpt->insertItem("/mnt/samba1",-1);
45 mountpt->insertItem("/mnt/samba2",-1); 46 mountpt->insertItem("/mnt/samba2",-1);
46 mountpt->insertItem("/mnt/samba3",-1); 47 mountpt->insertItem("/mnt/samba3",-1);
47 48
48 top_element = NULL; 49 top_element = NULL;
49 scanning = false; 50 scanning = false;
50} 51}
51 52
52Qsmb::~Qsmb() 53Qsmb::~Qsmb()
53{ 54{
54} 55}
55 56
56void Qsmb::clear() 57void Qsmb::clear()
57{ 58{
58 if (scanning) return; 59 if (scanning) return;
59 ListViewScan->clear(); 60 ListViewScan->clear();
60 TextViewOutput->setText(""); 61 TextViewOutput->setText("");
61 top_element = NULL; 62 top_element = NULL;
62} 63}
63 64
64void Qsmb::scanClicked() 65void Qsmb::scanClicked()
65{ 66{
66 if (scanning) return; 67 if (scanning) return;
67 pthread_create(&tpid, NULL, runit, (void *)this); 68 pthread_create(&tpid, NULL, runit, (void *)this);
68} 69}
69 70
70void Qsmb::DoItClicked() 71void Qsmb::DoItClicked()
71{ 72{
72 73
73 if(! ListViewScan->selectedItem()) { 74 if(! ListViewScan->selectedItem()) {
74 QMessageBox::warning(this, tr("Error"),tr("<p>No share selected!</p>")); 75 QMessageBox::warning(this, tr("Error"),tr("<p>No share selected!</p>"));
75 return; 76 return;
76 } 77 }
77 if (scanning) return; 78 if (scanning) return;
78 pthread_create(&tpid, NULL, runitm, (void *)this); 79 pthread_create(&tpid, NULL, runitm, (void *)this);
79} 80}
80 81
81void* runit(void* arg) 82void* runit(void* arg)
82{ 83{
83 Qsmb* caller = (Qsmb*)arg; 84 Qsmb* caller = (Qsmb*)arg;
84 caller->scan(); 85 caller->scan();
85 return(0); 86 return(0);
86} 87}
87 88
88void* runitm(void* arg) 89void* runitm(void* arg)
89{ 90{
90 Qsmb* caller = (Qsmb*)arg; 91 Qsmb* caller = (Qsmb*)arg;
91 caller->DoIt(); 92 caller->DoIt();
92 return(0); 93 return(0);
93} 94}
94 95
95void Qsmb::scan() 96void Qsmb::scan()
96{ 97{
97 int i; 98 int i;
98 99
99 if (scanning) return; 100 if (scanning) return;
100 scanning = true; 101 scanning = true;
101 102
102 QString match; 103 QString match;
103 char lmhosts[512];
104 QString cmd; 104 QString cmd;
105 char result[256];
106
107 FILE *pipe, *pipe2;
108
109 LScan->setText("Scanning..."); 105 LScan->setText("Scanning...");
110 qApp->processEvents(); 106 qApp->processEvents();
111 107
112 sockaddr_in my_addr; 108 sockaddr_in my_addr;
113 get_myaddress( &my_addr); 109 get_myaddress( &my_addr);
114 110
115 QString ip = inet_ntoa( my_addr.sin_addr); 111 QString ip = inet_ntoa( my_addr.sin_addr);
116 owarn << "IP Address : " << ip<< oendl; 112 owarn << "IP Address : " << ip<< oendl;
117 113
118 match = ip.left(5); 114 match = ip.left(5);
119 115
120 cmd = "smbfind"; 116 QStringList ccmd;
121 owarn <<"cmd: " << cmd << oendl; 117 TextViewOutput->append("smbfind");
122
123 TextViewOutput->append(cmd);
124
125 snprintf(lmhosts, 512, "echo '127.0.0.1 localhost'>/etc/samba/lmhosts");
126
127 if ((pipe2 = popen(lmhosts, "r")) == NULL) {
128 snprintf(result, 256, "Error: Can't run %s", lmhosts);
129 //TextViewOutput->append(result);
130 return;
131 }
132
133 /* run command & read output */
134 if ((pipe = popen(cmd.latin1(), "r")) == NULL) {
135 snprintf(result, 256, "Error: Can't run %s", cmd.latin1());
136 TextViewOutput->append(result);
137 return;
138 }
139 118
119 QFile lmhosts("/etc/samba/lmhosts");
120 QTextStream lms(&lmhosts);
121 lmhosts.open(IO_WriteOnly);
122 lms << "127.0.0.1 localhost\n";
123
140 /* parse output and display in ListViewScan */ 124 /* parse output and display in ListViewScan */
141 while(fgets(result, 256, pipe) != NULL) { 125 ccmd = "smbfind";
142 /* put result into TextViewOutput */ 126 owarn <<"cmd: " << ccmd << oendl;
143 TextViewOutput->append(result); 127 runCommand(ccmd);
144 128
145 if( strstr(result, match.latin1()) != NULL ) { 129 QTextStream s(&out, IO_ReadOnly);
146 char ip_addr[256], host[256], *ptr1; 130
147 131 while ( !s.atEnd() ) {
148 strcpy( ip_addr, result); 132 QString ip_addr, host, output;
149 ptr1 = strchr(ip_addr,' '); 133 QString tmp = s.readLine();
150 strcpy( host, ptr1); 134 bool ok;
151 ip_addr[ptr1 - ip_addr]='\0'; 135 tmp.left(1).toInt( &ok, 10 );
152 136 if(ok) {
153 for(i = 0; i < 256; i++) { 137 QStringList token = QStringList::split(' ', tmp );
154 if(host[i]!=' ') { 138 ip_addr = token[0];
155 strcpy( host, host + i); 139 host = token[1];
156 break;
157 }
158 }
159 ptr1 = strchr(host,' ');
160 host[ptr1 - host] = '\0';
161
162 owarn << "add host: " << host << oendl;
163
164 CBHost->insertItem( host, -1); 140 CBHost->insertItem( host, -1);
165 snprintf( lmhosts, 512, "echo '%s %s'>>/etc/samba/lmhosts", ip_addr,host); 141 lms << ip_addr+" "+host+"\n";
166
167 owarn << "lmhosts: " << lmhosts << oendl;
168
169 if ((pipe2 = popen(lmhosts, "r")) == NULL) {
170 snprintf(result, 256, "Error: Can't run %s", lmhosts);
171 return;
172 }
173 } 142 }
174 } 143 }
144 lmhosts.close();
175 145
176 TextViewOutput->append("\n\n============================================\n"); 146 TextViewOutput->append("\n\n============================================\n");
177 LScan->setText(""); 147 LScan->setText("");
178 scanning = false; 148 scanning = false;
179} 149}
180 150
181void Qsmb::hostSelected(int index) 151void Qsmb::hostSelected(int index)
182{ 152{
183 owarn << "hostSelected" << oendl; 153 owarn << "hostSelected" << oendl;
184 int i; 154 int i;
185 155
186 QListViewItem *element; 156 QListViewItem *element;
187 QListViewItem *parent; 157 QListViewItem *parent;
188 158
189 QString text = CBHost->currentText(); 159 QString text = CBHost->currentText();
190 160
191 if (scanning) return; 161 if (scanning) return;
192 scanning = true; 162 scanning = true;
193 163
194 QString cmd; 164 QString cmd;
195 char result[256]; 165 char result[256];
196 166
197 FILE *pipe; 167 FILE *pipe;
198 168
199 LScan->setText("Scanning..."); 169 LScan->setText("Scanning...");
200 170
201 if(username->text().isEmpty()) 171 if(username->text().isEmpty())
202 cmd = "/usr/bin/smbclient -L //"+CBHost->currentText()+" -N 2>&1 |grep Disk"; 172 cmd = "/usr/bin/smbclient -L //"+CBHost->currentText()+" -N 2>&1 |grep Disk";
203 else 173 else
204 cmd = "/usr/bin/smbclient -L //"+CBHost->currentText()+" -N -U "+username->text()+"\%"+password->text()+" 2>&1 |grep Disk"; 174 cmd = "/usr/bin/smbclient -L //"+CBHost->currentText()+" -N -U "+username->text()+"\%"+password->text()+" 2>&1 |grep Disk";
205 175
206// for(i = 0; i < 512; i++) { 176// for(i = 0; i < 512; i++) {
207// if(cmd[i]==':') { 177// if(cmd[i]==':') {
208// cmd[i]='%'; 178// cmd[i]='%';
209// break; 179// break;
210// } 180// }
211// if(cmd[i]=='\0') 181// if(cmd[i]=='\0')
212// break; 182// break;
213// } 183// }
214 184
215 owarn << "i="<< index << "cmd:" << cmd << oendl; 185 owarn << "i="<< index << "cmd:" << cmd << oendl;
216 186
217 TextViewOutput->append(cmd); 187 TextViewOutput->append(cmd);
218 188
219 /* run smbclient & read output */ 189 /* run smbclient & read output */
220 if ((pipe = popen(cmd.latin1(), "r")) == NULL) { 190 if ((pipe = popen(cmd.latin1(), "r")) == NULL) {
221 snprintf(result, 256, "Error: Can't run %s", cmd.latin1()); 191 snprintf(result, 256, "Error: Can't run %s", cmd.latin1());
222// cmd = "Error: Can't run "+cmd; 192// cmd = "Error: Can't run "+cmd;
223 TextViewOutput->append(result); 193 TextViewOutput->append(result);
224 return; 194 return;
225 } 195 }
226 196
227 /* parse output and display in ListViewScan */ 197 /* parse output and display in ListViewScan */
228 while(fgets(result, 256, pipe) != NULL) { 198 while(fgets(result, 256, pipe) != NULL) {
229 /* put result into TextViewOutput */ 199 /* put result into TextViewOutput */
230 TextViewOutput->append(result); 200 TextViewOutput->append(result);
231 201
232 if( strchr(result, '$') == NULL ) { 202 if( strchr(result, '$') == NULL ) {
233 char share[256], *ptr1; 203 char share[256], *ptr1;
234 204
235 strcpy(share,result); 205 strcpy(share,result);
236 ptr1 = strchr(share,' '); 206 ptr1 = strchr(share,' ');
237 share[ptr1 - share]='\0'; 207 share[ptr1 - share]='\0';
238 208
239 owarn<< "add share: " << share << oendl; 209 owarn<< "add share: " << share << oendl;
240 210
241 if(top_element != NULL) { 211 if(top_element != NULL) {
242 bool found = false; 212 bool found = false;
243 element = top_element; 213 element = top_element;
244 214
245 while(element != NULL && !found) { 215 while(element != NULL && !found) {
246 if(strcmp( element->text(0).ascii(), share)==0) { 216 if(strcmp( element->text(0).ascii(), share)==0) {
247 parent = element; 217 parent = element;
248 found = true; 218 found = true;
249 } 219 }
250 element = element->nextSibling(); 220 element = element->nextSibling();
251 } 221 }
252 222
253 if(!found) { 223 if(!found) {
254 element = new QListViewItem(ListViewScan,share); 224 element = new QListViewItem(ListViewScan,share);
255 element->setOpen(true); 225 element->setOpen(true);
256 parent=element; 226 parent=element;
257 } 227 }
258 } else { 228 } else {
259 element = new QListViewItem(ListViewScan,share); 229 element = new QListViewItem(ListViewScan,share);
260 element->setOpen(true); 230 element->setOpen(true);
261 top_element = element; 231 top_element = element;
262 parent = element; 232 parent = element;
263 } 233 }
264 } 234 }
265 } 235 }
266 236
267 TextViewOutput->append("\n\n============================================\n"); 237 TextViewOutput->append("\n\n============================================\n");
268 LScan->setText(""); 238 LScan->setText("");
269 scanning = false; 239 scanning = false;
270} 240}
271 241
272void Qsmb::DoIt() 242void Qsmb::DoIt()
273{ 243{
274 QListViewItem *element; 244 QListViewItem *element;
275 element = ListViewScan->selectedItem(); 245 element = ListViewScan->selectedItem();
276 if(!element) { 246 if(!element) {
277 QMessageBox::warning(this, tr("Error!!"),tr("<p><b>No</b> share selected!!</p>")); 247 QMessageBox::warning(this, tr("Error!!"),tr("<p><b>No</b> share selected!!</p>"));
278 return; 248 return;
279 } 249 }
280 250
281 if (scanning) return; 251 if (scanning) return;
282 scanning = true; 252 scanning = true;
283 253
284 int i; 254 int i;
285 bool err = false; 255 bool err = false;
286 256
287 char share[512]; 257 char share[512];
288 QString cmd; 258 QString cmd;
289 QString cmd2; 259 QString cmd2;
290 char result[256]; 260 char result[256];
291// QString result; 261// QString result;
292 QString text = mountpt->currentText(); 262 QString text = mountpt->currentText();
293 263
294 FILE *pipe,*pipe2; 264 FILE *pipe,*pipe2;
295 265
296 LScan->setText("Mounting..."); 266 LScan->setText("Mounting...");
297 qApp->processEvents(); 267 qApp->processEvents();
298 268
299 269
300 if(! QFileInfo(text).exists()) { 270 if(! QFileInfo(text).exists()) {
301// /* make sure mount exists! */ 271// /* make sure mount exists! */
302 272
303// cmd = "mkdir -p "+ text; 273// cmd = "mkdir -p "+ text;
304// owarn<<"cmd: "<< cmd << oendl; 274// owarn<<"cmd: "<< cmd << oendl;
305// if ((pipe2 = popen(cmd.latin1(), "r")) == NULL) { 275// if ((pipe2 = popen(cmd.latin1(), "r")) == NULL) {
306// snprintf(result, 256, "Error: Can't run %s", cmd.latin1()); 276// snprintf(result, 256, "Error: Can't run %s", cmd.latin1());
307// TextViewOutput->append(result); 277// TextViewOutput->append(result);
308// return; 278// return;
309// } 279// }
310// while(fgets(result, 256, pipe2) != NULL) { 280// while(fgets(result, 256, pipe2) != NULL) {
311// /* put result into TextViewOutput */ 281// /* put result into TextViewOutput */
312// TextViewOutput->append(result); 282// TextViewOutput->append(result);
313// } 283// }
314 QStringList ccmd; 284 QStringList ccmd;
315 ccmd << "mkdir"; 285 ccmd << "mkdir";
316 ccmd << "-p"; 286 ccmd << "-p";
317 ccmd << text; 287 ccmd << text;
318 288
319 owarn<<"cmd: "<< ccmd << oendl; 289 owarn<<"cmd: "<< ccmd << oendl;
320 runCommand(ccmd); 290 runCommand(ccmd);
321 } 291 }
322 292
323 293
324 strcpy(share,(const char *)element->text(0)); 294 strcpy(share,(const char *)element->text(0));
325 295
326 for(i = 0; i < 256; i++) { 296 for(i = 0; i < 256; i++) {
327 if(isalpha( share[i])) { 297 if(isalpha( share[i])) {
328 strcpy( share, share + i); 298 strcpy( share, share + i);
329 break; 299 break;
330 } 300 }
331 } 301 }
332 302
333 cmd = "/usr/bin/smbmount //"+CBHost->currentText()+"/"+share+" "+mountpt->currentText()+" -o username="+username->text()+",password="+password->text(); 303 cmd = "/usr/bin/smbmount //"+CBHost->currentText()+"/"+share+" "+mountpt->currentText()+" -o username="+username->text()+",password="+password->text();
334 304
335 owarn << "cmd: " << cmd << oendl; 305 owarn << "cmd: " << cmd << oendl;
336 TextViewOutput->append(cmd.latin1()); 306 TextViewOutput->append(cmd.latin1());
337 307
338 308
339 if(onbootBtn->isChecked()) { 309 if(onbootBtn->isChecked()) {
340 owarn << "Saving Setting permanently..." << oendl; 310 owarn << "Saving Setting permanently..." << oendl;
341 cmd2 = "echo '" + cmd + "'>/opt/QtPalmtop/etc/samba.env"; 311 cmd2 = "echo '" + cmd + "'>/opt/QtPalmtop/etc/samba.env";
342 /* run command & read output */ 312 /* run command & read output */
343 if ((pipe = popen(cmd2.latin1(), "r")) == NULL) { 313 if ((pipe = popen(cmd2.latin1(), "r")) == NULL) {
344 snprintf(result, 256, "Error: Can't run %s", cmd.latin1()); 314 snprintf(result, 256, "Error: Can't run %s", cmd.latin1());
345 return; 315 return;
346 } 316 }
347 /* parse output and display in ListViewScan */ 317 /* parse output and display in ListViewScan */
348 while(fgets(result, 256, pipe) != NULL) { 318 while(fgets(result, 256, pipe) != NULL) {
349 } 319 }
350 } 320 }
351 321
352 322
353 /* run command & read output */ 323 /* run command & read output */
354 if ((pipe = popen(cmd.latin1(), "r")) == NULL) { 324 if ((pipe = popen(cmd.latin1(), "r")) == NULL) {
355 snprintf(result, 256, "Error: Can't run %s", cmd.latin1()); 325 snprintf(result, 256, "Error: Can't run %s", cmd.latin1());
356 TextViewOutput->append(result); 326 TextViewOutput->append(result);
357 return; 327 return;
358 } 328 }
359 329
360 /* parse output and display in ListViewScan */ 330 /* parse output and display in ListViewScan */
361 while(fgets(result, 256, pipe) != NULL) { 331 while(fgets(result, 256, pipe) != NULL) {
362 /* put result into TextViewOutput */ 332 /* put result into TextViewOutput */
363 TextViewOutput->append(result); 333 TextViewOutput->append(result);
364 } 334 }
365 335
366 336
367 TextViewOutput->append("\n\n================CheckMounts==================\n"); 337 TextViewOutput->append("\n\n================CheckMounts==================\n");
368 LScan->setText(""); 338 LScan->setText("");
369 339
370 cmd = "/bin/mount 2>&1"; 340 cmd = "/bin/mount 2>&1";
371 owarn << "cmd: " << cmd << oendl; 341 owarn << "cmd: " << cmd << oendl;
372 342
373 if ((pipe2 = popen(cmd.latin1(), "r")) == NULL) { 343 if ((pipe2 = popen(cmd.latin1(), "r")) == NULL) {
374 344
375 snprintf(result, 256, "Error: Can't run %s", cmd.latin1()); 345 snprintf(result, 256, "Error: Can't run %s", cmd.latin1());
376// result = "Error: Can't run "+ cmd; 346// result = "Error: Can't run "+ cmd;
377 347
378 TextViewOutput->append(result); 348 TextViewOutput->append(result);
379 return; 349 return;
380 } 350 }
381 /* parse output and display in ListViewScan */ 351 /* parse output and display in ListViewScan */
382 while(fgets(result, 256, pipe2) != NULL) { 352 while(fgets(result, 256, pipe2) != NULL) {
383 /* put result into TextViewOutput */ 353 /* put result into TextViewOutput */
384 TextViewOutput->append(result); 354 TextViewOutput->append(result);
385 } 355 }
386 356
387 TextViewOutput->append("\n\n============================================\n"); 357 TextViewOutput->append("\n\n============================================\n");
388 scanning = false; 358 scanning = false;
389} 359}
390 360
391bool Qsmb::runCommand(const QStringList & command) { 361bool Qsmb::runCommand(const QStringList & command) {
392 owarn << "runCommand " << command.join(" ") << oendl; 362 owarn << "runCommand " << command.join(" ") << oendl;
393 out = ""; 363 out = "";
394 Process ipkg_status( command); 364 Process ipkg_status( command);
395 bool r = ipkg_status.exec("",out); 365 bool r = ipkg_status.exec("",out);
396 366
397 if(!r) { 367 if(!r) {
398 QMessageBox::warning(this, tr("Error!!"),tr("<p>"+out+"</p>")); 368 QMessageBox::warning(this, tr("Error!!"),tr("<p>"+out+"</p>"));
399 } 369 }
400 370
401 owarn << "Output " << out << oendl; 371 owarn << "Output " << out << oendl;
402 TextViewOutput->append(out.latin1()); 372 TextViewOutput->append(out.latin1());
403 return r; 373 return r;
404} 374}
405 375
406 376