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
@@ -280,133 +280,139 @@
280 <cstring>m_login</cstring> 280 <cstring>m_login</cstring>
281 </property> 281 </property>
282 <property stdset="1"> 282 <property stdset="1">
283 <name>autoMask</name> 283 <name>autoMask</name>
284 <bool>true</bool> 284 <bool>true</bool>
285 </property> 285 </property>
286 <property stdset="1"> 286 <property stdset="1">
287 <name>text</name> 287 <name>text</name>
288 <string>Login</string> 288 <string>Login</string>
289 </property> 289 </property>
290 </widget> 290 </widget>
291 <widget> 291 <widget>
292 <class>QPushButton</class> 292 <class>QPushButton</class>
293 <property stdset="1"> 293 <property stdset="1">
294 <name>name</name> 294 <name>name</name>
295 <cstring>m_suspend</cstring> 295 <cstring>m_suspend</cstring>
296 </property> 296 </property>
297 <property stdset="1"> 297 <property stdset="1">
298 <name>autoMask</name> 298 <name>autoMask</name>
299 <bool>true</bool> 299 <bool>true</bool>
300 </property> 300 </property>
301 <property stdset="1"> 301 <property stdset="1">
302 <name>text</name> 302 <name>text</name>
303 <string>Suspend</string> 303 <string>Suspend</string>
304 </property> 304 </property>
305 </widget> 305 </widget>
306 <widget> 306 <widget>
307 <class>QPushButton</class> 307 <class>QPushButton</class>
308 <property stdset="1"> 308 <property stdset="1">
309 <name>name</name> 309 <name>name</name>
310 <cstring>m_menu</cstring> 310 <cstring>m_menu</cstring>
311 </property> 311 </property>
312 <property stdset="1"> 312 <property stdset="1">
313 <name>autoMask</name> 313 <name>autoMask</name>
314 <bool>true</bool> 314 <bool>true</bool>
315 </property> 315 </property>
316 <property stdset="1"> 316 <property stdset="1">
317 <name>text</name> 317 <name>text</name>
318 <string>Menu</string> 318 <string>Menu</string>
319 </property> 319 </property>
320 </widget> 320 </widget>
321 </hbox> 321 </hbox>
322 </widget> 322 </widget>
323 <spacer> 323 <spacer>
324 <property> 324 <property>
325 <name>name</name> 325 <name>name</name>
326 <cstring>Spacer1</cstring> 326 <cstring>Spacer1</cstring>
327 </property> 327 </property>
328 <property stdset="1"> 328 <property stdset="1">
329 <name>orientation</name> 329 <name>orientation</name>
330 <enum>Vertical</enum> 330 <enum>Vertical</enum>
331 </property> 331 </property>
332 <property stdset="1"> 332 <property stdset="1">
333 <name>sizeType</name> 333 <name>sizeType</name>
334 <enum>Expanding</enum> 334 <enum>Expanding</enum>
335 </property> 335 </property>
336 <property> 336 <property>
337 <name>sizeHint</name> 337 <name>sizeHint</name>
338 <size> 338 <size>
339 <width>20</width> 339 <width>20</width>
340 <height>20</height> 340 <height>20</height>
341 </size> 341 </size>
342 </property> 342 </property>
343 </spacer> 343 </spacer>
344 </vbox> 344 </vbox>
345 </widget> 345 </widget>
346 <widget> 346 <widget>
347 <class>QFrame</class> 347 <class>QFrame</class>
348 <property stdset="1"> 348 <property stdset="1">
349 <name>name</name> 349 <name>name</name>
350 <cstring>m_taskbar</cstring> 350 <cstring>m_taskbar</cstring>
351 </property> 351 </property>
352 <property stdset="1"> 352 <property stdset="1">
353 <name>frameShape</name> 353 <name>frameShape</name>
354 <enum>NoFrame</enum> 354 <enum>NoFrame</enum>
355 </property> 355 </property>
356 <property stdset="1"> 356 <property stdset="1">
357 <name>frameShadow</name> 357 <name>frameShadow</name>
358 <enum>Raised</enum> 358 <enum>Raised</enum>
359 </property> 359 </property>
360 <property stdset="1"> 360 <property stdset="1">
361 <name>margin</name> 361 <name>margin</name>
362 <number>0</number> 362 <number>0</number>
363 </property> 363 </property>
364 </widget> 364 </widget>
365 </vbox> 365 </vbox>
366</widget> 366</widget>
367<images> 367<images>
368 <image> 368 <image>
369 <name>image0</name> 369 <name>image0</name>
370 <data format="XPM.GZ" length="394">789cd3d7528808f055d0d2e72a2e492cc94c5648ce482c52d04a29cdcdad8c8eb5ade6523234530022230543251d2e253d856405bffcbc54105b19c856360003b0141a808a2983b03284848a298304c108240e15033141045829580cac07ac4e590f5d0c22a4876caf32d45898797a48044caf32c22948e629c39d0457a78ce60f65b8f104ec50d6c366af1e865eb4b0aab5e602008bcd444d</data> 370 <data format="XPM.GZ" length="394">789cd3d7528808f055d0d2e72a2e492cc94c5648ce482c52d04a29cdcdad8c8eb5ade6523234530022230543251d2e253d856405bffcbc54105b19c856360003b0141a808a2983b03284848a298304c108240e15033141045829580cac07ac4e590f5d0c22a4876caf32d45898797a48044caf32c22948e629c39d0457a78ce60f65b8f104ec50d6c366af1e865eb4b0aab5e602008bcd444d</data>
371 </image> 371 </image>
372 <image> 372 <image>
373 <name>image1</name> 373 <name>image1</name>
374 <data format="XPM.GZ" length="341">789c558fcd0a02310c84ef7d8ad0b915c9bae84d7c04c5a3201e4275d1c32ab8eb41c477b73fa96e43a1f30d4d266d1ced771b728d194619af9efc451ee44ecfbe7f1d8eebb7b1ed92c259506b67c63279dade6fe7a81134e6a9224ac4ae2bc85565075004901c8820731069a648b490effc26eac4a25dcc195373c94231b87a8349fabf894b7a3d27a76af8cf01eb0e534757d70da1bf8a933f2bf30509e84b68</data> 374 <data format="XPM.GZ" length="341">789c558fcd0a02310c84ef7d8ad0b915c9bae84d7c04c5a3201e4275d1c32ab8eb41c477b73fa96e43a1f30d4d266d1ced771b728d194619af9efc451ee44ecfbe7f1d8eebb7b1ed92c259506b67c63279dade6fe7a81134e6a9224ac4ae2bc85565075004901c8820731069a648b490effc26eac4a25dcc195373c94231b87a8349fabf894b7a3d27a76af8cf01eb0e534757d70da1bf8a933f2bf30509e84b68</data>
375 </image> 375 </image>
376</images> 376</images>
377<connections> 377<connections>
378 <connection> 378 <connection>
379 <sender>ToolButton1</sender> 379 <sender>ToolButton1</sender>
380 <signal>clicked()</signal> 380 <signal>clicked()</signal>
381 <receiver>m_password</receiver> 381 <receiver>m_password</receiver>
382 <slot>clear()</slot> 382 <slot>clear()</slot>
383 </connection> 383 </connection>
384 <connection> 384 <connection>
385 <sender>ToolButton3</sender> 385 <sender>ToolButton3</sender>
386 <signal>toggled(bool)</signal> 386 <signal>toggled(bool)</signal>
387 <receiver>LoginWindow</receiver> 387 <receiver>LoginWindow</receiver>
388 <slot>toggleEchoMode(bool)</slot> 388 <slot>toggleEchoMode(bool)</slot>
389 </connection> 389 </connection>
390 <connection> 390 <connection>
391 <sender>m_suspend</sender> 391 <sender>m_suspend</sender>
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,326 +1,345 @@
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}
29#else 31#else
30#include <crypt.h> 32#include <crypt.h>
31#include <shadow.h> 33#include <shadow.h>
32#endif 34#endif
33 35
34#include "loginwindowimpl.h" 36#include "loginwindowimpl.h"
35#include "inputmethods.h" 37#include "inputmethods.h"
36 38
37using namespace Opie; 39using namespace Opie;
38 40
39 41
40LoginWindowImpl::LoginWindowImpl ( ) : LoginWindow ( 0, "LOGIN-WINDOW", WStyle_Customize | WStyle_NoBorder | WDestructiveClose ) 42LoginWindowImpl::LoginWindowImpl ( ) : LoginWindow ( 0, "LOGIN-WINDOW", WStyle_Customize | WStyle_NoBorder | WDestructiveClose )
41{ 43{
42 QPopupMenu *pop = new QPopupMenu ( this ); 44 QPopupMenu *pop = new QPopupMenu ( this );
43 pop-> insertItem ( tr( "Restart" ), this, SLOT( restart ( ))); 45 pop-> insertItem ( tr( "Restart" ), this, SLOT( restart ( )));
44 pop-> insertItem ( tr( "Quit" ), this, SLOT( quit ( ))); 46 pop-> insertItem ( tr( "Quit" ), this, SLOT( quit ( )));
45 m_menu-> setPopup ( pop ); 47 m_menu-> setPopup ( pop );
46 48
47 QHBoxLayout *lay = new QHBoxLayout ( m_taskbar, 4, 4 ); 49 QHBoxLayout *lay = new QHBoxLayout ( m_taskbar, 4, 4 );
48 m_input = new InputMethods ( m_taskbar ); 50 m_input = new InputMethods ( m_taskbar );
49 lay-> addWidget ( m_input ); 51 lay-> addWidget ( m_input );
50 lay-> addStretch ( 10 ); 52 lay-> addStretch ( 10 );
51 53
52 setActiveWindow ( ); 54 setActiveWindow ( );
53 m_password-> setFocus ( ); 55 m_password-> setFocus ( );
54 56
55 m_user-> insertStringList ( getAllUsers ( )); 57 m_user-> insertStringList ( getAllUsers ( ));
56 58
57 QTimer::singleShot ( 0, this, SLOT( showIM ( ))); 59 QTimer::singleShot ( 0, this, SLOT( showIM ( )));
58 60
59 QString opiedir = ::getenv ( "OPIEDIR" ); 61 QString opiedir = ::getenv ( "OPIEDIR" );
60 QPixmap bgpix ( opiedir + "/pics/launcher/opie-background.jpg" ); 62 QPixmap bgpix ( opiedir + "/pics/launcher/opie-background.jpg" );
61 63
62 if ( !bgpix. isNull ( )) 64 if ( !bgpix. isNull ( ))
63 setBackgroundPixmap ( bgpix ); 65 setBackgroundPixmap ( bgpix );
64 66
65 m_caption-> setText ( m_caption-> text ( ) + tr( "<center>%1 %2</center>" ). arg ( ODevice::inst ( )-> systemString ( )). arg ( ODevice::inst ( )-> systemVersionString ( ))); 67 m_caption-> setText ( m_caption-> text ( ) + tr( "<center>%1 %2</center>" ). arg ( ODevice::inst ( )-> systemString ( )). arg ( ODevice::inst ( )-> systemVersionString ( )));
66} 68}
67 69
68LoginWindowImpl::~LoginWindowImpl ( ) 70LoginWindowImpl::~LoginWindowImpl ( )
69{ 71{
70} 72}
71 73
72void LoginWindowImpl::keyPressEvent ( QKeyEvent *e ) 74void LoginWindowImpl::keyPressEvent ( QKeyEvent *e )
73{ 75{
74 switch ( e-> key ( )) { 76 switch ( e-> key ( )) {
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 ( )
107{ 110{
108 m_input-> showInputMethod ( ); 111 m_input-> showInputMethod ( );
109} 112}
110 113
111void LoginWindowImpl::restart ( ) 114void LoginWindowImpl::restart ( )
112{ 115{
113 qApp-> quit ( ); 116 qApp-> quit ( );
114} 117}
115 118
116void LoginWindowImpl::quit ( ) 119void LoginWindowImpl::quit ( )
117{ 120{
118 qApp-> quit ( ); 121 qApp-> quit ( );
119 ::kill ( ::getppid ( ), SIGUSR1 ); 122 ::kill ( ::getppid ( ), SIGUSR1 );
120} 123}
121 124
122void LoginWindowImpl::suspend ( ) 125void LoginWindowImpl::suspend ( )
123{ 126{
124 ODevice::inst ( )-> suspend ( ); 127 ODevice::inst ( )-> suspend ( );
125 128
126 QCopEnvelope e("QPE/System", "setBacklight(int)"); 129 QCopEnvelope e("QPE/System", "setBacklight(int)");
127 e << -3; // Force on 130 e << -3; // Force on
128} 131}
129 132
130void LoginWindowImpl::backlight ( ) 133void LoginWindowImpl::backlight ( )
131{ 134{
132 QCopEnvelope e("QPE/System", "setBacklight(int)"); 135 QCopEnvelope e("QPE/System", "setBacklight(int)");
133 e << -2; // toggle 136 e << -2; // toggle
134} 137}
135 138
136#ifdef USEPAM 139#ifdef USEPAM
137 140
138static const char *_PAM_SERVICE = "xdm"; 141static const char *_PAM_SERVICE = "xdm";
139static const char *PAM_password; 142static const char *PAM_password;
140 143
141typedef const struct pam_message pam_message_type; 144typedef const struct pam_message pam_message_type;
142 145
143static int PAM_conv( int, pam_message_type **, struct pam_response **, void * ); 146static int PAM_conv( int, pam_message_type **, struct pam_response **, void * );
144 147
145static struct pam_conv PAM_conversation = { 148static struct pam_conv PAM_conversation = {
146 &PAM_conv, 149 &PAM_conv,
147 NULL 150 NULL
148}; 151};
149 152
150//---------------------------------------------------------------------------- 153//----------------------------------------------------------------------------
151 154
152static char *COPY_STRING( const char * s ) { 155static char *COPY_STRING( const char * s ) {
153 return (s) ? strdup(s) : (char *)NULL; 156 return (s) ? strdup(s) : (char *)NULL;
154} 157}
155 158
156#define GET_MEM if (reply) realloc(reply, size);\ 159#define GET_MEM if (reply) realloc(reply, size);\
157 else reply = (struct pam_response *)malloc(size); \ 160 else reply = (struct pam_response *)malloc(size); \
158 if (!reply) return PAM_CONV_ERR; \ 161 if (!reply) return PAM_CONV_ERR; \
159 size += sizeof(struct pam_response) 162 size += sizeof(struct pam_response)
160 163
161 164
162static int PAM_conv( int num_msg, pam_message_type **msg, 165static int PAM_conv( int num_msg, pam_message_type **msg,
163 struct pam_response **resp, void *) 166 struct pam_response **resp, void *)
164{ 167{
165 int count = 0, replies = 0; 168 int count = 0, replies = 0;
166 struct pam_response *reply = NULL; 169 struct pam_response *reply = NULL;
167 int size = sizeof(struct pam_response); 170 int size = sizeof(struct pam_response);
168 171
169 for( count = 0; count < num_msg; count++ ) { 172 for( count = 0; count < num_msg; count++ ) {
170 switch (msg[count]->msg_style) { 173 switch (msg[count]->msg_style) {
171 case PAM_PROMPT_ECHO_ON: 174 case PAM_PROMPT_ECHO_ON:
172 /* user name given to PAM already */ 175 /* user name given to PAM already */
173 return PAM_CONV_ERR; 176 return PAM_CONV_ERR;
174 177
175 case PAM_PROMPT_ECHO_OFF: 178 case PAM_PROMPT_ECHO_OFF:
176 /* wants password */ 179 /* wants password */
177 GET_MEM; 180 GET_MEM;
178 reply[replies].resp_retcode = PAM_SUCCESS; 181 reply[replies].resp_retcode = PAM_SUCCESS;
179 reply[replies].resp = COPY_STRING(PAM_password); 182 reply[replies].resp = COPY_STRING(PAM_password);
180 replies++; 183 replies++;
181 /* PAM frees resp */ 184 /* PAM frees resp */
182 break; 185 break;
183 case PAM_TEXT_INFO: 186 case PAM_TEXT_INFO:
184 break; 187 break;
185 default: 188 default:
186 /* unknown or PAM_ERROR_MSG */ 189 /* unknown or PAM_ERROR_MSG */
187 if (reply) free (reply); 190 if (reply) free (reply);
188 return PAM_CONV_ERR; 191 return PAM_CONV_ERR;
189 } 192 }
190 } 193 }
191 if (reply) *resp = reply; 194 if (reply) *resp = reply;
192 return PAM_SUCCESS; 195 return PAM_SUCCESS;
193} 196}
194 197
195 198
196static bool pwcheck_PAM( const char *user, const char *password ) 199static bool pwcheck_PAM( const char *user, const char *password )
197{ 200{
198 bool pw_correct = false; 201 bool pw_correct = false;
199 int pam_error; 202 int pam_error;
200 int pam_return = 0; 203 int pam_return = 0;
201 pam_handle_t *pamh = 0; 204 pam_handle_t *pamh = 0;
202 PAM_password = password; 205 PAM_password = password;
203 206
204 pam_error = pam_start( _PAM_SERVICE, user, &PAM_conversation, &pamh ); 207 pam_error = pam_start( _PAM_SERVICE, user, &PAM_conversation, &pamh );
205 if( pam_error == PAM_SUCCESS ) { 208 if( pam_error == PAM_SUCCESS ) {
206 pam_error = pam_authenticate( pamh, 0 ); 209 pam_error = pam_authenticate( pamh, 0 );
207 if( pam_error == PAM_SUCCESS ) { 210 if( pam_error == PAM_SUCCESS ) {
208 //-- password correct 211 //-- password correct
209 pw_correct = true; 212 pw_correct = true;
210 pam_return = PAM_SUCCESS; 213 pam_return = PAM_SUCCESS;
211 } else { 214 } else {
212 pam_return = pam_error; 215 pam_return = pam_error;
213 } 216 }
214 } else { 217 } else {
215 // cerr << "PAM error: " << pam_strerror( pamh, pam_error ) << endl; 218 // cerr << "PAM error: " << pam_strerror( pamh, pam_error ) << endl;
216 } 219 }
217 pam_end( pamh, pam_return ); 220 pam_end( pamh, pam_return );
218 return pw_correct; 221 return pw_correct;
219} 222}
220 223
221#else 224#else
222 225
223//---------------------------------------------------------------------------- 226//----------------------------------------------------------------------------
224 227
225static bool pwcheck_Unix( const char *user, const char *pass ) 228static bool pwcheck_Unix( const char *user, const char *pass )
226{ 229{
227 char *encrypted, *correct; 230 char *encrypted, *correct;
228 struct passwd *pw; 231 struct passwd *pw;
229 232
230 if ( !user || !pass ) 233 if ( !user || !pass )
231 return false; 234 return false;
232 235
233 pw = getpwnam ( user ); 236 pw = getpwnam ( user );
234 237
235 if ( !pw ) 238 if ( !pw )
236 return false; 239 return false;
237 240
238 if (( strcmp ( pw-> pw_passwd, "x" ) == 0 ) || ( strcmp ( pw-> pw_passwd, "*" ) == 0 )) { 241 if (( strcmp ( pw-> pw_passwd, "x" ) == 0 ) || ( strcmp ( pw-> pw_passwd, "*" ) == 0 )) {
239 struct spwd *sp = getspnam ( pw-> pw_name ); 242 struct spwd *sp = getspnam ( pw-> pw_name );
240 243
241 if ( !sp ) 244 if ( !sp )
242 return false; 245 return false;
243 246
244 correct = sp-> sp_pwdp; 247 correct = sp-> sp_pwdp;
245 } 248 }
246 else 249 else
247 correct = pw-> pw_passwd; 250 correct = pw-> pw_passwd;
248 251
249 if ( correct == 0 || correct[0] == '\0' ) 252 if ( correct == 0 || correct[0] == '\0' )
250 return true; 253 return true;
251 254
252 encrypted = crypt ( pass, correct ); 255 encrypted = crypt ( pass, correct );
253 return ( strcmp ( encrypted, correct ) == 0 ); 256 return ( strcmp ( encrypted, correct ) == 0 );
254} 257}
255 258
256#endif 259#endif
257 260
258 261
259bool LoginWindowImpl::changeIdentity ( const char *user ) 262bool LoginWindowImpl::changeIdentity ( const char *user )
260{ 263{
261 const char *DEFAULT_LOGIN_PATH = "/bin:/usr/bin"; 264 const char *DEFAULT_LOGIN_PATH = "/bin:/usr/bin";
262 const char *DEFAULT_ROOT_LOGIN_PATH = "/usr/sbin:/bin:/usr/bin:/sbin"; 265 const char *DEFAULT_ROOT_LOGIN_PATH = "/usr/sbin:/bin:/usr/bin:/sbin";
263 266
264 bool fail = false; 267 bool fail = false;
265 struct passwd *pw = getpwnam ( user ); 268 struct passwd *pw = getpwnam ( user );
266 269
267 fail |= ( pw == 0 ); 270 fail |= ( pw == 0 );
268 fail |= ( initgroups ( pw-> pw_name, pw-> pw_gid )); 271 fail |= ( initgroups ( pw-> pw_name, pw-> pw_gid ));
269 endgrent ( ); 272 endgrent ( );
270 fail |= ( setgid ( pw-> pw_gid )); 273 fail |= ( setgid ( pw-> pw_gid ));
271 fail |= ( setuid ( pw-> pw_uid )); 274 fail |= ( setuid ( pw-> pw_uid ));
272 275
273 fail |= ( chdir ( pw-> pw_dir ) && chdir ( "/" )); 276 fail |= ( chdir ( pw-> pw_dir ) && chdir ( "/" ));
274 277
275 fail |= ( setenv ( "HOME", pw-> pw_dir, 1 )); 278 fail |= ( setenv ( "HOME", pw-> pw_dir, 1 ));
276 fail |= ( setenv ( "SHELL", pw-> pw_shell, 1 )); 279 fail |= ( setenv ( "SHELL", pw-> pw_shell, 1 ));
277 fail |= ( setenv ( "USER", pw-> pw_name, 1 )); 280 fail |= ( setenv ( "USER", pw-> pw_name, 1 ));
278 fail |= ( setenv ( "LOGNAME", pw-> pw_name, 1 )); 281 fail |= ( setenv ( "LOGNAME", pw-> pw_name, 1 ));
279 fail |= ( setenv ( "PATH", ( pw-> pw_uid ? DEFAULT_LOGIN_PATH : DEFAULT_ROOT_LOGIN_PATH ), 1 )); 282 fail |= ( setenv ( "PATH", ( pw-> pw_uid ? DEFAULT_LOGIN_PATH : DEFAULT_ROOT_LOGIN_PATH ), 1 ));
280 283
281 return !fail; 284 return !fail;
282} 285}
283 286
284void LoginWindowImpl::login ( ) 287void LoginWindowImpl::login ( )
285{ 288{
286 const char *user = ::strdup ( m_user-> currentText ( ). local8Bit ( )); 289 const char *user = ::strdup ( m_user-> currentText ( ). local8Bit ( ));
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}