/* This file is part of the KDE project * * Copyright (C) 2001-2003 George Staikos * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library 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 * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public License * along with this library; see the file COPYING.LIB. If not, write to * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301, USA. */ #ifndef KSSLCERTDIALOG_H #define KSSLCERTDIALOG_H #include #include #include class QWidget; class QCheckBox; class QRadioButton; class QListWidget; class QPushButton; /** * KDE X.509 Certificate Dialog * * This class is used to create and display a dialog which contains the user's * X.509 certificates and allows the user to present it during SSL sessions. * * @author George Staikos * @see KSSL * @short KDE X.509 Certificate Dialog */ class KIO_EXPORT KSSLCertDialog : public KDialog { Q_OBJECT public: /** * Construct a KSSL certificate dialog * * @param parent the parent widget * @param name the internal name of this instance * @param modal create a modal dialog if set to true */ explicit KSSLCertDialog(QWidget *parent=0L, const char *name=0L, bool modal=false); /** * Destroy this object and close the dialog */ virtual ~KSSLCertDialog(); /** * Setup the dialog. Call this before you display the dialog. * * @param certs the list of possible certificates * @param saveChecked save the checked item for the future * @param sendChecked send the checked item to the remote host */ void setupDialog(const QStringList& certs, bool saveChecked = false, bool sendChecked = true); /** * Obtain the name of the certificate the user wants to send * * @return the name of the certificate */ QString getChoice(); /** * Determine if the user wants to send a certificate. * * @return true if the user wants to send a certificate */ bool wantsToSend(); /** * Determine if the user wants to save the choice for the future. * * @return true if the user wants to save the choice. */ bool saveChoice(); /** * Set the hostname that we are connecting to. * * @param host the hostname */ void setHost(const QString& host); private Q_SLOTS: void slotSend(); void slotDont(); private: class KSSLCertDialogPrivate; KSSLCertDialogPrivate* const d; QCheckBox *_save; QRadioButton *_send, *_dont; QListWidget *_certs; QPushButton *_ok; QString _host; }; /** * This class is used in the internal DCOP communication between TPCSlaveBase and kuiserver. * Don't use it directly. * \internal */ class KIO_EXPORT KSSLCertDialogRet { public: QString choice; bool ok; bool send; bool save; }; KIO_EXPORT QDataStream& operator<<(QDataStream& s, const KSSLCertDialogRet& r); KIO_EXPORT QDataStream& operator>>(QDataStream& s, KSSLCertDialogRet& r); #endif