Commit 66d4ee06 authored by mvogt's avatar mvogt

[nemo-qml-plugin-systemsettings] Add a model for system certificates. Contributes to MER#1627

parent 82d80e45
...@@ -18,6 +18,7 @@ BuildRequires: pkgconfig(mlite5) ...@@ -18,6 +18,7 @@ BuildRequires: pkgconfig(mlite5)
BuildRequires: pkgconfig(usb-moded-qt5) BuildRequires: pkgconfig(usb-moded-qt5)
BuildRequires: pkgconfig(libshadowutils) BuildRequires: pkgconfig(libshadowutils)
BuildRequires: pkgconfig(blkid) BuildRequires: pkgconfig(blkid)
BuildRequires: pkgconfig(libcrypto)
%description %description
%{summary}. %{summary}.
......
This diff is collapsed.
/*
* 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
...@@ -46,6 +46,7 @@ ...@@ -46,6 +46,7 @@
#include "developermodesettings.h" #include "developermodesettings.h"
#include "diskusage.h" #include "diskusage.h"
#include "partitionmodel.h" #include "partitionmodel.h"
#include "certificatemodel.h"
class SystemSettingsPlugin : public QQmlExtensionPlugin class SystemSettingsPlugin : public QQmlExtensionPlugin
{ {
...@@ -72,6 +73,7 @@ public: ...@@ -72,6 +73,7 @@ public:
qmlRegisterType<PartitionModel>(uri, 1, 0, "PartitionModel"); qmlRegisterType<PartitionModel>(uri, 1, 0, "PartitionModel");
qmlRegisterType<DeviceLockInterface>(uri, 1, 0, "DeviceLockInterface"); qmlRegisterType<DeviceLockInterface>(uri, 1, 0, "DeviceLockInterface");
qmlRegisterType<DeveloperModeSettings>(uri, 1, 0, "DeveloperModeSettings"); qmlRegisterType<DeveloperModeSettings>(uri, 1, 0, "DeveloperModeSettings");
qmlRegisterType<CertificateModel>(uri, 1, 0, "CertificateModel");
qRegisterMetaType<DeveloperModeSettings::Status>("DeveloperModeSettings::Status"); qRegisterMetaType<DeveloperModeSettings::Status>("DeveloperModeSettings::Status");
qmlRegisterType<DiskUsage>(uri, 1, 0, "DiskUsage"); qmlRegisterType<DiskUsage>(uri, 1, 0, "DiskUsage");
} }
......
...@@ -6,7 +6,7 @@ QT += qml dbus systeminfo ...@@ -6,7 +6,7 @@ QT += qml dbus systeminfo
QT -= gui QT -= gui
CONFIG += c++11 hide_symbols link_pkgconfig CONFIG += c++11 hide_symbols link_pkgconfig
PKGCONFIG += profile mlite5 timed-qt5 libshadowutils blkid PKGCONFIG += profile mlite5 timed-qt5 libshadowutils blkid libcrypto
system(qdbusxml2cpp -p mceiface.h:mceiface.cpp mce.xml) system(qdbusxml2cpp -p mceiface.h:mceiface.cpp mce.xml)
...@@ -18,6 +18,7 @@ SOURCES += \ ...@@ -18,6 +18,7 @@ SOURCES += \
mceiface.cpp \ mceiface.cpp \
displaysettings.cpp \ displaysettings.cpp \
aboutsettings.cpp \ aboutsettings.cpp \
certificatemodel.cpp \
devicelockiface.cpp \ devicelockiface.cpp \
developermodesettings.cpp \ developermodesettings.cpp \
diskusage.cpp \ diskusage.cpp \
...@@ -34,6 +35,7 @@ PUBLIC_HEADERS = \ ...@@ -34,6 +35,7 @@ PUBLIC_HEADERS = \
mceiface.h \ mceiface.h \
displaysettings.h \ displaysettings.h \
aboutsettings.h \ aboutsettings.h \
certificatemodel.h \
devicelockiface.h \ devicelockiface.h \
developermodesettings.h \ developermodesettings.h \
diskusage.h \ diskusage.h \
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment