2016-05-10 12:05:10 +00:00
|
|
|
/*
|
|
|
|
protocol_p.h
|
|
|
|
|
|
|
|
This file is part of qgpgme, the Qt API binding for gpgme
|
|
|
|
Copyright (c) 2004,2005 Klarälvdalens Datakonsult AB
|
Change copyright from Intevation to BSI
* lang/cpp/src/gpggencardkeyinteractor.cpp,
lang/cpp/src/gpggencardkeyinteractor.h,
lang/cpp/src/gpgmepp_export.h,
lang/cpp/src/swdbresult.cpp,
lang/cpp/src/swdbresult.h,
lang/cpp/src/tofuinfo.cpp,
lang/cpp/src/tofuinfo.h,
lang/qt/src/abstractimportjob.h,
lang/qt/src/adduseridjob.h,
lang/qt/src/changeexpiryjob.h,
lang/qt/src/changeownertrustjob.h,
lang/qt/src/changepasswdjob.h,
lang/qt/src/cryptoconfig.cpp,
lang/qt/src/cryptoconfig.h,
lang/qt/src/dataprovider.cpp,
lang/qt/src/dataprovider.h,
lang/qt/src/decryptjob.h,
lang/qt/src/decryptverifyjob.h,
lang/qt/src/deletejob.h,
lang/qt/src/dn.cpp,
lang/qt/src/dn.h,
lang/qt/src/downloadjob.h,
lang/qt/src/encryptjob.h,
lang/qt/src/exportjob.h,
lang/qt/src/hierarchicalkeylistjob.h,
lang/qt/src/importfromkeyserverjob.h,
lang/qt/src/importjob.h,
lang/qt/src/job.cpp,
lang/qt/src/job.h,
lang/qt/src/keyformailboxjob.h,
lang/qt/src/keygenerationjob.h,
lang/qt/src/keylistjob.h,
lang/qt/src/listallkeysjob.h,
lang/qt/src/multideletejob.h,
lang/qt/src/protocol.h,
lang/qt/src/protocol_p.h,
lang/qt/src/qgpgme_export.h,
lang/qt/src/qgpgmeadduseridjob.cpp,
lang/qt/src/qgpgmeadduseridjob.h,
lang/qt/src/qgpgmebackend.cpp,
lang/qt/src/qgpgmebackend.h,
lang/qt/src/qgpgmechangeexpiryjob.cpp,
lang/qt/src/qgpgmechangeexpiryjob.h,
lang/qt/src/qgpgmechangeownertrustjob.cpp,
lang/qt/src/qgpgmechangeownertrustjob.h,
lang/qt/src/qgpgmechangepasswdjob.cpp,
lang/qt/src/qgpgmechangepasswdjob.h,
lang/qt/src/qgpgmedecryptjob.cpp,
lang/qt/src/qgpgmedecryptjob.h,
lang/qt/src/qgpgmedecryptverifyjob.cpp,
lang/qt/src/qgpgmedecryptverifyjob.h,
lang/qt/src/qgpgmedeletejob.cpp,
lang/qt/src/qgpgmedeletejob.h,
lang/qt/src/qgpgmedownloadjob.cpp,
lang/qt/src/qgpgmedownloadjob.h,
lang/qt/src/qgpgmeencryptjob.cpp,
lang/qt/src/qgpgmeencryptjob.h,
lang/qt/src/qgpgmeexportjob.cpp,
lang/qt/src/qgpgmeexportjob.h,
lang/qt/src/qgpgmeimportfromkeyserverjob.cpp,
lang/qt/src/qgpgmeimportfromkeyserverjob.h,
lang/qt/src/qgpgmeimportjob.cpp,
lang/qt/src/qgpgmeimportjob.h,
lang/qt/src/qgpgmekeyformailboxjob.cpp,
lang/qt/src/qgpgmekeyformailboxjob.h,
lang/qt/src/qgpgmekeygenerationjob.cpp,
lang/qt/src/qgpgmekeygenerationjob.h,
lang/qt/src/qgpgmekeylistjob.cpp,
lang/qt/src/qgpgmekeylistjob.h,
lang/qt/src/qgpgmelistallkeysjob.cpp,
lang/qt/src/qgpgmelistallkeysjob.h,
lang/qt/src/qgpgmenewcryptoconfig.cpp,
lang/qt/src/qgpgmenewcryptoconfig.h,
lang/qt/src/qgpgmerefreshkeysjob.cpp,
lang/qt/src/qgpgmerefreshkeysjob.h,
lang/qt/src/qgpgmesecretkeyexportjob.cpp,
lang/qt/src/qgpgmesecretkeyexportjob.h,
lang/qt/src/qgpgmesignencryptjob.cpp,
lang/qt/src/qgpgmesignencryptjob.h,
lang/qt/src/qgpgmesignjob.cpp,
lang/qt/src/qgpgmesignjob.h,
lang/qt/src/qgpgmesignkeyjob.cpp,
lang/qt/src/qgpgmesignkeyjob.h,
lang/qt/src/qgpgmetofupolicyjob.cpp,
lang/qt/src/qgpgmetofupolicyjob.h,
lang/qt/src/qgpgmeverifydetachedjob.cpp,
lang/qt/src/qgpgmeverifydetachedjob.h,
lang/qt/src/qgpgmeverifyopaquejob.cpp,
lang/qt/src/qgpgmeverifyopaquejob.h,
lang/qt/src/qgpgmewkspublishjob.cpp,
lang/qt/src/qgpgmewkspublishjob.h,
lang/qt/src/refreshkeysjob.h,
lang/qt/src/signencryptjob.h,
lang/qt/src/signjob.h,
lang/qt/src/signkeyjob.h,
lang/qt/src/specialjob.h,
lang/qt/src/threadedjobmixin.cpp,
lang/qt/src/threadedjobmixin.h,
lang/qt/src/tofupolicyjob.h,
lang/qt/src/verifydetachedjob.h,
lang/qt/src/verifyopaquejob.h,
lang/qt/src/wkspublishjob.h,
lang/qt/tests/run-keyformailboxjob.cpp,
lang/qt/tests/t-config.cpp,
lang/qt/tests/t-encrypt.cpp,
lang/qt/tests/t-keylist.cpp,
lang/qt/tests/t-keylocate.cpp,
lang/qt/tests/t-ownertrust.cpp,
lang/qt/tests/t-support.cpp,
lang/qt/tests/t-support.h,
lang/qt/tests/t-tofuinfo.cpp,
lang/qt/tests/t-various.cpp,
lang/qt/tests/t-verify.cpp,
lang/qt/tests/t-wkspublish.cpp,
tests/gpg/t-encrypt-mixed.c,
tests/gpg/t-thread-keylist-verify.c,
tests/gpg/t-thread-keylist.c,
tests/run-decrypt.c: Change Intevation GmbH copyright to BSI.
--
This should make it more transparent where the BSI is the actual
copyright holder as the code was mostly developed as part of a
development contract.
2017-04-25 08:24:11 +00:00
|
|
|
Copyright (c) 2016 by Bundesamt für Sicherheit in der Informationstechnik
|
|
|
|
Software engineering by Intevation GmbH
|
2022-01-04 14:38:49 +00:00
|
|
|
Copyright (c) 2022 by g10 Code GmbH
|
|
|
|
Software engineering by Ingo Klöcker <dev@ingo-kloecker.de>
|
2016-05-10 12:05:10 +00:00
|
|
|
|
|
|
|
QGpgME 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) any later version.
|
|
|
|
|
|
|
|
QGpgME 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, write to the Free Software
|
|
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
|
|
|
|
In addition, as a special exception, the copyright holders give
|
|
|
|
permission to link the code of this program with any edition of
|
|
|
|
the Qt library by Trolltech AS, Norway (or with modified versions
|
|
|
|
of Qt that use the same license as Qt), and distribute linked
|
|
|
|
combinations including the two. You must obey the GNU General
|
|
|
|
Public License in all respects for all of the code used other than
|
|
|
|
Qt. If you modify this file, you may extend this exception to
|
|
|
|
your version of the file, but you are not obligated to do so. If
|
|
|
|
you do not wish to do so, delete this exception statement from
|
|
|
|
your version.
|
|
|
|
*/
|
|
|
|
#ifndef __QGPGME_PROTOCOL_P_H__
|
|
|
|
#define __QGPGME_PROTOCOL_P_H__
|
|
|
|
#include "qgpgmenewcryptoconfig.h"
|
|
|
|
|
|
|
|
#include "qgpgmekeygenerationjob.h"
|
|
|
|
#include "qgpgmekeylistjob.h"
|
|
|
|
#include "qgpgmelistallkeysjob.h"
|
|
|
|
#include "qgpgmedecryptjob.h"
|
|
|
|
#include "qgpgmedecryptverifyjob.h"
|
2022-05-02 13:28:09 +00:00
|
|
|
#include "qgpgmerefreshopenpgpkeysjob.h"
|
2022-04-28 10:04:10 +00:00
|
|
|
#include "qgpgmerefreshsmimekeysjob.h"
|
2016-05-10 12:05:10 +00:00
|
|
|
#include "qgpgmedeletejob.h"
|
|
|
|
#include "qgpgmedownloadjob.h"
|
|
|
|
#include "qgpgmesignencryptjob.h"
|
|
|
|
#include "qgpgmeencryptjob.h"
|
|
|
|
#include "qgpgmesignjob.h"
|
|
|
|
#include "qgpgmesignkeyjob.h"
|
|
|
|
#include "qgpgmeexportjob.h"
|
|
|
|
#include "qgpgmeverifydetachedjob.h"
|
|
|
|
#include "qgpgmeimportjob.h"
|
|
|
|
#include "qgpgmeimportfromkeyserverjob.h"
|
|
|
|
#include "qgpgmeverifyopaquejob.h"
|
|
|
|
#include "qgpgmechangeexpiryjob.h"
|
|
|
|
#include "qgpgmechangeownertrustjob.h"
|
|
|
|
#include "qgpgmechangepasswdjob.h"
|
qt: Add job to add existing subkeys to other keys
* lang/qt/src/addexistingsubkeyjob.h,
lang/qt/src/qgpgmeaddexistingsubkeyjob.cpp,
lang/qt/src/qgpgmeaddexistingsubkeyjob.h: New.
* lang/qt/src/protocol.h (class Protocol): Add pure virtual member
function addExistingSubkeyJob.
* lang/qt/src/protocol_p.h (Protocol::addExistingSubkeyJob): Implement.
* lang/qt/src/job.cpp, lang/qt/src/Makefile.am: Update accordingly.
* lang/qt/tests/Makefile.am (the_tests, moc_files, noinst_PROGRAMS):
Add new test.
(t_addexistingsubkey_SOURCES): New.
* lang/qt/tests/t-addexistingsubkey.cpp: New.
* lang/qt/tests/t-support.h (VERIFY_OR_RETURN_VALUE,
COMPARE_OR_RETURN_VALUE, VERIFY_OR_OBJECT, COMPARE_OR_OBJECT,
VERIFY_OR_FALSE, COMPARE_OR_FALSE): New.
* lang/qt/tests/t-support.h, lang/qt/tests/t-support.cpp
(class QQGpgMETest): New member function importSecretKeys.
--
The new job allows adding existing subkeys to other keys as with the
"addkey" edit-key command of gpg. The added subkey will have the same
expiration date (+/- 1 second) as the original subkey.
GnuPG-bug-id: 5770
2022-01-13 11:51:38 +00:00
|
|
|
#include "qgpgmeaddexistingsubkeyjob.h"
|
2016-05-10 12:05:10 +00:00
|
|
|
#include "qgpgmeadduseridjob.h"
|
2016-08-11 15:22:35 +00:00
|
|
|
#include "qgpgmekeyformailboxjob.h"
|
2021-12-13 09:48:52 +00:00
|
|
|
#include "qgpgmewkdlookupjob.h"
|
2016-08-25 12:29:41 +00:00
|
|
|
#include "qgpgmewkspublishjob.h"
|
2016-09-16 14:55:25 +00:00
|
|
|
#include "qgpgmetofupolicyjob.h"
|
2017-12-01 13:29:04 +00:00
|
|
|
#include "qgpgmequickjob.h"
|
2022-02-02 10:53:29 +00:00
|
|
|
#include "qgpgmereceivekeysjob.h"
|
2022-03-29 13:45:52 +00:00
|
|
|
#include "qgpgmerevokekeyjob.h"
|
2016-05-10 12:05:10 +00:00
|
|
|
|
|
|
|
namespace
|
|
|
|
{
|
|
|
|
|
|
|
|
class Protocol : public QGpgME::Protocol
|
|
|
|
{
|
|
|
|
GpgME::Protocol mProtocol;
|
|
|
|
public:
|
|
|
|
explicit Protocol(GpgME::Protocol proto) : mProtocol(proto) {}
|
|
|
|
|
|
|
|
QString name() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
switch (mProtocol) {
|
|
|
|
case GpgME::OpenPGP: return QStringLiteral("OpenPGP");
|
|
|
|
case GpgME::CMS: return QStringLiteral("SMIME");
|
|
|
|
default: return QString();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
QString displayName() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
// ah (2.4.16): Where is this used and isn't this inverted
|
|
|
|
// with name
|
|
|
|
switch (mProtocol) {
|
|
|
|
case GpgME::OpenPGP: return QStringLiteral("gpg");
|
|
|
|
case GpgME::CMS: return QStringLiteral("gpgsm");
|
|
|
|
default: return QStringLiteral("unknown");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::SpecialJob *specialJob(const char *, const QMap<QString, QVariant> &) const Q_DECL_OVERRIDE
|
|
|
|
{
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::KeyListJob *keyListJob(bool remote, bool includeSigs, bool validate) const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
unsigned int mode = context->keyListMode();
|
|
|
|
if (remote) {
|
|
|
|
mode |= GpgME::Extern;
|
|
|
|
mode &= ~GpgME::Local;
|
|
|
|
} else {
|
|
|
|
mode |= GpgME::Local;
|
|
|
|
mode &= ~GpgME::Extern;
|
|
|
|
}
|
|
|
|
if (includeSigs) {
|
|
|
|
mode |= GpgME::Signatures;
|
|
|
|
}
|
|
|
|
if (validate) {
|
|
|
|
mode |= GpgME::Validate;
|
|
|
|
}
|
|
|
|
context->setKeyListMode(mode);
|
|
|
|
return new QGpgME::QGpgMEKeyListJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::ListAllKeysJob *listAllKeysJob(bool includeSigs, bool validate) const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
unsigned int mode = context->keyListMode();
|
|
|
|
mode |= GpgME::Local;
|
|
|
|
mode &= ~GpgME::Extern;
|
|
|
|
if (includeSigs) {
|
|
|
|
mode |= GpgME::Signatures;
|
|
|
|
}
|
|
|
|
if (validate) {
|
|
|
|
mode |= GpgME::Validate;
|
|
|
|
/* Setting the context to offline mode disables CRL / OCSP checks in
|
|
|
|
this Job. Otherwise we would try to fetch the CRL's for all CMS
|
|
|
|
keys in the users keyring because GpgME::Validate includes remote
|
|
|
|
resources by default in the validity check.
|
|
|
|
This setting only has any effect if gpgsm >= 2.1.6 is used.
|
|
|
|
*/
|
|
|
|
context->setOffline(true);
|
|
|
|
}
|
|
|
|
context->setKeyListMode(mode);
|
|
|
|
return new QGpgME::QGpgMEListAllKeysJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::EncryptJob *encryptJob(bool armor, bool textmode) const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
context->setArmor(armor);
|
|
|
|
context->setTextMode(textmode);
|
|
|
|
return new QGpgME::QGpgMEEncryptJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::DecryptJob *decryptJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMEDecryptJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::SignJob *signJob(bool armor, bool textMode) const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
context->setArmor(armor);
|
|
|
|
context->setTextMode(textMode);
|
|
|
|
return new QGpgME::QGpgMESignJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::VerifyDetachedJob *verifyDetachedJob(bool textMode) const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
context->setTextMode(textMode);
|
|
|
|
return new QGpgME::QGpgMEVerifyDetachedJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::VerifyOpaqueJob *verifyOpaqueJob(bool textMode) const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
context->setTextMode(textMode);
|
|
|
|
return new QGpgME::QGpgMEVerifyOpaqueJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::KeyGenerationJob *keyGenerationJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMEKeyGenerationJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::ImportJob *importJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMEImportJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::ImportFromKeyserverJob *importFromKeyserverJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMEImportFromKeyserverJob(context);
|
|
|
|
}
|
|
|
|
|
2022-02-02 10:53:29 +00:00
|
|
|
QGpgME::ReceiveKeysJob *receiveKeysJob() const override
|
|
|
|
{
|
|
|
|
if (mProtocol != GpgME::OpenPGP) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMEReceiveKeysJob{context};
|
|
|
|
}
|
|
|
|
|
2016-05-10 12:05:10 +00:00
|
|
|
QGpgME::ExportJob *publicKeyExportJob(bool armor) const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
context->setArmor(armor);
|
|
|
|
return new QGpgME::QGpgMEExportJob(context);
|
|
|
|
}
|
|
|
|
|
2022-01-04 14:38:49 +00:00
|
|
|
QGpgME::ExportJob *secretKeyExportJob(bool armor, const QString &) const Q_DECL_OVERRIDE
|
2016-05-10 12:05:10 +00:00
|
|
|
{
|
2022-01-04 14:38:49 +00:00
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
2022-01-04 14:38:49 +00:00
|
|
|
context->setArmor(armor);
|
|
|
|
return new QGpgME::QGpgMEExportJob(context, GpgME::Context::ExportSecret);
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
2022-01-04 14:56:34 +00:00
|
|
|
QGpgME::ExportJob *secretSubkeyExportJob(bool armor) const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
context->setArmor(armor);
|
|
|
|
return new QGpgME::QGpgMEExportJob(context, GpgME::Context::ExportSecretSubkey);
|
|
|
|
}
|
|
|
|
|
2016-05-10 12:05:10 +00:00
|
|
|
QGpgME::RefreshKeysJob *refreshKeysJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
2022-05-02 13:28:09 +00:00
|
|
|
if (mProtocol == GpgME::CMS) {
|
|
|
|
return new QGpgME::QGpgMERefreshSMIMEKeysJob;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
2022-05-02 13:28:09 +00:00
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMERefreshOpenPGPKeysJob{context};
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::DownloadJob *downloadJob(bool armor) const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
context->setArmor(armor);
|
|
|
|
// this is the hackish interface for downloading from keyserers currently:
|
|
|
|
context->setKeyListMode(GpgME::Extern);
|
|
|
|
return new QGpgME::QGpgMEDownloadJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::DeleteJob *deleteJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMEDeleteJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::SignEncryptJob *signEncryptJob(bool armor, bool textMode) const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
context->setArmor(armor);
|
|
|
|
context->setTextMode(textMode);
|
|
|
|
return new QGpgME::QGpgMESignEncryptJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::DecryptVerifyJob *decryptVerifyJob(bool textMode) const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
context->setTextMode(textMode);
|
|
|
|
return new QGpgME::QGpgMEDecryptVerifyJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::ChangeExpiryJob *changeExpiryJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
if (mProtocol != GpgME::OpenPGP) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr; // only supported by gpg
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMEChangeExpiryJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::ChangePasswdJob *changePasswdJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
if (!GpgME::hasFeature(GpgME::PasswdFeature, 0)) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMEChangePasswdJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::SignKeyJob *signKeyJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
if (mProtocol != GpgME::OpenPGP) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr; // only supported by gpg
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMESignKeyJob(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
QGpgME::ChangeOwnerTrustJob *changeOwnerTrustJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
if (mProtocol != GpgME::OpenPGP) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr; // only supported by gpg
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMEChangeOwnerTrustJob(context);
|
|
|
|
}
|
|
|
|
|
qt: Add job to add existing subkeys to other keys
* lang/qt/src/addexistingsubkeyjob.h,
lang/qt/src/qgpgmeaddexistingsubkeyjob.cpp,
lang/qt/src/qgpgmeaddexistingsubkeyjob.h: New.
* lang/qt/src/protocol.h (class Protocol): Add pure virtual member
function addExistingSubkeyJob.
* lang/qt/src/protocol_p.h (Protocol::addExistingSubkeyJob): Implement.
* lang/qt/src/job.cpp, lang/qt/src/Makefile.am: Update accordingly.
* lang/qt/tests/Makefile.am (the_tests, moc_files, noinst_PROGRAMS):
Add new test.
(t_addexistingsubkey_SOURCES): New.
* lang/qt/tests/t-addexistingsubkey.cpp: New.
* lang/qt/tests/t-support.h (VERIFY_OR_RETURN_VALUE,
COMPARE_OR_RETURN_VALUE, VERIFY_OR_OBJECT, COMPARE_OR_OBJECT,
VERIFY_OR_FALSE, COMPARE_OR_FALSE): New.
* lang/qt/tests/t-support.h, lang/qt/tests/t-support.cpp
(class QQGpgMETest): New member function importSecretKeys.
--
The new job allows adding existing subkeys to other keys as with the
"addkey" edit-key command of gpg. The added subkey will have the same
expiration date (+/- 1 second) as the original subkey.
GnuPG-bug-id: 5770
2022-01-13 11:51:38 +00:00
|
|
|
QGpgME:: AddExistingSubkeyJob *addExistingSubkeyJob() const override
|
|
|
|
{
|
|
|
|
if (mProtocol != GpgME::OpenPGP) {
|
|
|
|
return nullptr; // only supported by gpg
|
|
|
|
}
|
|
|
|
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMEAddExistingSubkeyJob{context};
|
|
|
|
}
|
|
|
|
|
2016-05-10 12:05:10 +00:00
|
|
|
QGpgME::AddUserIDJob *addUserIDJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
if (mProtocol != GpgME::OpenPGP) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr; // only supported by gpg
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-10 12:05:10 +00:00
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMEAddUserIDJob(context);
|
|
|
|
}
|
|
|
|
|
2016-05-13 11:16:12 +00:00
|
|
|
QGpgME::KeyListJob *locateKeysJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
if (mProtocol != GpgME::OpenPGP) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-13 11:16:12 +00:00
|
|
|
}
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-05-13 11:16:12 +00:00
|
|
|
}
|
2022-05-02 13:59:41 +00:00
|
|
|
context->setKeyListMode(GpgME::Locate | GpgME::Signatures | GpgME::Validate);
|
2016-05-13 11:16:12 +00:00
|
|
|
return new QGpgME::QGpgMEKeyListJob(context);
|
|
|
|
}
|
2016-08-11 15:22:35 +00:00
|
|
|
|
|
|
|
QGpgME::KeyForMailboxJob *keyForMailboxJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-08-11 15:22:35 +00:00
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMEKeyForMailboxJob(context);
|
|
|
|
}
|
2016-08-25 12:29:41 +00:00
|
|
|
|
2021-12-13 09:48:52 +00:00
|
|
|
QGpgME::WKDLookupJob *wkdLookupJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
if (mProtocol != GpgME::OpenPGP) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
auto context = GpgME::Context::createForEngine(GpgME::AssuanEngine);
|
|
|
|
if (!context) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMEWKDLookupJob(context.release());
|
|
|
|
}
|
|
|
|
|
2016-08-25 12:29:41 +00:00
|
|
|
QGpgME::WKSPublishJob *wksPublishJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
if (mProtocol != GpgME::OpenPGP) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-08-25 12:29:41 +00:00
|
|
|
}
|
|
|
|
auto context = GpgME::Context::createForEngine(GpgME::SpawnEngine);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-08-25 12:29:41 +00:00
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMEWKSPublishJob(context.release());
|
|
|
|
}
|
2016-09-16 14:55:25 +00:00
|
|
|
|
|
|
|
QGpgME::TofuPolicyJob *tofuPolicyJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
if (mProtocol != GpgME::OpenPGP) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-09-16 14:55:25 +00:00
|
|
|
}
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2016-09-16 14:55:25 +00:00
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMETofuPolicyJob(context);
|
|
|
|
}
|
2017-12-01 13:29:04 +00:00
|
|
|
|
|
|
|
QGpgME::QuickJob *quickJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
if (mProtocol != GpgME::OpenPGP) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2017-12-01 13:29:04 +00:00
|
|
|
}
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
2018-12-03 11:20:33 +00:00
|
|
|
return nullptr;
|
2017-12-01 13:29:04 +00:00
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMEQuickJob(context);
|
|
|
|
}
|
2022-03-29 13:45:52 +00:00
|
|
|
|
|
|
|
QGpgME::RevokeKeyJob *revokeKeyJob() const Q_DECL_OVERRIDE
|
|
|
|
{
|
|
|
|
if (mProtocol != GpgME::OpenPGP) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
GpgME::Context *context = GpgME::Context::createForProtocol(mProtocol);
|
|
|
|
if (!context) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
return new QGpgME::QGpgMERevokeKeyJob(context);
|
|
|
|
}
|
2016-05-10 12:05:10 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
#endif
|