summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/opie-smb/qsmb.cpp3
1 files changed, 2 insertions, 1 deletions
diff --git a/noncore/net/opie-smb/qsmb.cpp b/noncore/net/opie-smb/qsmb.cpp
index a219c58..422b9f3 100644
--- a/noncore/net/opie-smb/qsmb.cpp
+++ b/noncore/net/opie-smb/qsmb.cpp
@@ -75,193 +75,194 @@ void Qsmb::DoItClicked()
75 QMessageBox::warning(this, tr("Error"),tr("<p>No share selected!</p>")); 75 QMessageBox::warning(this, tr("Error"),tr("<p>No share selected!</p>"));
76 return; 76 return;
77 } 77 }
78 if (scanning) return; 78 if (scanning) return;
79 pthread_create(&tpid, NULL, runitm, (void *)this); 79 pthread_create(&tpid, NULL, runitm, (void *)this);
80} 80}
81 81
82void* runit(void* arg) 82void* runit(void* arg)
83{ 83{
84 Qsmb* caller = (Qsmb*)arg; 84 Qsmb* caller = (Qsmb*)arg;
85 caller->scan(); 85 caller->scan();
86 return(0); 86 return(0);
87} 87}
88 88
89void* runitm(void* arg) 89void* runitm(void* arg)
90{ 90{
91 Qsmb* caller = (Qsmb*)arg; 91 Qsmb* caller = (Qsmb*)arg;
92 caller->DoIt(); 92 caller->DoIt();
93 return(0); 93 return(0);
94} 94}
95 95
96void Qsmb::scan() 96void Qsmb::scan()
97{ 97{
98// int i; 98// int i;
99 99
100 if (scanning) return; 100 if (scanning) return;
101 scanning = true; 101 scanning = true;
102 102
103 QString match; 103 QString match;
104 QString cmd; 104 QString cmd;
105 LScan->setText("Scanning..."); 105 LScan->setText("Scanning...");
106 qApp->processEvents(); 106 qApp->processEvents();
107 107
108 sockaddr_in my_addr; 108 sockaddr_in my_addr;
109 get_myaddress( &my_addr); 109 get_myaddress( &my_addr);
110 110
111 QString ip = inet_ntoa( my_addr.sin_addr); 111 QString ip = inet_ntoa( my_addr.sin_addr);
112 owarn << "IP Address : " << ip<< oendl; 112 owarn << "IP Address : " << ip<< oendl;
113 113
114 match = ip.left(5); 114 match = ip.left(5);
115 115
116 QStringList ccmd; 116 QStringList ccmd;
117 TextViewOutput->append("smbfind"); 117 TextViewOutput->append("smbfind");
118 118
119 QFile lmhosts("/etc/samba/lmhosts"); 119 QFile lmhosts("/etc/samba/lmhosts");
120 QTextStream lms(&lmhosts); 120 QTextStream lms(&lmhosts);
121 lmhosts.open(IO_WriteOnly); 121 lmhosts.open(IO_WriteOnly);
122 lms << "127.0.0.1 localhost\n"; 122 lms << "127.0.0.1 localhost\n";
123 123
124 /* parse output and display in ListViewScan */ 124 /* parse output and display in ListViewScan */
125 ccmd = "smbfind"; 125 ccmd = "smbfind";
126 runCommand(ccmd); 126 runCommand(ccmd);
127 127
128 QTextStream s(&out, IO_ReadOnly); 128 QTextStream s(&out, IO_ReadOnly);
129 129
130 while ( !s.atEnd() ) { 130 while ( !s.atEnd() ) {
131 QString ip_addr, host, output; 131 QString ip_addr, host, output;
132 QString tmp = s.readLine(); 132 QString tmp = s.readLine();
133 bool ok; 133 bool ok;
134 tmp.left(1).toInt( &ok, 10 ); 134 tmp.left(1).toInt( &ok, 10 );
135 if(ok) { 135 if(ok) {
136 QStringList token = QStringList::split(' ', tmp ); 136 QStringList token = QStringList::split(' ', tmp );
137 ip_addr = token[0]; 137 ip_addr = token[0];
138 host = token[1]; 138 host = token[1];
139 CBHost->insertItem( host, -1); 139 CBHost->insertItem( host, -1);
140 lms << ip_addr+" "+host+"\n"; 140 lms << ip_addr+" "+host+"\n";
141 } 141 }
142 } 142 }
143 lmhosts.close(); 143 lmhosts.close();
144 144
145 TextViewOutput->append("\n\n============================================\n"); 145 TextViewOutput->append("\n\n============================================\n");
146 LScan->setText(""); 146 LScan->setText("");
147 scanning = false; 147 scanning = false;
148} 148}
149 149
150void Qsmb::hostSelected(int index) 150void Qsmb::hostSelected(int index)
151{ 151{
152 owarn << "hostSelected" << oendl; 152 owarn << "hostSelected" << oendl;
153 QListViewItem *element; 153 QListViewItem *element;
154 QListViewItem *parent; 154 QListViewItem *parent;
155 155
156 QString text = CBHost->currentText(); 156 QString text = CBHost->currentText();
157 157
158 if (scanning) return; 158 if (scanning) return;
159 scanning = true; 159 scanning = true;
160 160
161 QString cmd; 161 QString cmd;
162 QStringList ccmd; 162 QStringList ccmd;
163 163
164 LScan->setText("Scanning..."); 164 LScan->setText("Scanning...");
165 165
166 ccmd << "/usr/bin/smbclient"; 166 ccmd << "/usr/bin/smbclient";
167 ccmd << "-L"; 167 ccmd << "-L";
168 ccmd << CBHost->currentText(); 168 ccmd << CBHost->currentText();
169 ccmd << "-N"; 169 ccmd << "-N";
170 170
171 if(!username->text().isEmpty()) { 171 if(username->text().isEmpty()) {
172 //do nothing
172 } else { 173 } else {
173 ccmd << "-U"; 174 ccmd << "-U";
174 ccmd << username->text()+"\%"+ password->text(); 175 ccmd << username->text()+"\%"+ password->text();
175 } 176 }
176 runCommand(ccmd); 177 runCommand(ccmd);
177 QTextStream s(&out, IO_ReadOnly); 178 QTextStream s(&out, IO_ReadOnly);
178 179
179 while ( !s.atEnd() ) { 180 while ( !s.atEnd() ) {
180 QString share; 181 QString share;
181 QString comment; 182 QString comment;
182 QString tmp = s.readLine(); 183 QString tmp = s.readLine();
183 184
184 if( tmp.find("$") == -1 && tmp.find("Disk") != -1) { 185 if( tmp.find("$") == -1 && tmp.find("Disk") != -1) {
185 QStringList token = QStringList::split(' ', tmp ); 186 QStringList token = QStringList::split(' ', tmp );
186 share = token[0]; 187 share = token[0];
187 comment = token[2]; 188 comment = token[2];
188 element = new QListViewItem(ListViewScan,share, comment); 189 element = new QListViewItem(ListViewScan,share, comment);
189 element->setOpen(true); 190 element->setOpen(true);
190// top_element = element; 191// top_element = element;
191// parent = element; 192// parent = element;
192 } 193 }
193 194
194 } 195 }
195// owarn << "i="<< index << "cmd:" << cmd << oendl; 196// owarn << "i="<< index << "cmd:" << cmd << oendl;
196 197
197 TextViewOutput->append(cmd); 198 TextViewOutput->append(cmd);
198 199
199 /* run smbclient & read output */ 200 /* run smbclient & read output */
200// if ((pipe = popen(cmd.latin1(), "r")) == NULL) { 201// if ((pipe = popen(cmd.latin1(), "r")) == NULL) {
201// snprintf(result, 256, "Error: Can't run %s", cmd.latin1()); 202// snprintf(result, 256, "Error: Can't run %s", cmd.latin1());
202// // cmd = "Error: Can't run "+cmd; 203// // cmd = "Error: Can't run "+cmd;
203// TextViewOutput->append(result); 204// TextViewOutput->append(result);
204// return; 205// return;
205// } 206// }
206 207
207 /* parse output and display in ListViewScan */ 208 /* parse output and display in ListViewScan */
208// while(fgets(result, 256, pipe) != NULL) { 209// while(fgets(result, 256, pipe) != NULL) {
209// /* put result into TextViewOutput */ 210// /* put result into TextViewOutput */
210// TextViewOutput->append(result); 211// TextViewOutput->append(result);
211 212
212// if( strchr(result, '$') == NULL ) { 213// if( strchr(result, '$') == NULL ) {
213// char share[256], *ptr1; 214// char share[256], *ptr1;
214 215
215// strcpy(share,result); 216// strcpy(share,result);
216// ptr1 = strchr(share,' '); 217// ptr1 = strchr(share,' ');
217// share[ptr1 - share]='\0'; 218// share[ptr1 - share]='\0';
218 219
219// owarn<< "add share: " << share << oendl; 220// owarn<< "add share: " << share << oendl;
220 221
221// if(top_element != NULL) { 222// if(top_element != NULL) {
222// bool found = false; 223// bool found = false;
223// element = top_element; 224// element = top_element;
224 225
225// while(element != NULL && !found) { 226// while(element != NULL && !found) {
226// if(strcmp( element->text(0).ascii(), share)==0) { 227// if(strcmp( element->text(0).ascii(), share)==0) {
227// parent = element; 228// parent = element;
228// found = true; 229// found = true;
229// } 230// }
230// element = element->nextSibling(); 231// element = element->nextSibling();
231// } 232// }
232 233
233// if(!found) { 234// if(!found) {
234// element = new QListViewItem(ListViewScan,share); 235// element = new QListViewItem(ListViewScan,share);
235// element->setOpen(true); 236// element->setOpen(true);
236// parent=element; 237// parent=element;
237// } 238// }
238// } else { 239// } else {
239// element = new QListViewItem(ListViewScan,share); 240// element = new QListViewItem(ListViewScan,share);
240// element->setOpen(true); 241// element->setOpen(true);
241// top_element = element; 242// top_element = element;
242// parent = element; 243// parent = element;
243// } 244// }
244// } 245// }
245// } 246// }
246 247
247 TextViewOutput->append("\n\n============================================\n"); 248 TextViewOutput->append("\n\n============================================\n");
248 LScan->setText(""); 249 LScan->setText("");
249 scanning = false; 250 scanning = false;
250} 251}
251 252
252void Qsmb::DoIt() 253void Qsmb::DoIt()
253{ 254{
254 QListViewItem *element; 255 QListViewItem *element;
255 element = ListViewScan->selectedItem(); 256 element = ListViewScan->selectedItem();
256 if(!element) { 257 if(!element) {
257 QMessageBox::warning(this, tr("Error!!"),tr("<p><b>No</b> share selected!!</p>")); 258 QMessageBox::warning(this, tr("Error!!"),tr("<p><b>No</b> share selected!!</p>"));
258 return; 259 return;
259 } 260 }
260 261
261 if (scanning) return; 262 if (scanning) return;
262 scanning = true; 263 scanning = true;
263 264
264 int i; 265 int i;
265 bool err = false; 266 bool err = false;
266 267
267 char share[512]; 268 char share[512];