diff options
author | Timothy Pearson <[email protected]> | 2015-10-02 19:58:14 -0500 |
---|---|---|
committer | Timothy Pearson <[email protected]> | 2015-10-02 19:58:14 -0500 |
commit | 37b6d0d80ff63156326d46ba1e0a19f3b7c02e5b (patch) | |
tree | cb73e51e4ec907e2721bbdc305d7d0024c21ded1 /kdesktop/lock/lockdlg.cc | |
parent | 48cf3058c5543a65026cb1cc9d8fc7450c4ccc68 (diff) | |
download | tdebase-37b6d0d80ff63156326d46ba1e0a19f3b7c02e5b.tar.gz tdebase-37b6d0d80ff63156326d46ba1e0a19f3b7c02e5b.zip |
Fix cryptographic card login process
Diffstat (limited to 'kdesktop/lock/lockdlg.cc')
-rw-r--r-- | kdesktop/lock/lockdlg.cc | 31 |
1 files changed, 21 insertions, 10 deletions
diff --git a/kdesktop/lock/lockdlg.cc b/kdesktop/lock/lockdlg.cc index 677b4129f..8202a7f68 100644 --- a/kdesktop/lock/lockdlg.cc +++ b/kdesktop/lock/lockdlg.cc @@ -546,9 +546,24 @@ void PasswordDlg::handleVerify() // Reset password entry and change text greet->start(); greet->textPrompt( arr, false, false ); + // Force relayout setFixedSize( sizeHint().width(), sizeHint().height() + 1 ); setFixedSize( sizeHint() ); + + // Check if cryptographic card login is being used + if (mCardLoginInProgress) { + // Attempt authentication if configured + TDECryptographicCardDevice* cdevice = static_cast<LockProcess*>(parent())->cryptographicCardDevice(); + if (cdevice) { + TQString autoPIN = cdevice->autoPIN(); + if (autoPIN != TQString::null) { + greet->setPassword(autoPIN); + TQTimer::singleShot(0, this, SLOT(slotOK())); + } + } + mCardLoginInProgress = false; + } } else { greet->textPrompt( arr, false, false ); @@ -971,21 +986,17 @@ void PasswordDlg::attemptCardLogin() { setFixedSize(sizeHint().width(), sizeHint().height() + 1); setFixedSize(sizeHint()); - // Attempt authentication if configured - TDECryptographicCardDevice* cdevice = static_cast<LockProcess*>(parent())->cryptographicCardDevice(); - if (cdevice) { - TQString autoPIN = cdevice->autoPIN(); - if (autoPIN != TQString::null) { - greet->start(); - greet->setPassword(autoPIN); - TQTimer::singleShot(0, this, SLOT(slotOK())); - } - } + // Bypass initial password prompt + greet->start(); + greet->setPassword(""); + TQTimer::singleShot(0, this, SLOT(slotOK())); } void PasswordDlg::resetCardLogin() { validUserCardInserted = false; greet->abort(); + greet->clear(); + greet->revive(); greet->start(); greet->setPasswordPrompt(TQString::null); |