summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/launcher/desktop.cpp34
-rw-r--r--library/password.cpp24
-rw-r--r--library/password.h1
3 files changed, 46 insertions, 13 deletions
diff --git a/core/launcher/desktop.cpp b/core/launcher/desktop.cpp
index 0e60839..d74b745 100644
--- a/core/launcher/desktop.cpp
+++ b/core/launcher/desktop.cpp
@@ -136,97 +136,97 @@ void DesktopPowerAlerter::alert( const QString &text, int priority )
136{ 136{
137 alertCount++; 137 alertCount++;
138 if ( alertCount < priority ) 138 if ( alertCount < priority )
139 return ; 139 return ;
140 if ( priority > currentPriority ) 140 if ( priority > currentPriority )
141 return ; 141 return ;
142 currentPriority = priority; 142 currentPriority = priority;
143 setText( text ); 143 setText( text );
144 show(); 144 show();
145} 145}
146 146
147 147
148void DesktopPowerAlerter::hideEvent( QHideEvent *e ) 148void DesktopPowerAlerter::hideEvent( QHideEvent *e )
149{ 149{
150 QMessageBox::hideEvent( e ); 150 QMessageBox::hideEvent( e );
151 alertCount = 0; 151 alertCount = 0;
152 currentPriority = INT_MAX; 152 currentPriority = INT_MAX;
153} 153}
154 154
155 155
156class QPEScreenSaver : public QWSScreenSaver 156class QPEScreenSaver : public QWSScreenSaver
157{ 157{
158private: 158private:
159 int LcdOn; 159 int LcdOn;
160 160
161public: 161public:
162 QPEScreenSaver() 162 QPEScreenSaver()
163 { 163 {
164 m_disable_suspend = 100; 164 m_disable_suspend = 100;
165 m_enable_dim = false; 165 m_enable_dim = false;
166 m_enable_lightoff = false; 166 m_enable_lightoff = false;
167 m_enable_onlylcdoff = false; 167 m_enable_onlylcdoff = false;
168 168
169 m_lcd_status = true; 169 m_lcd_status = true;
170 170
171 m_backlight_bright = -1; 171 m_backlight_bright = -1;
172 m_backlight_forcedoff = false; 172 m_backlight_forcedoff = false;
173 173
174 // Make sure the LCD is in fact on, (if opie was killed while the LCD is off it would still be off) 174 // Make sure the LCD is in fact on, (if opie was killed while the LCD is off it would still be off)
175 ODevice::inst ( ) -> setDisplayStatus ( true ); 175 ODevice::inst ( ) -> setDisplayStatus ( true );
176 } 176 }
177 void restore() 177 void restore()
178 { 178 {
179 if ( !m_lcd_status ) { // We must have turned it off 179 if ( !m_lcd_status ) { // We must have turned it off
180 ODevice::inst ( ) -> setDisplayStatus ( true ); 180 ODevice::inst ( ) -> setDisplayStatus ( true );
181 m_lcd_status = true; 181 m_lcd_status = true;
182 } 182 }
183 183
184 setBacklight ( -3 ); 184 setBacklight ( -1 );
185 } 185 }
186 bool save( int level ) 186 bool save( int level )
187 { 187 {
188 switch ( level ) { 188 switch ( level ) {
189 case 0: 189 case 0:
190 if ( m_disable_suspend > 0 && m_enable_dim ) { 190 if ( m_disable_suspend > 0 && m_enable_dim ) {
191 if ( backlight() > 1 ) 191 if ( backlight() > 1 )
192 setBacklight( 1 ); // lowest non-off 192 setBacklight( 1 ); // lowest non-off
193 } 193 }
194 return true; 194 return true;
195 break; 195 break;
196 case 1: 196 case 1:
197 if ( m_disable_suspend > 1 && m_enable_lightoff ) { 197 if ( m_disable_suspend > 1 && m_enable_lightoff ) {
198 setBacklight( 0 ); // off 198 setBacklight( 0 ); // off
199 } 199 }
200 return true; 200 return true;
201 break; 201 break;
202 case 2: 202 case 2:
203 if ( m_enable_onlylcdoff ) { 203 if ( m_enable_onlylcdoff ) {
204 ODevice::inst ( ) -> setDisplayStatus ( false ); 204 ODevice::inst ( ) -> setDisplayStatus ( false );
205 m_lcd_status = false; 205 m_lcd_status = false;
206 return true; 206 return true;
207 } 207 }
208 else // We're going to suspend the whole machine 208 else // We're going to suspend the whole machine
209 { 209 {
210 if ( ( m_disable_suspend > 2 ) && 210 if ( ( m_disable_suspend > 2 ) &&
211 ( PowerStatusManager::readStatus().acStatus() != PowerStatus::Online ) && 211 ( PowerStatusManager::readStatus().acStatus() != PowerStatus::Online ) &&
212 ( !Network::networkOnline ( ) ) ) { 212 ( !Network::networkOnline ( ) ) ) {
213 QWSServer::sendKeyEvent( 0xffff, Qt::Key_F34, FALSE, TRUE, FALSE ); 213 QWSServer::sendKeyEvent( 0xffff, Qt::Key_F34, FALSE, TRUE, FALSE );
214 return true; 214 return true;
215 } 215 }
216 } 216 }
217 break; 217 break;
218 } 218 }
219 return false; 219 return false;
220 } 220 }
221 221
222private: 222private:
223 static int ssi( int interval, Config & config, const QString & enable, const QString & value, int def ) 223 static int ssi( int interval, Config & config, const QString & enable, const QString & value, int def )
224 { 224 {
225 if ( !enable.isEmpty() && config.readNumEntry( enable, 0 ) == 0 ) 225 if ( !enable.isEmpty() && config.readNumEntry( enable, 0 ) == 0 )
226 return 0; 226 return 0;
227 227
228 if ( interval < 0 ) { 228 if ( interval < 0 ) {
229 // Restore screen blanking and power saving state 229 // Restore screen blanking and power saving state
230 interval = config.readNumEntry( value, def ); 230 interval = config.readNumEntry( value, def );
231 } 231 }
232 return interval; 232 return interval;
@@ -287,102 +287,104 @@ public:
287 if ( bright == -3 ) { 287 if ( bright == -3 ) {
288 // Forced on 288 // Forced on
289 m_backlight_forcedoff = false; 289 m_backlight_forcedoff = false;
290 bright = -1; 290 bright = -1;
291 } 291 }
292 if ( m_backlight_forcedoff && bright != -2 ) 292 if ( m_backlight_forcedoff && bright != -2 )
293 return ; 293 return ;
294 if ( bright == -2 ) { 294 if ( bright == -2 ) {
295 // Toggle between off and on 295 // Toggle between off and on
296 bright = m_backlight_bright ? 0 : -1; 296 bright = m_backlight_bright ? 0 : -1;
297 m_backlight_forcedoff = !bright; 297 m_backlight_forcedoff = !bright;
298 } 298 }
299 299
300 m_backlight_bright = bright; 300 m_backlight_bright = bright;
301 301
302 bright = backlight ( ); 302 bright = backlight ( );
303 ODevice::inst ( ) -> setDisplayBrightness ( bright ); 303 ODevice::inst ( ) -> setDisplayBrightness ( bright );
304 304
305 m_backlight_bright = bright; 305 m_backlight_bright = bright;
306 } 306 }
307 307
308 void setDisplayState ( bool on ) 308 void setDisplayState ( bool on )
309 { 309 {
310 if ( m_lcd_status != on ) { 310 if ( m_lcd_status != on ) {
311 ODevice::inst ( ) -> setDisplayStatus ( on ); 311 ODevice::inst ( ) -> setDisplayStatus ( on );
312 m_lcd_status = on; 312 m_lcd_status = on;
313 } 313 }
314 } 314 }
315 315
316private: 316private:
317 int m_disable_suspend; 317 int m_disable_suspend;
318 bool m_enable_dim; 318 bool m_enable_dim;
319 bool m_enable_lightoff; 319 bool m_enable_lightoff;
320 bool m_enable_onlylcdoff; 320 bool m_enable_onlylcdoff;
321 321
322 bool m_lcd_status; 322 bool m_lcd_status;
323 323
324 int m_backlight_bright; 324 int m_backlight_bright;
325 bool m_backlight_forcedoff; 325 bool m_backlight_forcedoff;
326}; 326};
327 327
328 328
329void DesktopApplication::switchLCD ( bool on ) 329void DesktopApplication::switchLCD ( bool on )
330{ 330{
331 if ( qApp ) { 331 if ( qApp ) {
332 DesktopApplication *dapp = (DesktopApplication *) qApp; 332 DesktopApplication *dapp = (DesktopApplication *) qApp;
333 333
334 if ( dapp-> m_screensaver ) { 334 if ( dapp-> m_screensaver ) {
335 if ( on ) 335 if ( on ) {
336 dapp-> m_screensaver-> restore ( ); //setBacklight ( on ? -3 : -1 ); 336 dapp-> m_screensaver-> setDisplayState ( true );
337 else 337 dapp-> m_screensaver-> setBacklight ( -3 );
338 dapp-> m_screensaver-> save ( 1 ); 338 }
339 339 else {
340 } 340 dapp-> m_screensaver-> setDisplayState ( false );
341 }
342 }
341 } 343 }
342} 344}
343 345
344 346
345DesktopApplication::DesktopApplication( int& argc, char **argv, Type appType ) 347DesktopApplication::DesktopApplication( int& argc, char **argv, Type appType )
346 : QPEApplication( argc, argv, appType ) 348 : QPEApplication( argc, argv, appType )
347{ 349{
348 350
349 QTimer * t = new QTimer( this ); 351 QTimer * t = new QTimer( this );
350 connect( t, SIGNAL( timeout() ), this, SLOT( psTimeout() ) ); 352 connect( t, SIGNAL( timeout() ), this, SLOT( psTimeout() ) );
351 t->start( 10000 ); 353 t->start( 10000 );
352 ps = new PowerStatus; 354 ps = new PowerStatus;
353 pa = new DesktopPowerAlerter( 0 ); 355 pa = new DesktopPowerAlerter( 0 );
354 356
355 channel = new QCopChannel( "QPE/Desktop", this ); 357 channel = new QCopChannel( "QPE/Desktop", this );
356 connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), 358 connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ),
357 this, SLOT( desktopMessage( const QCString&, const QByteArray& ) ) ); 359 this, SLOT( desktopMessage( const QCString&, const QByteArray& ) ) );
358 360
359 channel = new QCopChannel( "QPE/System", this ); 361 channel = new QCopChannel( "QPE/System", this );
360 connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ), 362 connect( channel, SIGNAL( received( const QCString&, const QByteArray& ) ),
361 this, SLOT( systemMessage( const QCString&, const QByteArray& ) ) ); 363 this, SLOT( systemMessage( const QCString&, const QByteArray& ) ) );
362 364
363 m_screensaver = new QPEScreenSaver; 365 m_screensaver = new QPEScreenSaver;
364 366
365 m_screensaver-> setInterval ( -1 ); 367 m_screensaver-> setInterval ( -1 );
366 QWSServer::setScreenSaver( m_screensaver ); 368 QWSServer::setScreenSaver( m_screensaver );
367} 369}
368 370
369 371
370DesktopApplication::~DesktopApplication() 372DesktopApplication::~DesktopApplication()
371{ 373{
372 delete ps; 374 delete ps;
373 delete pa; 375 delete pa;
374} 376}
375 377
376void DesktopApplication::desktopMessage( const QCString &msg, const QByteArray &data ) 378void DesktopApplication::desktopMessage( const QCString &msg, const QByteArray &data )
377{ 379{
378#ifdef Q_WS_QWS 380#ifdef Q_WS_QWS
379 QDataStream stream( data, IO_ReadOnly ); 381 QDataStream stream( data, IO_ReadOnly );
380 if ( msg == "keyRegister(int key, QString channel, QString message)" ) { 382 if ( msg == "keyRegister(int key, QString channel, QString message)" ) {
381 int k; 383 int k;
382 QString c, m; 384 QString c, m;
383 stream >> k; 385 stream >> k;
384 stream >> c; 386 stream >> c;
385 stream >> m; 387 stream >> m;
386 388
387 qWarning( "KeyRegisterReceived: %i, %s, %s", k, ( const char* ) c, ( const char * ) m ); 389 qWarning( "KeyRegisterReceived: %i, %s, %s", k, ( const char* ) c, ( const char * ) m );
388 keyRegisterList.append( QCopKeyRegister( k, c, m ) ); 390 keyRegisterList.append( QCopKeyRegister( k, c, m ) );
@@ -817,115 +819,125 @@ void Desktop::raiseEmail()
817 cfg.setGroup( "AppsKey" ); 819 cfg.setGroup( "AppsKey" );
818 QString tempItem; 820 QString tempItem;
819 tempItem = cfg.readEntry( "RightEnd", "Mail" ); 821 tempItem = cfg.readEntry( "RightEnd", "Mail" );
820 if ( tempItem == "Mail" || tempItem == "qtmail" || tempItem.isEmpty() ) { 822 if ( tempItem == "Mail" || tempItem == "qtmail" || tempItem.isEmpty() ) {
821 tempItem = "mail"; 823 tempItem = "mail";
822 } 824 }
823 QCopEnvelope e( "QPE/System", "execute(QString)" ); 825 QCopEnvelope e( "QPE/System", "execute(QString)" );
824 e << tempItem; 826 e << tempItem;
825} 827}
826 828
827// autoStarts apps on resume and start 829// autoStarts apps on resume and start
828void Desktop::execAutoStart() 830void Desktop::execAutoStart()
829{ 831{
830 QString appName; 832 QString appName;
831 int delay; 833 int delay;
832 QDateTime now = QDateTime::currentDateTime(); 834 QDateTime now = QDateTime::currentDateTime();
833 Config cfg( "autostart" ); 835 Config cfg( "autostart" );
834 cfg.setGroup( "AutoStart" ); 836 cfg.setGroup( "AutoStart" );
835 appName = cfg.readEntry( "Apps", "" ); 837 appName = cfg.readEntry( "Apps", "" );
836 delay = ( cfg.readEntry( "Delay", "0" ) ).toInt(); 838 delay = ( cfg.readEntry( "Delay", "0" ) ).toInt();
837 // If the time between suspend and resume was longer then the 839 // If the time between suspend and resume was longer then the
838 // value saved as delay, start the app 840 // value saved as delay, start the app
839 if ( suspendTime.secsTo( now ) >= ( delay * 60 ) && !appName.isEmpty() ) { 841 if ( suspendTime.secsTo( now ) >= ( delay * 60 ) && !appName.isEmpty() ) {
840 QCopEnvelope e( "QPE/System", "execute(QString)" ); 842 QCopEnvelope e( "QPE/System", "execute(QString)" );
841 e << QString( appName ); 843 e << QString( appName );
842 } 844 }
843} 845}
844 846
845#if defined(QPE_HAVE_TOGGLELIGHT) 847#if defined(QPE_HAVE_TOGGLELIGHT)
846#include <qpe/config.h> 848#include <qpe/config.h>
847 849
848#include <sys/ioctl.h> 850#include <sys/ioctl.h>
849#include <sys/types.h> 851#include <sys/types.h>
850#include <fcntl.h> 852#include <fcntl.h>
851#include <unistd.h> 853#include <unistd.h>
852#include <errno.h> 854#include <errno.h>
853#include <linux/ioctl.h> 855#include <linux/ioctl.h>
854#include <time.h> 856#include <time.h>
855#endif 857#endif
856 858
857 859
858void Desktop::togglePower() 860void Desktop::togglePower()
859{ 861{
860 static bool excllock = false; 862 static bool excllock = false;
861 863
862 qDebug ( "togglePower (locked == %d)", excllock ? 1 : 0 ); 864 qDebug ( "togglePower (locked == %d)", excllock ? 1 : 0 );
863 865
864 if ( excllock ) 866 if ( excllock )
865 return ; 867 return;
866 868
867 excllock = true; 869 excllock = true;
868 870
869 bool wasloggedin = loggedin; 871 bool wasloggedin = loggedin;
870 loggedin = 0; 872 loggedin = 0;
871 suspendTime = QDateTime::currentDateTime(); 873 suspendTime = QDateTime::currentDateTime();
872 874
873 ODevice::inst ( ) -> suspend ( ); 875#ifdef QWS
876 if ( Password::needToAuthenticate ( true ) && qt_screen ) {
877 // Should use a big black window instead.
878 // But this would not show up fast enough
879 QGfx *g = qt_screen-> screenGfx ( );
880 g-> fillRect ( 0, 0, qt_screen-> width ( ), qt_screen-> height ( ));
881 delete g;
882 }
883#endif
884
885 ODevice::inst ( )-> suspend ( );
874 886
875 QWSServer::screenSaverActivate ( false );
876 DesktopApplication::switchLCD ( true ); // force LCD on without slow qcop call 887 DesktopApplication::switchLCD ( true ); // force LCD on without slow qcop call
888 QWSServer::screenSaverActivate ( false );
877 889
878 { 890 {
879 QCopEnvelope( "QPE/Card", "mtabChanged()" ); // might have changed while asleep 891 QCopEnvelope( "QPE/Card", "mtabChanged()" ); // might have changed while asleep
880 } 892 }
881 893
882 if ( wasloggedin ) 894 if ( wasloggedin )
883 login( TRUE ); 895 login ( true );
884 896
885 execAutoStart(); 897 execAutoStart();
886 //qcopBridge->closeOpenConnections(); 898 //qcopBridge->closeOpenConnections();
887 899
888 excllock = false; 900 excllock = false;
889} 901}
890 902
891void Desktop::toggleLight() 903void Desktop::toggleLight()
892{ 904{
893 QCopEnvelope e( "QPE/System", "setBacklight(int)" ); 905 QCopEnvelope e( "QPE/System", "setBacklight(int)" );
894 e << -2; // toggle 906 e << -2; // toggle
895} 907}
896 908
897void Desktop::toggleSymbolInput() 909void Desktop::toggleSymbolInput()
898{ 910{
899 tb->toggleSymbolInput(); 911 tb->toggleSymbolInput();
900} 912}
901 913
902void Desktop::toggleNumLockState() 914void Desktop::toggleNumLockState()
903{ 915{
904 tb->toggleNumLockState(); 916 tb->toggleNumLockState();
905} 917}
906 918
907void Desktop::toggleCapsLockState() 919void Desktop::toggleCapsLockState()
908{ 920{
909 tb->toggleCapsLockState(); 921 tb->toggleCapsLockState();
910} 922}
911 923
912void Desktop::styleChange( QStyle &s ) 924void Desktop::styleChange( QStyle &s )
913{ 925{
914 QWidget::styleChange( s ); 926 QWidget::styleChange( s );
915 int displayw = qApp->desktop() ->width(); 927 int displayw = qApp->desktop() ->width();
916 int displayh = qApp->desktop() ->height(); 928 int displayh = qApp->desktop() ->height();
917 929
918 QSize sz = tb->sizeHint(); 930 QSize sz = tb->sizeHint();
919 931
920 tb->setGeometry( 0, displayh - sz.height(), displayw, sz.height() ); 932 tb->setGeometry( 0, displayh - sz.height(), displayw, sz.height() );
921} 933}
922 934
923void DesktopApplication::shutdown() 935void DesktopApplication::shutdown()
924{ 936{
925 if ( type() != GuiServer ) 937 if ( type() != GuiServer )
926 return ; 938 return ;
927 ShutdownImpl *sd = new ShutdownImpl( 0, 0, WDestructiveClose ); 939 ShutdownImpl *sd = new ShutdownImpl( 0, 0, WDestructiveClose );
928 connect( sd, SIGNAL( shutdown( ShutdownImpl::Type ) ), 940 connect( sd, SIGNAL( shutdown( ShutdownImpl::Type ) ),
929 this, SLOT( shutdown( ShutdownImpl::Type ) ) ); 941 this, SLOT( shutdown( ShutdownImpl::Type ) ) );
930 sd->showMaximized(); 942 sd->showMaximized();
931} 943}
diff --git a/library/password.cpp b/library/password.cpp
index 4b22b65..6d126c4 100644
--- a/library/password.cpp
+++ b/library/password.cpp
@@ -1,78 +1,78 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. 2** Copyright (C) 2000-2002 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of the Qtopia Environment. 4** This file is part of the Qtopia Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#include "password.h" 20#include "password.h"
21#include "config.h" 21#include "config.h"
22#include "global.h" 22#include "global.h"
23#include "backend/contact.h" 23#include "backend/contact.h"
24#include <qlabel.h> 24#include <qlabel.h>
25#include <qlineedit.h> 25#include <qlineedit.h>
26#include <qtextview.h> 26#include <qtextview.h>
27#include <qstring.h> 27#include <qstring.h>
28#include <qapplication.h> 28#include <qapplication.h>
29#include <qfile.h> 29#include <qfile.h>
30#include <qwindowsystem_qws.h> 30//#include <qwindowsystem_qws.h>
31 31
32#include <qdialog.h> 32#include <qdialog.h>
33 33
34#include <unistd.h> //for sleep 34#include <unistd.h> //for sleep
35#include "passwordbase_p.h" 35#include "passwordbase_p.h"
36 36
37class PasswordDialog : public PasswordBase 37class PasswordDialog : public PasswordBase
38{ 38{
39 Q_OBJECT 39 Q_OBJECT
40 40
41public: 41public:
42 PasswordDialog( QWidget* parent = 0, const char* name = 0, WFlags fl = 0 ); 42 PasswordDialog( QWidget* parent = 0, const char* name = 0, WFlags fl = 0 );
43 ~PasswordDialog(); 43 ~PasswordDialog();
44 44
45 void clear(); 45 void clear();
46 void setPrompt( const QString& ); 46 void setPrompt( const QString& );
47 47
48signals: 48signals:
49 void passwordEntered( const QString& ); 49 void passwordEntered( const QString& );
50 50
51protected: 51protected:
52 bool eventFilter( QObject*, QEvent* ); 52 bool eventFilter( QObject*, QEvent* );
53 void keyPressEvent( QKeyEvent * ); 53 void keyPressEvent( QKeyEvent * );
54 54
55private: 55private:
56 void input( QString ); 56 void input( QString );
57 friend class Password; 57 friend class Password;
58 QString text; 58 QString text;
59}; 59};
60 60
61 61
62extern "C" char *crypt(const char *key, const char *salt); 62extern "C" char *crypt(const char *key, const char *salt);
63static QString qcrypt(const QString& k, const char *salt) 63static QString qcrypt(const QString& k, const char *salt)
64{ 64{
65 return QString::fromUtf8(crypt(k.utf8(),salt)); 65 return QString::fromUtf8(crypt(k.utf8(),salt));
66} 66}
67 67
68/* 68/*
69 * Constructs a PasswordDialog which is a child of 'parent', with the 69 * Constructs a PasswordDialog which is a child of 'parent', with the
70 * name 'name' and widget flags set to 'f' 70 * name 'name' and widget flags set to 'f'
71 */ 71 */
72PasswordDialog::PasswordDialog( QWidget* parent, const char* name, WFlags fl ) 72PasswordDialog::PasswordDialog( QWidget* parent, const char* name, WFlags fl )
73 : PasswordBase( parent, name, fl ) 73 : PasswordBase( parent, name, fl )
74{ 74{
75 QRect desk = qApp->desktop()->geometry(); 75 QRect desk = qApp->desktop()->geometry();
76 76
77 if ( desk.width() < 220 ) { 77 if ( desk.width() < 220 ) {
78 QFont f( font() ); 78 QFont f( font() );
@@ -240,94 +240,114 @@ public:
240 240
241 void resizeEvent( QResizeEvent * ) 241 void resizeEvent( QResizeEvent * )
242 { 242 {
243 tv->resize( size() ); 243 tv->resize( size() );
244 } 244 }
245 245
246 bool eventFilter(QObject *o, QEvent *e) 246 bool eventFilter(QObject *o, QEvent *e)
247 { 247 {
248 if (e->type() == QEvent::KeyPress || e->type() == QEvent::MouseButtonPress ) { 248 if (e->type() == QEvent::KeyPress || e->type() == QEvent::MouseButtonPress ) {
249 accept(); 249 accept();
250 return TRUE; 250 return TRUE;
251 } 251 }
252 return QWidget::eventFilter(o, e); 252 return QWidget::eventFilter(o, e);
253 } 253 }
254 254
255 void mousePressEvent( QMouseEvent * ) { accept(); } 255 void mousePressEvent( QMouseEvent * ) { accept(); }
256 256
257private: 257private:
258 QTextView *tv; 258 QTextView *tv;
259}; 259};
260 260
261/*! 261/*!
262 Returns a crypted password entered by the user when prompted with \a prompt 262 Returns a crypted password entered by the user when prompted with \a prompt
263 The returned value is QString::null if the user cancels the operation, 263 The returned value is QString::null if the user cancels the operation,
264 or the empty string if the user enters no password (but confirms the 264 or the empty string if the user enters no password (but confirms the
265 dialog). 265 dialog).
266*/ 266*/
267 267
268QString Password::getPassword( const QString& prompt ) 268QString Password::getPassword( const QString& prompt )
269{ 269{
270 PasswdDlg pd(0,0,TRUE); 270 PasswdDlg pd(0,0,TRUE);
271 pd.passw->setPrompt( prompt ); 271 pd.passw->setPrompt( prompt );
272 272
273 pd.showMaximized(); 273 pd.showMaximized();
274 int r = pd.exec(); 274 int r = pd.exec();
275 275
276 if ( r == QDialog::Accepted ) { 276 if ( r == QDialog::Accepted ) {
277 if (pd.passw->text.isEmpty()) 277 if (pd.passw->text.isEmpty())
278 return ""; 278 return "";
279 else 279 else
280 return qcrypt(pd.passw->text,"a0"); 280 return qcrypt(pd.passw->text,"a0");
281 } else { 281 } else {
282 return QString::null; 282 return QString::null;
283 } 283 }
284} 284}
285 285
286 286
287/*! 287/*!
288 Return if a prompt for the user's passcode is needed.
289
290 If \a at_poweron is TRUE, the dialog is only used if the user's
291 preference request it at poweron
292
293 Opie extension to speed up suspend/resume.
294*/
295
296bool Password::needToAuthenticate(bool at_poweron)
297{
298 Config cfg("Security");
299 cfg.setGroup("Passcode");
300 QString passcode = cfg.readEntry("passcode");
301
302 return ( !passcode.isEmpty()
303 && (!at_poweron || cfg.readNumEntry("passcode_poweron",0)) );
304}
305
306/*!
288 Prompt, fullscreen, for the user's passcode until they get it right. 307 Prompt, fullscreen, for the user's passcode until they get it right.
289 308
290 If \a at_poweron is TRUE, the dialog is only used if the user's 309 If \a at_poweron is TRUE, the dialog is only used if the user's
291 preference request it at poweron; either way, the screen is always repainted 310 preference request it at poweron; either way, the screen is always repainted
292 by this function. (this functionality may move to the caller of this function). 311 by this function. (this functionality may move to the caller of this function).
293*/ 312*/
294 313
295void Password::authenticate(bool at_poweron) 314void Password::authenticate(bool at_poweron)
296{ 315{
297 Config cfg("Security"); 316 Config cfg("Security");
298 cfg.setGroup("Passcode"); 317 cfg.setGroup("Passcode");
299 QString passcode = cfg.readEntry("passcode"); 318 QString passcode = cfg.readEntry("passcode");
300 if ( !passcode.isEmpty() 319 if ( !passcode.isEmpty()
301 && (!at_poweron || cfg.readNumEntry("passcode_poweron",0)) ) 320 && (!at_poweron || cfg.readNumEntry("passcode_poweron",0)) )
302 { 321 {
303 // Do it as a fullscreen modal dialog 322 // Do it as a fullscreen modal dialog
304 PasswdDlg pd(0,0,TRUE,TRUE); 323 PasswdDlg pd(0,0,TRUE,TRUE);
305 324
306 // see if there is contact information. 325 // see if there is contact information.
307 OwnerDlg *oi = 0; 326 OwnerDlg *oi = 0;
308 QString vfilename = Global::applicationFileName("addressbook", 327 QString vfilename = Global::applicationFileName("addressbook",
309 "businesscard.vcf"); 328 "businesscard.vcf");
310 if (QFile::exists(vfilename)) { 329 if (QFile::exists(vfilename)) {
311 Contact c; 330 Contact c;
312 c = Contact::readVCard( vfilename )[0]; 331 c = Contact::readVCard( vfilename )[0];
313 332
314 oi = new OwnerDlg(0, 0, c, TRUE, TRUE); 333 oi = new OwnerDlg(0, 0, c, TRUE, TRUE);
315 } 334 }
316 335
317 pd.reset(); 336 pd.reset();
318 pd.exec(); 337 pd.exec();
319 while (qcrypt(pd.passw->text, "a0") != passcode) { 338 while (qcrypt(pd.passw->text, "a0") != passcode) {
320 if (oi) 339 if (oi)
321 oi->exec(); 340 oi->exec();
322 pd.reset(); 341 pd.reset();
323 pd.exec(); 342 pd.exec();
324 } 343 }
325 } else if ( at_poweron ) { 344 } else if ( at_poweron ) {
326 // refresh screen #### should probably be in caller 345 // refresh screen #### should probably be in caller
327 // Not needed (we took away the screen blacking) 346 // Not needed (we took away the screen blacking) TT
347 // Not needed (we have intelligent screen blacking) sandman
328 //if ( qwsServer ) 348 //if ( qwsServer )
329 //qwsServer->refresh(); 349 //qwsServer->refresh();
330 } 350 }
331} 351}
332 352
333#include "password.moc" 353#include "password.moc"
diff --git a/library/password.h b/library/password.h
index a3a3e45..a2f2c3c 100644
--- a/library/password.h
+++ b/library/password.h
@@ -1,32 +1,33 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. 2** Copyright (C) 2000-2002 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of the Qtopia Environment. 4** This file is part of the Qtopia Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#ifndef PASSWORD_H 20#ifndef PASSWORD_H
21#define PASSWORD_H 21#define PASSWORD_H
22 22
23#include <qstring.h> 23#include <qstring.h>
24 24
25class Password 25class Password
26{ 26{
27public: 27public:
28 static bool needToAuthenticate(bool atpoweron=FALSE); // Opie extension to speed up suspend/resume (sandman)
28 static void authenticate(bool atpoweron=FALSE); 29 static void authenticate(bool atpoweron=FALSE);
29 static QString getPassword( const QString& prompt ); 30 static QString getPassword( const QString& prompt );
30}; 31};
31 32
32#endif // PASSWORD_H 33#endif // PASSWORD_H