summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/opie-login/loginwindow.ui6
-rw-r--r--core/opie-login/loginwindowimpl.cpp19
2 files changed, 25 insertions, 0 deletions
diff --git a/core/opie-login/loginwindow.ui b/core/opie-login/loginwindow.ui
index edd0819..5a35c8d 100644
--- a/core/opie-login/loginwindow.ui
+++ b/core/opie-login/loginwindow.ui
@@ -392,21 +392,27 @@
392 <signal>clicked()</signal> 392 <signal>clicked()</signal>
393 <receiver>LoginWindow</receiver> 393 <receiver>LoginWindow</receiver>
394 <slot>suspend()</slot> 394 <slot>suspend()</slot>
395 </connection> 395 </connection>
396 <connection> 396 <connection>
397 <sender>m_password</sender> 397 <sender>m_password</sender>
398 <signal>returnPressed()</signal> 398 <signal>returnPressed()</signal>
399 <receiver>m_login</receiver> 399 <receiver>m_login</receiver>
400 <slot>animateClick()</slot> 400 <slot>animateClick()</slot>
401 </connection> 401 </connection>
402 <connection> 402 <connection>
403 <sender>m_login</sender> 403 <sender>m_login</sender>
404 <signal>clicked()</signal> 404 <signal>clicked()</signal>
405 <receiver>LoginWindow</receiver> 405 <receiver>LoginWindow</receiver>
406 <slot>login()</slot> 406 <slot>login()</slot>
407 </connection> 407 </connection>
408 <connection>
409 <sender>m_user</sender>
410 <signal>activated(int)</signal>
411 <receiver>m_password</receiver>
412 <slot>setFocus()</slot>
413 </connection>
408 <slot access="public">login()</slot> 414 <slot access="public">login()</slot>
409 <slot access="public">suspend()</slot> 415 <slot access="public">suspend()</slot>
410 <slot access="public">toggleEchoMode(bool)</slot> 416 <slot access="public">toggleEchoMode(bool)</slot>
411</connections> 417</connections>
412</UI> 418</UI>
diff --git a/core/opie-login/loginwindowimpl.cpp b/core/opie-login/loginwindowimpl.cpp
index 63baaa6..c59338f 100644
--- a/core/opie-login/loginwindowimpl.cpp
+++ b/core/opie-login/loginwindowimpl.cpp
@@ -1,28 +1,30 @@
1#include <qapplication.h> 1#include <qapplication.h>
2#include <qpushbutton.h> 2#include <qpushbutton.h>
3#include <qlayout.h> 3#include <qlayout.h>
4#include <qframe.h> 4#include <qframe.h>
5#include <qlineedit.h> 5#include <qlineedit.h>
6#include <qtimer.h> 6#include <qtimer.h>
7#include <qcombobox.h> 7#include <qcombobox.h>
8#include <qpixmap.h> 8#include <qpixmap.h>
9#include <qlabel.h> 9#include <qlabel.h>
10#include <qpopupmenu.h> 10#include <qpopupmenu.h>
11#include <qmessagebox.h> 11#include <qmessagebox.h>
12#include <qimage.h>
12 13
14#include <qpe/resource.h>
13#include <qpe/qcopenvelope_qws.h> 15#include <qpe/qcopenvelope_qws.h>
14 16
15#include <opie/odevice.h> 17#include <opie/odevice.h>
16 18
17#include <stdio.h> 19#include <stdio.h>
18 20
19#include <pwd.h> 21#include <pwd.h>
20#include <grp.h> 22#include <grp.h>
21#include <unistd.h> 23#include <unistd.h>
22#include <stdlib.h> 24#include <stdlib.h>
23#include <signal.h> 25#include <signal.h>
24 26
25#ifdef USEPAM 27#ifdef USEPAM
26extern "C" { 28extern "C" {
27#include <security/pam_appl.h> 29#include <security/pam_appl.h>
28} 30}
@@ -75,32 +77,33 @@ void LoginWindowImpl::keyPressEvent ( QKeyEvent *e )
75 case HardKey_Suspend: suspend ( ); 77 case HardKey_Suspend: suspend ( );
76 break; 78 break;
77 case HardKey_Backlight: backlight ( ); 79 case HardKey_Backlight: backlight ( );
78 break; 80 break;
79 default: e-> ignore ( ); 81 default: e-> ignore ( );
80 break; 82 break;
81 } 83 }
82 LoginWindow::keyPressEvent ( e ); 84 LoginWindow::keyPressEvent ( e );
83} 85}
84 86
85 87
86void LoginWindowImpl::toggleEchoMode ( bool t ) 88void LoginWindowImpl::toggleEchoMode ( bool t )
87{ 89{
88 m_password-> setEchoMode ( t ? QLineEdit::Normal : QLineEdit::Password ); 90 m_password-> setEchoMode ( t ? QLineEdit::Normal : QLineEdit::Password );
89} 91}
90 92
93
91QStringList LoginWindowImpl::getAllUsers ( ) 94QStringList LoginWindowImpl::getAllUsers ( )
92{ 95{
93 struct passwd *pwd; 96 struct passwd *pwd;
94 QStringList sl; 97 QStringList sl;
95 98
96 while (( pwd = ::getpwent ( ))) { 99 while (( pwd = ::getpwent ( ))) {
97 if (( pwd-> pw_uid == 0 ) || ( pwd-> pw_uid >= 500 && pwd-> pw_uid < 65534 )) 100 if (( pwd-> pw_uid == 0 ) || ( pwd-> pw_uid >= 500 && pwd-> pw_uid < 65534 ))
98 sl << QString ( pwd-> pw_name ); 101 sl << QString ( pwd-> pw_name );
99 } 102 }
100 103
101 ::endpwent ( ); 104 ::endpwent ( );
102 105
103 return sl; 106 return sl;
104} 107}
105 108
106void LoginWindowImpl::showIM ( ) 109void LoginWindowImpl::showIM ( )
@@ -287,40 +290,56 @@ void LoginWindowImpl::login ( )
287 const char *pass = ::strdup ( m_password-> text ( ). local8Bit ( )); 290 const char *pass = ::strdup ( m_password-> text ( ). local8Bit ( ));
288 bool ok; 291 bool ok;
289 292
290 if ( !user || !user [0] ) 293 if ( !user || !user [0] )
291 return; 294 return;
292 if ( !pass ) 295 if ( !pass )
293 pass = ""; 296 pass = "";
294 297
295#if defined( USEPAM ) 298#if defined( USEPAM )
296 ok = pwcheck_PAM ( user, pass ); 299 ok = pwcheck_PAM ( user, pass );
297#else 300#else
298 ok = pwcheck_Unix ( user, pass ); 301 ok = pwcheck_Unix ( user, pass );
299#endif 302#endif
300 303
301 if ( ok ) { 304 if ( ok ) {
302 if ( changeIdentity ( user )) { 305 if ( changeIdentity ( user )) {
306 // Draw a big wait icon, the image can be altered in later revisions
307 QWidget *d = QApplication::desktop ( );
308 m_input-> hideInputMethod ( );
309
310 QImage img = Resource::loadImage( "launcher/new_wait" );
311 QPixmap pix;
312 pix. convertFromImage ( img );
313 QLabel *w = new QLabel ( 0, "wait hack!", WStyle_Customize | WStyle_NoBorder | WStyle_Tool );
314 w-> setPixmap ( pix );
315 w-> setAlignment ( AlignCenter );
316 w-> showMaximized ( );
317 qApp-> processEvents ( );
318
303 char *opie = ::getenv ( "OPIEDIR" ); 319 char *opie = ::getenv ( "OPIEDIR" );
304 char *arg = new char [::strlen ( opie ) + 8 + 1]; 320 char *arg = new char [::strlen ( opie ) + 8 + 1];
305 321
306 ::strcpy ( arg, opie ); 322 ::strcpy ( arg, opie );
307 ::strcat ( arg, "/bin/qpe" ); 323 ::strcat ( arg, "/bin/qpe" );
308 324
309 // start qpe via a login shell 325 // start qpe via a login shell
310 ::execl ( "/bin/sh", "-sh", "-c", arg, 0 ); 326 ::execl ( "/bin/sh", "-sh", "-c", arg, 0 );
311 327
328 w-> hide ( );
329 delete w;
330
312 QMessageBox::critical ( this, tr( "Failure" ), tr( "Could not start OPIE\n(%1)." ). arg ( arg )); 331 QMessageBox::critical ( this, tr( "Failure" ), tr( "Could not start OPIE\n(%1)." ). arg ( arg ));
313 delete [] arg; 332 delete [] arg;
314 333
315 restart ( ); 334 restart ( );
316 } 335 }
317 else { 336 else {
318 QMessageBox::critical ( this, tr( "Failure" ), tr( "Could not switch to new user identity" )); 337 QMessageBox::critical ( this, tr( "Failure" ), tr( "Could not switch to new user identity" ));
319 restart ( ); 338 restart ( );
320 } 339 }
321 } 340 }
322 else { 341 else {
323 QMessageBox::warning ( this, tr( "Wrong password" ), tr( "The given password is incorrect." )); 342 QMessageBox::warning ( this, tr( "Wrong password" ), tr( "The given password is incorrect." ));
324 m_password-> clear ( ); 343 m_password-> clear ( );
325 } 344 }
326} 345}