Mercurial > trustbridge
view ui/certificatelist.cpp @ 248:9f0865dc8b14
Add accessor to check if the certificate should be installed
author | Andre Heinecke <aheinecke@intevation.de> |
---|---|
date | Mon, 31 Mar 2014 08:03:20 +0000 |
parents | 60c5df8e7980 |
children | 6a7eb102716d |
line wrap: on
line source
#include "certificatelist.h" #include <QDebug> #define PARSER_VERSION "1" CertificateList::CertificateList() : mStatus(NoList) { } list_status_t CertificateList::readList(const char *fileName) { char *data = NULL; size_t size = 0; mCertificatesRemove.clear(); mCertificatesInstall.clear(); mDate = QDateTime(); mData = QString(); mStatus = read_and_verify_list(fileName, &data, &size); if (!isValid()) { return mStatus; } // Take the data into the Qt Universe where memory is plentiful // and CPU's are fast :) mData = QString::fromLatin1(data, size); free(data); data = NULL; QStringList lines = mData.split("\n"); for (int i = 0; i < lines.size(); ++i) { QString curLine = lines[i].trimmed(); if (curLine.startsWith("F:")) { if (curLine.right(1) != PARSER_VERSION) { qDebug() << "Invalid Format Version"; mStatus = IncompatibleVersion; return mStatus; } } else if (curLine.startsWith("D:")) { bool ok = false; qlonglong timestamp = 0; curLine.remove(0, 2); timestamp = curLine.toLongLong(&ok); if (!ok) { qDebug() << "Invalid Date"; mStatus = InvalidFormat; return mStatus; } mDate = QDateTime::fromMSecsSinceEpoch(timestamp * 1000); } else if (curLine.startsWith("I:")) { mCertificatesInstall << Certificate(curLine); } else if (curLine.startsWith("R:")) { mCertificatesRemove << Certificate(curLine); } else if (curLine.startsWith("S:")) { // Signature is verified in read_and_verify_list continue; } else if (!curLine.isEmpty()){ qDebug () << "Don't know how to handle: " << curLine; } } return mStatus; } CertificateList::CertificateList(const char *fileName) : mStatus(NoList) { readList(fileName); } const QList<Certificate>& CertificateList::getInstallCertificates() const { return mCertificatesInstall; } const QList<Certificate>& CertificateList::getRemoveCertificates() const { return mCertificatesRemove; }