Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
meta-nemo
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
NemoMobile
meta-nemo
Commits
cbdf7274
Commit
cbdf7274
authored
Jan 24, 2019
by
Florent Revest
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
nemo-qml-plugin-systemsettings: Fix build with thud's OpenSSL
parent
e6cbe53b
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
960 additions
and
1 deletion
+960
-1
0005-Disable-build-of-CertificatteModel-which-is-broken-w.patch
...isable-build-of-CertificatteModel-which-is-broken-w.patch
+958
-0
nemo-qml-plugin-systemsettings_git.bb
...le/nemo-qml-plugins/nemo-qml-plugin-systemsettings_git.bb
+2
-1
No files found.
recipes-nemomobile/nemo-qml-plugins/nemo-qml-plugin-systemsettings/0005-Disable-build-of-CertificatteModel-which-is-broken-w.patch
0 → 100644
View file @
cbdf7274
From 01c2be2fecca5e4133e2f5b4076f39c0a96f8d42 Mon Sep 17 00:00:00 2001
From: Florent Revest <revestflo@gmail.com>
Date: Mon, 3 Dec 2018 13:22:52 +0100
Subject: [PATCH] Disable build of CertificatteModel which is broken with
OpenSSL 1.1
---
src/certificatemodel.cpp | 754 ---------------------------------------
src/certificatemodel.h | 134 -------
src/plugin/plugin.cpp | 2 -
src/src.pro | 2 -
4 files changed, 892 deletions(-)
delete mode 100644 src/certificatemodel.cpp
delete mode 100644 src/certificatemodel.h
diff --git a/src/certificatemodel.cpp b/src/certificatemodel.cpp
deleted file mode 100644
index 4fa565a..0000000
--- a/src/certificatemodel.cpp
+++ /dev/null
@@ -1,754 +0,0 @@
-/*
- * Copyright (C) 2016 Jolla Ltd.
- * COntact: Matt Vogt <matthew.vogt@jollamobile.com>
- *
- * You may use this file under the terms of the BSD license as follows:
- *
- * "Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are
- * met:
- * * Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * * Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in
- * the documentation and/or other materials provided with the
- * distribution.
- * * Neither the name of Nemo Mobile nor the names of its contributors
- * may be used to endorse or promote products derived from this
- * software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
- * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
- * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
- * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
- */
-
-#include "certificatemodel.h"
-
-#include <QFile>
-#include <QRegularExpression>
-#include <QDebug>
-
-#include <openssl/opensslv.h>
-#include <openssl/bio.h>
-#include <openssl/conf.h>
-#include <openssl/engine.h>
-#include <openssl/err.h>
-#include <openssl/evp.h>
-#include <openssl/pem.h>
-#include <openssl/x509v3.h>
-
-namespace {
-
-struct X509List;
-
-}
-
-struct X509Certificate
-{
- QList<QPair<QString, QString>> subjectList(bool shortForm = false) const
- {
- return nameList(X509_get_subject_name(x509), shortForm);
- }
- QString subject(bool shortForm = true, const QString &separator = QString(", ")) const
- {
- return toString(subjectList(shortForm), separator);
- }
- QString subjectElement(int nid) const
- {
- return nameElement(X509_get_subject_name(x509), nid);
- }
-
- QList<QPair<QString, QString>> issuerList(bool shortForm = false) const
- {
- return nameList(X509_get_issuer_name(x509), shortForm);
- }
- QString issuer(bool shortForm = true, const QString &separator = QString(", ")) const
- {
- return toString(issuerList(shortForm), separator);
- }
- QString issuerElement(int nid) const
- {
- return nameElement(X509_get_issuer_name(x509), nid);
- }
-
- QString version() const
- {
- return QString::number(X509_get_version(x509) + 1);
- }
-
- QString serialNumber() const
- {
- return integerToString(X509_get_serialNumber(x509));
- }
-
- QDateTime notBefore() const
- {
- return toDateTime(X509_get_notBefore(x509));
- }
-
- QDateTime notAfter() const
- {
- return toDateTime(X509_get_notAfter(x509));
- }
-
- QList<QPair<QString, QString>> publicKeyList(bool shortForm = false) const
- {
- QList<QPair<QString, QString>> rv;
-
- if (EVP_PKEY *key = X509_get_pubkey(x509)) {
- rv.append(qMakePair(QStringLiteral("Algorithm"), idToString(EVP_PKEY_id(key), shortForm)));
- rv.append(qMakePair(QStringLiteral("Bits"), QString::number(EVP_PKEY_bits(key))));
-
- BIO *b = BIO_new(BIO_s_mem());
- EVP_PKEY_print_public(b, key, 0, 0);
- const QList<QPair<QString, QString>> &details(parseData(bioToString(b)));
- for (auto it = details.cbegin(), end = details.cend(); it != end; ++it) {
- rv.append(qMakePair(it->first, it->second));
- }
- BIO_free(b);
-
- EVP_PKEY_free(key);
- }
-
- return rv;
- }
-
- QList<QPair<QString, QString>> extensionList(bool shortForm = false) const
- {
- QList<QPair<QString, QString>> rv;
-
- for (int i = 0, n = sk_X509_EXTENSION_num(x509->cert_info->extensions); i < n; ++i) {
- X509_EXTENSION *extension = sk_X509_EXTENSION_value(x509->cert_info->extensions, i);
-
- ASN1_OBJECT *object = X509_EXTENSION_get_object(extension);
- int nid = OBJ_obj2nid(object);
- if (nid == NID_undef)
- continue;
-
- QString name(objectToString(object, shortForm));
- if (X509_EXTENSION_get_critical(extension) > 0) {
- name.append(QStringLiteral(" (Critical)"));
- }
-
- BIO *b = BIO_new(BIO_s_mem());
- X509V3_EXT_print(b, extension, 0, 0);
- rv.append(qMakePair(name, bioToString(b)));
- BIO_free(b);
- }
-
- return rv;
- }
-
- QList<QPair<QString, QString>> signatureList(bool shortForm = false) const
- {
- QList<QPair<QString, QString>> rv;
-
- rv.append(qMakePair(QStringLiteral("Algorithm"), objectToString(x509->sig_alg->algorithm, shortForm)));
-
- BIO *b = BIO_new(BIO_s_mem());
- X509_signature_dump(b, x509->signature, 0);
- QString d(bioToString(b).replace(QChar('\n'), QString()));
- rv.append(qMakePair(QStringLiteral("Data"), d.trimmed()));
- BIO_free(b);
-
- return rv;
- }
-
-private:
- static QString stringToString(ASN1_STRING *data)
- {
- return QString::fromUtf8(reinterpret_cast<char*>(ASN1_STRING_data(data)));
- }
-
- static QString timeToString(ASN1_TIME *data)
- {
- return stringToString(data);
- }
-
- static QString idToString(int nid, bool shortForm)
- {
- return QString::fromUtf8(shortForm ? OBJ_nid2sn(nid) : OBJ_nid2ln(nid));
- }
-
- static QString objectToString(ASN1_OBJECT *object, bool shortForm)
- {
- return idToString(OBJ_obj2nid(object), shortForm);
- }
-
- static QString integerToString(ASN1_INTEGER *integer)
- {
- if (integer->type != V_ASN1_INTEGER && integer->type != V_ASN1_NEG_INTEGER)
- return QString();
-
- quint64 value = 0;
- for (size_t i = 0, n = qMin(integer->length, 8); i < n; ++i)
- value = value << 8 | integer->data[i];
-
- QString rv = QString::number(value);
- if (integer->type == V_ASN1_NEG_INTEGER)
- rv.prepend(QStringLiteral("-"));
- return rv;
- }
-
- static QString bioToString(BIO *bio)
- {
- char *out = 0;
- int n = BIO_get_mem_data(bio, &out);
- return QString::fromUtf8(QByteArray::fromRawData(out, n));
- }
-
- static QList<QPair<QString, QString>> nameList(X509_NAME *name, bool shortForm = true)
- {
- QList<QPair<QString, QString>> rv;
-
- for (int i = 0, n = X509_NAME_entry_count(name); i < n; ++i) {
- X509_NAME_ENTRY *entry = X509_NAME_get_entry(name, i);
- ASN1_OBJECT *object = X509_NAME_ENTRY_get_object(entry);
- ASN1_STRING *data = X509_NAME_ENTRY_get_data(entry);
- rv.append(qMakePair(objectToString(object, shortForm), stringToString(data)));
- }
-
- return rv;
- }
-
- static QString nameElement(X509_NAME *name, int nid)
- {
- for (int i = 0, n = X509_NAME_entry_count(name); i < n; ++i) {
- X509_NAME_ENTRY *entry = X509_NAME_get_entry(name, i);
- ASN1_OBJECT *object = X509_NAME_ENTRY_get_object(entry);
- if (OBJ_obj2nid(object) == nid) {
- ASN1_STRING *data = X509_NAME_ENTRY_get_data(entry);
- return stringToString(data);
- }
- }
-
- return QString();
- }
-
- static QString toString(const QList<QPair<QString, QString>> &list, const QString &separator = QString(", "))
- {
- QString rv;
-
- for (auto it = list.cbegin(), end = list.cend(); it != end; ++it) {
- if (!rv.isEmpty()) {
- rv.append(separator);
- }
- rv.append(it->first);
- rv.append(QChar(':'));
- rv.append(it->second);
- }
-
- return rv;
- }
-
- static QDateTime toDateTime(ASN1_TIME *time)
- {
- const QString ts(timeToString(time));
- return (time->type == V_ASN1_GENERALIZEDTIME ? fromGENERALIZEDTIME(ts) : fromUTCTIME(ts));
- }
-
- static QDateTime fromUTCTIME(const QString &ts)
- {
- QDate d;
- QTime t;
- int offset = 0;
-
- // "YYMMDDhhmm[ss](Z|(+|-)hhmm)"
- const QRegularExpression re("([0-9]{2})([0-9]{2})([0-9]{2})([0-9]{2})([0-9]{2})([0-9]{2})?(Z)?(([+-])([0-9]{2})([0-9]{2}))?");
- QRegularExpressionMatch match = re.match(ts);
- if (match.hasMatch()) {
- int y = match.captured(1).toInt();
- d = QDate((y < 70 ? 2000 : 1900) + y, match.captured(2).toInt(), match.captured(3).toInt());
-
- t = QTime(match.captured(4).toInt(), match.captured(5).toInt(), match.captured(6).toInt());
-
- if (match.lastCapturedIndex() > 7) {
- offset = match.captured(11).toInt() * 60 + match.captured(10).toInt() * 60*60;
- if (match.captured(9) == "-") {
- offset = -offset;
- }
- }
- }
-
- return QDateTime(d, t, Qt::OffsetFromUTC, offset);
- }
-
- static QDateTime fromGENERALIZEDTIME(const QString &ts)
- {
- QDate d;
- QTime t;
- int offset = 0;
-
- // "YYYYMMDDhh[mm[ss[.fff]]](Z|(+|-)hhmm)" <- nested optionals can be treated as appearing sequentially
- const QRegularExpression re("([0-9]{4})([0-9]{2})([0-9]{2})([0-9]{2})([0-9]{2})?([0-9]{2})?(\\.[0-9]{1,3})?(Z)?(([+-])([0-9]{2})([0-9]{2}))?");
- QRegularExpressionMatch match = re.match(ts);
- if (match.hasMatch()) {
- d = QDate(match.captured(1).toInt(), match.captured(2).toInt(), match.captured(3).toInt());
-
- double fraction = match.captured(7).toDouble();
- int ms = (fraction * 1000);
- t = QTime(match.captured(4).toInt(), match.captured(5).toInt(), match.captured(6).toInt(), ms);
-
- if (match.lastCapturedIndex() > 8) {
- offset = match.captured(12).toInt() * 60 + match.captured(11).toInt() * 60*60;
- if (match.captured(10) == "-") {
- offset = -offset;
- }
- }
- }
-
- return QDateTime(d, t, Qt::OffsetFromUTC, offset);
- }
-
- static QList<QPair<QString, QString>> parseData(QString data)
- {
- QList<QPair<QString, QString>> rv;
-
- // Join any data with the preceding header
- data.replace(QRegularExpression(": *\n +"), QStringLiteral(":"));
- foreach (const QString &line, data.split(QString("\n"), QString::SkipEmptyParts)) {
- int index = line.indexOf(QChar(':'));
- if (index != -1) {
- QString name(line.left(index));
- QString value(line.mid(index + 1).trimmed());
- rv.append(qMakePair(name, value));
- }
- }
-
- return rv;
- }
-
- friend X509List;
-
- X509Certificate(X509 *x) : x509(x) {}
-
- X509 *x509;
-};
-
-namespace {
-
-struct X509List
-{
- X509List()
- : crlStack(0), certificateStack(0), pkcs7(0), pkcs7Signed(0)
- {
- crlStack = sk_X509_CRL_new_null();
- if (!crlStack) {
- qWarning() << "Unable to allocate CRL stack";
- } else {
- certificateStack = sk_X509_new_null();
- if (!certificateStack) {
- qWarning() << "Unable to allocate X509 stack";
- } else {
- pkcs7 = PKCS7_new();
- pkcs7Signed = PKCS7_SIGNED_new();
- if (!pkcs7 || !pkcs7Signed) {
- qWarning() << "Unable to create PKCS7 structures";
- } else {
- pkcs7Signed->crl = crlStack;
- pkcs7Signed->cert = certificateStack;
-
- pkcs7->type = OBJ_nid2obj(NID_pkcs7_signed);
- pkcs7->d.sign = pkcs7Signed;
- pkcs7Signed->contents->type = OBJ_nid2obj(NID_pkcs7_data);
- if (!ASN1_INTEGER_set(pkcs7Signed->version, 1)) {
- qWarning() << "Unable to set PKCS7 signed version";
- }
- }
- }
- }
- }
-
- ~X509List()
- {
- /* Apparently, pkcs7Signed and pkcs7 cannot be safely freed...
- if (pkcs7Signed)
- PKCS7_SIGNED_free(pkcs7Signed);
- if (pkcs7)
- PKCS7_free(pkcs7);
- */
- if (certificateStack)
- sk_X509_free(certificateStack);
- if (crlStack)
- sk_X509_CRL_free(crlStack);
- }
-
- bool isValid() const
- {
- return pkcs7 && pkcs7Signed;
- }
-
- int count() const
- {
- return sk_X509_num(certificateStack);
- }
-
- void append(X509 *x509)
- {
- sk_X509_push(certificateStack, x509);
- }
-
- void for_each(std::function<void (const X509Certificate &)> fn) const
- {
- for (int i = 0, n(count()); i < n; ++i) {
- fn(X509Certificate(sk_X509_value(certificateStack, i)));
- }
- }
-
-private:
- STACK_OF(X509_CRL) *crlStack;
- STACK_OF(X509) *certificateStack;
- PKCS7 *pkcs7;
- PKCS7_SIGNED *pkcs7Signed;
-};
-
-struct PKCS7File
-{
- explicit PKCS7File(const QString &path)
- {
- if (!isValid()) {
- qWarning() << "Unable to prepare X509 certificates structure";
- } else {
- BIO *input = BIO_new(BIO_s_file());
- if (!input) {
- qWarning() << "Unable to allocate new BIO for:" << path;
- } else {
- const QByteArray filename(QFile::encodeName(path));
- if (BIO_read_filename(input, const_cast<char *>(filename.constData())) <= 0) {
- qWarning() << "Unable to open PKCS7 file:" << path;
- } else {
- STACK_OF(X509_INFO) *certificateStack = PEM_X509_INFO_read_bio(input, NULL, NULL, NULL);
- if (!certificateStack) {
- qWarning() << "Unable to read PKCS7 file:" << path;
- } else {
- while (sk_X509_INFO_num(certificateStack)) {
- X509_INFO *certificateInfo = sk_X509_INFO_shift(certificateStack);
- if (certificateInfo->x509 != NULL) {
- certs.append(certificateInfo->x509);
- certificateInfo->x509 = NULL;
- }
- X509_INFO_free(certificateInfo);
- }
-
- sk_X509_INFO_free(certificateStack);
- }
- }
-
- BIO_free(input);
- }
- }
- }
-
- ~PKCS7File()
- {
- }
-
- bool isValid() const
- {
- return certs.isValid();
- }
-
- int count() const
- {
- return certs.count();
- }
-
- const X509List &getCertificates()
- {
- return certs;
- }
-
-private:
- X509List certs;
-};
-
-class LibCrypto
-{
- struct Initializer
- {
- Initializer()
- {
- // As per: https://wiki.openssl.org/index.php/Library_Initialization#libcrypto_Initialization
- OpenSSL_add_all_algorithms();
- ERR_load_crypto_strings();
- OPENSSL_config(NULL);
- }
-
- ~Initializer()
- {
- FIPS_mode_set(0);
- ENGINE_cleanup();
- CONF_modules_unload(1);
- EVP_cleanup();
- CRYPTO_cleanup_all_ex_data();
- ERR_remove_thread_state(NULL);
- ERR_free_strings();
- }
- };
-
- static Initializer init;
-
-public:
- static QList<Certificate> getCertificates(const QString &bundlePath)
- {
- QList<Certificate> certificates;
-
- PKCS7File bundle(bundlePath);
- if (bundle.isValid() && bundle.count() > 0) {
- certificates.reserve(bundle.count());
- bundle.getCertificates().for_each([&certificates](const X509Certificate &cert) {
- certificates.append(Certificate(cert));
- });
- }
-
- return certificates;
- }
-};
-
-LibCrypto::Initializer LibCrypto::init;
-
-const QList<QPair<QString, CertificateModel::BundleType> > &bundlePaths()
-{
- static QList<QPair<QString, CertificateModel::BundleType> > paths;
- if (paths.isEmpty()) {
- paths.append(qMakePair(QString("/etc/pki/ca-trust/extracted/pem/tls-ca-bundle.pem"), CertificateModel::TLSBundle));
- paths.append(qMakePair(QString("/etc/pki/ca-trust/extracted/pem/email-ca-bundle.pem"), CertificateModel::EmailBundle));
- paths.append(qMakePair(QString("/etc/pki/ca-trust/extracted/pem/objsign-ca-bundle.pem"), CertificateModel::ObjectSigningBundle));
- }
- return paths;
-}
-
-CertificateModel::BundleType bundleType(const QString &path)
-{
- if (path.isEmpty())
- return CertificateModel::NoBundle;
-
- const QList<QPair<QString, CertificateModel::BundleType> > &bundles(bundlePaths());
- for (auto it = bundles.cbegin(), end = bundles.cend(); it != end; ++it) {
- if (it->first == path)
- return it->second;
- }
-
- return CertificateModel::UserSpecifiedBundle;
-}
-
-QString bundlePath(CertificateModel::BundleType type)
-{
- if (type == CertificateModel::UserSpecifiedBundle)
- return QString();
-
- const QList<QPair<QString, CertificateModel::BundleType> > &bundles(bundlePaths());
- for (auto it = bundles.cbegin(), end = bundles.cend(); it != end; ++it) {
- if (it->second == type)
- return it->first;
- }
-
- return QStringLiteral("");
-}
-
-}
-
-Certificate::Certificate(const X509Certificate &cert)
- : m_commonName(cert.subjectElement(NID_commonName))
- , m_countryName(cert.subjectElement(NID_countryName))
- , m_organizationName(cert.subjectElement(NID_organizationName))
- , m_organizationalUnitName(cert.subjectElement(NID_organizationalUnitName))
- , m_notValidBefore(cert.notBefore())
- , m_notValidAfter(cert.notAfter())
-{
- // Yield consistent names for the certificates, despite inconsistent naming policy
- QString Certificate::*members[] = { &Certificate::m_commonName, &Certificate::m_organizationalUnitName, &Certificate::m_organizationName, &Certificate::m_countryName };
- for (auto it = std::begin(members); it != std::end(members); ++it) {
- const QString &s(this->*(*it));
- if (!s.isEmpty()) {
- if (m_primaryName.isEmpty()) {
- m_primaryName = s;
- } else if (m_secondaryName.isEmpty()) {
- m_secondaryName = s;
- break;
- }
- }
- }
-
- // Populate the details map
- m_details.insert(QStringLiteral("Version"), QVariant(cert.version()));
- m_details.insert(QStringLiteral("SerialNumber"), QVariant(cert.serialNumber()));
-
- QVariantMap validity;
- validity.insert(QStringLiteral("NotBefore"), QVariant(cert.notBefore()));
- validity.insert(QStringLiteral("NotAfter"), QVariant(cert.notAfter()));
- m_details.insert(QStringLiteral("Validity"), QVariant(validity));
-
- QVariantMap issuer;
- const QList<QPair<QString, QString>> &issuerDetails(cert.issuerList());
- for (auto it = issuerDetails.cbegin(), end = issuerDetails.cend(); it != end; ++it) {
- issuer.insert(it->first, QVariant(it->second));
- }
- m_details.insert(QStringLiteral("Issuer"), QVariant(issuer));
-
- QVariantMap subject;
- const QList<QPair<QString, QString>> &subjectDetails(cert.subjectList());
- for (auto it = subjectDetails.cbegin(), end = subjectDetails.cend(); it != end; ++it) {
- subject.insert(it->first, QVariant(it->second));
- }
- m_details.insert(QStringLiteral("Subject"), QVariant(subject));
-
- QVariantMap publicKey;
- const QList<QPair<QString, QString>> &keyDetails(cert.publicKeyList());
- for (auto it = keyDetails.cbegin(), end = keyDetails.cend(); it != end; ++it) {
- publicKey.insert(it->first, QVariant(it->second));
- }
- m_details.insert(QStringLiteral("SubjectPublicKeyInfo"), QVariant(publicKey));
-
- QVariantMap extensions;
- const QList<QPair<QString, QString>> &extensionDetails(cert.extensionList());
- for (auto it = extensionDetails.cbegin(), end = extensionDetails.cend(); it != end; ++it) {
- extensions.insert(it->first, QVariant(it->second));
- }
- m_details.insert(QStringLiteral("Extensions"), extensions);
-
- QVariantMap signature;
- const QList<QPair<QString, QString>> &signatureDetails(cert.signatureList());
- for (auto it = signatureDetails.cbegin(), end = signatureDetails.cend(); it != end; ++it) {
- signature.insert(it->first, QVariant(it->second));
- }
- m_details.insert(QStringLiteral("Signature"), signature);
-}
-
-CertificateModel::CertificateModel(QObject *parent)
- : QAbstractListModel(parent)
- , m_type(NoBundle)
-{
-}
-
-CertificateModel::~CertificateModel()
-{
-}
-
-CertificateModel::BundleType CertificateModel::bundleType() const
-{
- return m_type;
-}
-
-void CertificateModel::setBundleType(BundleType type)
-{
- if (m_type != type) {
- m_type = type;
-
- const QString path(::bundlePath(m_type));
- if (!path.isNull())
- setBundlePath(path);
-
- emit bundleTypeChanged();
- }
-}
-
-QString CertificateModel::bundlePath() const
-{
- return m_path;
-}
-
-void CertificateModel::setBundlePath(const QString &path)
-{
- if (m_path != path) {
- m_path = path;
- refresh();
-
- const BundleType type(::bundleType(m_path));
- setBundleType(type);
-
- emit bundlePathChanged();
- }
-}
-
-int CertificateModel::rowCount(const QModelIndex & parent) const
-{
- Q_UNUSED(parent)
- return m_certificates.count();
-}
-
-QVariant CertificateModel::data(const QModelIndex &index, int role) const
-{
- int row = index.row();
- if (row < 0 || row >= m_certificates.count()) {
- return QVariant();
- }
-
- const Certificate &cert = m_certificates.at(row);
- switch (role) {
- case CommonNameRole:
- return cert.commonName();
- case CountryNameRole:
- return cert.countryName();
- case OrganizationNameRole:
- return cert.organizationName();
- case OrganizationalUnitNameRole:
- return cert.organizationalUnitName();
- case PrimaryNameRole:
- return cert.primaryName();
- case SecondaryNameRole:
- return cert.secondaryName();
- case NotValidBeforeRole:
- return cert.notValidBefore();
- case NotValidAfterRole:
- return cert.notValidAfter();
- case DetailsRole:
- return cert.details();
- default:
- break;
- }
-
- return QVariant();
-}
-
-QHash<int, QByteArray> CertificateModel::roleNames() const
-{
- QHash<int, QByteArray> roles;
-
- roles[CommonNameRole] = "commonName";
- roles[CountryNameRole] = "countryName";
- roles[OrganizationNameRole] = "organizationName";
- roles[OrganizationalUnitNameRole] = "organizationalUnitName";
- roles[PrimaryNameRole] = "primaryName";
- roles[SecondaryNameRole] = "secondaryName";
- roles[NotValidBeforeRole] = "notValidBefore";
- roles[NotValidAfterRole] = "notValidAfter";
- roles[DetailsRole] = "details";
-
- return roles;
-}
-void CertificateModel::refresh()
-{
- beginResetModel();
- if (m_path.isEmpty()) {
- m_certificates.clear();
- } else {
- m_certificates = getCertificates(m_path);
- std::stable_sort(m_certificates.begin(), m_certificates.end(), [](const Certificate &lhs, const Certificate &rhs) {
- int c = lhs.primaryName().compare(rhs.primaryName(), Qt::CaseInsensitive);
- if (c < 0)
- return true;
- if (c > 0)
- return false;
- c = lhs.secondaryName().compare(rhs.secondaryName(), Qt::CaseInsensitive);
- if (c < 0)
- return true;
- return false;
- });
- }
- endResetModel();
-}
-
-QList<Certificate> CertificateModel::getCertificates(const QString &bundlePath)
-{
- return LibCrypto::getCertificates(bundlePath);
-}
-
diff --git a/src/certificatemodel.h b/src/certificatemodel.h
deleted file mode 100644
index b6cad18..0000000
--- a/src/certificatemodel.h
+++ /dev/null
@@ -1,134 +0,0 @@
-/*
- * Copyright (C) 2016 Jolla Ltd.
- * Contact: Matt Vogt <matthew.vogt@jollamobile.com>
- *
- * You may use this file under the terms of the BSD license as follows:
- *
- * "Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are
- * met:
- * * Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * * Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in
- * the documentation and/or other materials provided with the
- * distribution.
- * * Neither the name of Nemo Mobile nor the names of its contributors
- * may be used to endorse or promote products derived from this
- * software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
- * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
- * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
- * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
- */
-
-#ifndef CERTIFICATEMODEL_H
-#define CERTIFICATEMODEL_H
-
-#include <QAbstractListModel>
-#include <QDateTime>
-#include <QList>
-#include <QVariantMap>
-
-#include <systemsettingsglobal.h>
-
-
-struct X509Certificate;
-
-class SYSTEMSETTINGS_EXPORT Certificate
-{
-public:
- Certificate(const X509Certificate &cert);
-
- QString commonName() const { return m_commonName; }
- QString countryName() const { return m_countryName; }
- QString organizationName() const { return m_organizationName; }
- QString organizationalUnitName() const { return m_organizationalUnitName; }
- QString primaryName() const { return m_primaryName; }
- QString secondaryName() const { return m_secondaryName; }
-
- QDateTime notValidBefore() const { return m_notValidBefore; }
- QDateTime notValidAfter() const { return m_notValidAfter; }
-
- QVariantMap details() const { return m_details; }
-
-private:
- QString m_commonName;
- QString m_countryName;
- QString m_organizationName;
- QString m_organizationalUnitName;
- QString m_primaryName;
- QString m_secondaryName;
-
- QDateTime m_notValidBefore;
- QDateTime m_notValidAfter;
-
- QVariantMap m_details;
-};
-
-class SYSTEMSETTINGS_EXPORT CertificateModel: public QAbstractListModel
-{
- Q_OBJECT
- Q_PROPERTY(BundleType bundleType READ bundleType WRITE setBundleType NOTIFY bundleTypeChanged)
- Q_PROPERTY(QString bundlePath READ bundlePath WRITE setBundlePath NOTIFY bundlePathChanged)
- Q_ENUMS(BundleType)
-
-public:
- enum BundleType {
- NoBundle,
- TLSBundle,
- EmailBundle,
- ObjectSigningBundle,
- UserSpecifiedBundle,
- };
-
- enum CertificateRoles {
- CommonNameRole = Qt::UserRole + 1,
- CountryNameRole = Qt::UserRole + 2,
- OrganizationNameRole = Qt::UserRole + 3,
- OrganizationalUnitNameRole = Qt::UserRole + 4,
- PrimaryNameRole = Qt::UserRole + 5,
- SecondaryNameRole = Qt::UserRole + 6,
- NotValidBeforeRole = Qt::UserRole + 7,
- NotValidAfterRole = Qt::UserRole + 8,
- DetailsRole = Qt::UserRole + 9,
- };
-
- explicit CertificateModel(QObject *parent = 0);
- virtual ~CertificateModel();
-
- BundleType bundleType() const;
- void setBundleType(BundleType type);
-
- QString bundlePath() const;
- void setBundlePath(const QString &path);
-
- virtual int rowCount(const QModelIndex & parent = QModelIndex()) const;
- virtual QVariant data(const QModelIndex &index, int role) const;
-
- static QList<Certificate> getCertificates(const QString &bundlePath);
-
-signals:
- void bundleTypeChanged();
- void bundlePathChanged();
-
-protected:
- void refresh();
-
- QHash<int, QByteArray> roleNames() const;
-
-private:
- BundleType m_type;
- QString m_path;
- QList<Certificate> m_certificates;
-};
-
-#endif
diff --git a/src/plugin/plugin.cpp b/src/plugin/plugin.cpp
index 1da0ab6..4be61f1 100644
--- a/src/plugin/plugin.cpp
+++ b/src/plugin/plugin.cpp
@@ -46,7 +46,6 @@
#include "batterystatus.h"
#include "diskusage.h"
#include "partitionmodel.h"
-#include "certificatemodel.h"
#include "vpnmodel.h"
#include "locationsettings.h"
#include "deviceinfo.h"
@@ -80,7 +79,6 @@
public:
qmlRegisterType<AboutSettings>(uri, 1, 0, "AboutSettings");
qmlRegisterType<PartitionModel>(uri, 1, 0, "PartitionModel");
qmlRegisterType<DeveloperModeSettings>(uri, 1, 0, "DeveloperModeSettings");
- qmlRegisterType<CertificateModel>(uri, 1, 0, "CertificateModel");
qmlRegisterSingletonType<VpnModel>(uri, 1, 0, "VpnModel", vpnmodel_api_factory);
qRegisterMetaType<DeveloperModeSettings::Status>("DeveloperModeSettings::Status");
qmlRegisterType<BatteryStatus>(uri, 1, 0, "BatteryStatus");
diff --git a/src/src.pro b/src/src.pro
index d86d61b..d4f9c31 100644
--- a/src/src.pro
+++ b/src/src.pro
@@ -21,7 +21,6 @@
SOURCES += \
mceiface.cpp \
displaysettings.cpp \
aboutsettings.cpp \
- certificatemodel.cpp \
vpnmodel.cpp \
connmanvpnproxy.cpp \
connmanvpnconnectionproxy.cpp \
@@ -44,7 +43,6 @@
PUBLIC_HEADERS = \
mceiface.h \
displaysettings.h \
aboutsettings.h \
- certificatemodel.h \
vpnmodel.h \
connmanvpnproxy.h \
connmanvpnconnectionproxy.h \
--
2.19.1
recipes-nemomobile/nemo-qml-plugins/nemo-qml-plugin-systemsettings_git.bb
View file @
cbdf7274
...
@@ -7,7 +7,8 @@ SRC_URI = "git://git.merproject.org/mer-core/nemo-qml-plugin-systemsettings.git;
...
@@ -7,7 +7,8 @@ SRC_URI = "git://git.merproject.org/mer-core/nemo-qml-plugin-systemsettings.git;
file://location.conf \
file://location.conf \
file://0001-Disable-SSU-dependency.patch \
file://0001-Disable-SSU-dependency.patch \
file://0002-languagemodel-install-languages-in-usr-share-support.patch \
file://0002-languagemodel-install-languages-in-usr-share-support.patch \
file://0004-LanguageModel-Notify-asteroid-launcher-of-locale-cha.patch"
file://0004-LanguageModel-Notify-asteroid-launcher-of-locale-cha.patch \
file://0005-Disable-build-of-CertificatteModel-which-is-broken-w.patch"
SRCREV = "0c3034612fabce0cca18366f6ac04020296428cf"
SRCREV = "0c3034612fabce0cca18366f6ac04020296428cf"
PR = "r1"
PR = "r1"
PV = "+git${SRCPV}"
PV = "+git${SRCPV}"
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment