/* ============================================================ * * This file is a part of the rekonq project * * Copyright (C) 2011 by Andrea Diamantini * * * This program 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 2 of * the License or (at your option) version 3 or any later version * accepted by the membership of KDE e.V. (or its successor approved * by the membership of KDE e.V.), which shall act as a proxy * defined in Section 14 of version 3 of the license. * * This program 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 this program. If not, see . * * ============================================================ */ // Auto Includes #include "sslwidget.h" #include "sslwidget.moc" // Local includes #include "application.h" #include "historymanager.h" #include "sslinfodialog.h" // KDE Includes // Qt Includes #include #include #include #include SSLWidget::SSLWidget(const QUrl &url, const WebSslInfo &info, QWidget *parent) : QMenu(parent) , m_url(url) , m_info(info) { setAttribute(Qt::WA_DeleteOnClose); setMinimumWidth(400); QList caList = info.certificateChain(); QSslCertificate firstCA = caList.first(); QFormLayout *layout = new QFormLayout(this); QLabel *label; // ------------------------------------------------------------------------------------------------------------------ label = new QLabel(this); label->setText( i18n("

Identity

") ); layout->addRow(label); if (firstCA.isNull()) { label = new QLabel(this); label->setText( i18n("Warning: this site is carrying a NULL certificate") ); layout->addRow(label); } else { if (firstCA.isValid()) { label = new QLabel(this); label->setText( i18n("This certificate for this site is Valid and has been verified by ") + firstCA.subjectInfo(QSslCertificate::CommonName) ); layout->addRow(label); } else { label = new QLabel(this); label->setText( i18n("Warning: The certificate for this site is NOT valid!") ); layout->addRow(label); } label = new QLabel(this); label->setText("Certificate Information"); connect(label, SIGNAL(linkActivated(const QString &)), this, SLOT(showMoreSslInfos(const QString &))); layout->addRow(label); // ------------------------------------------------------------------------------------------------------------------ label = new QLabel(this); label->setText( QL1S("

Encryption

") ); // ----------------------------------------------- // layout->addRow(label); label = new QLabel(this); label->setText( QL1S("COMMON NAME: ") + firstCA.subjectInfo(QSslCertificate::CommonName) ); layout->addRow(label); label = new QLabel(this); label->setText( QL1S("ORGANIZATION: ") + firstCA.subjectInfo(QSslCertificate::Organization) ); layout->addRow(label); label = new QLabel(this); label->setText( QL1S("ORGANIZATION UNIT: ") + firstCA.subjectInfo(QSslCertificate::OrganizationalUnitName) ); layout->addRow(label); label = new QLabel(this); label->setText( QL1S("SERIAL NUMBER: ") + QL1S( firstCA.serialNumber().toHex() ) ); layout->addRow(label); label = new QLabel(this); label->setText( QL1S("

") + i18n("Issued by") + QL1S("

") ); layout->addRow(label); label = new QLabel(this); label->setText( QL1S("COMMON NAME: ") + firstCA.issuerInfo(QSslCertificate::CommonName) ); layout->addRow(label); label = new QLabel(this); label->setText( QL1S("ORGANIZATION: ") + firstCA.issuerInfo(QSslCertificate::Organization) ); layout->addRow(label); label = new QLabel(this); label->setText( QL1S("ORGANIZATION UNIT: ") + firstCA.issuerInfo(QSslCertificate::OrganizationalUnitName) ); layout->addRow(label); label = new QLabel(this); label->setText( QL1S("

") + i18n("Validity Period") + QL1S("

") ); layout->addRow(label); label = new QLabel(this); label->setText( i18n("Issued on: ") + firstCA.effectiveDate().date().toString(Qt::SystemLocaleShortDate) ); layout->addRow(label); label = new QLabel(this); label->setText( i18n("Expires on: ") + firstCA.expiryDate().date().toString(Qt::SystemLocaleShortDate) ); layout->addRow(label); label = new QLabel(this); label->setText( QL1S("

") + i18n("FingerPrints") + QL1S("

") ); layout->addRow(label); label = new QLabel(this); label->setText( QL1S("SHA1 FingerPrint: ") + QL1S( firstCA.digest(QCryptographicHash::Sha1).toHex() ) ); layout->addRow(label); label = new QLabel(this); label->setText( QL1S("MD5 FingerPrint: ") + QL1S( firstCA.digest(QCryptographicHash::Md5).toHex() ) ); layout->addRow(label); } // ------------------------------------------------------------------------------------------------------------------ label = new QLabel(this); label->setText( i18n("

Site Information

") ); layout->addRow(label); label = new QLabel(this); if (rApp->historyManager()->historyContains(url.toString())) //FIXME change with visit count > 1 { label->setText( i18n("You just visited this site") ); } else { label->setText( i18n("It's your first time visiting this site") ); } layout->addRow(label); // ----------------------------------------------------------------------------------- setLayout(layout); } void SSLWidget::showAt(const QPoint &pos) { adjustSize(); QPoint p(pos.x() - width(), pos.y() + 10); move(p); show(); } void SSLWidget::accept() { close(); } void SSLWidget::showMoreSslInfos(const QString &) { // FIXME: show it every time??? if (m_info.isValid()) { QPointer dlg = new SslInfoDialog(m_url.host(), m_info, this); // dlg->setSslInfo(m_info.certificateChain(), // m_info.peerAddress().toString(), // m_host, // m_info.protocol(), // m_info.ciphers(), // m_info.usedChiperBits(), // m_info.supportedChiperBits() // ); dlg->exec(); delete dlg; return; } }