/* * Copyright 2015 Timothy Pearson <kb9vqf@pearsoncomputing.net> * * This file is part of cryptocardwatcher, the TDE Cryptographic Card Session Monitor * * cryptocardwatcher is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as * published by the Free Software Foundation, either version 3 * of the License, or (at your option) any later version. * * cryptocardwatcher is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public * License along with cryptocardwatcher. If not, see http://www.gnu.org/licenses/. */ #include "watcher.h" #include <ksslcertificate.h> #include <tdehardwaredevices.h> #include <tdecryptographiccarddevice.h> #include <dmctl.h> #include <kuser.h> CardWatcher::CardWatcher() : TQObject() { // } CardWatcher::~CardWatcher() { // } void CardWatcher::cryptographicCardInserted(TDECryptographicCardDevice* cdevice) { TQString login_name = TQString::null; X509CertificatePtrList certList = cdevice->cardX509Certificates(); if (certList.count() > 0) { KSSLCertificate* card_cert = NULL; card_cert = KSSLCertificate::fromX509(certList[0]); TQStringList cert_subject_parts = TQStringList::split("/", card_cert->getSubject(), false); for (TQStringList::Iterator it = cert_subject_parts.begin(); it != cert_subject_parts.end(); ++it ) { TQString lcpart = (*it).lower(); if (lcpart.startsWith("cn=")) { login_name = lcpart.right(lcpart.length() - strlen("cn=")); } } delete card_cert; } if (login_name != "") { // Determine if user already has an active session DM dm; SessList sess; bool user_active = false; bool unused_session_available = false; bool unused_session_active = false; int unused_session_vt_number = -1; if (dm.localSessions(sess)) { TQString user, loc; for (SessList::ConstIterator it = sess.begin(); it != sess.end(); ++it) { DM::sess2Str2(*it, user, loc); if (user.startsWith(login_name + ": ")) { // Found active session user_active = true; // Switch VTs DM().switchVT((*it).vt); break; } if (user == "Unused") { // Found active unused session unused_session_available = true; unused_session_vt_number = (*it).vt; if ((*it).vt == dm.activeVT()) { unused_session_active = true; break; } } } } if (!user_active || unused_session_available) { if (unused_session_available) { if (!unused_session_active) { // Switch to unused VT DM().switchVT(unused_session_vt_number); } } else { // Activate new VT DM().startReserve(); } } } } void CardWatcher::cryptographicCardRemoved(TDECryptographicCardDevice* cdevice) { // } #include "watcher.moc"