1 /* quickjob.h 2 3 This file is part of qgpgme, the Qt API binding for gpgme 4 Copyright (c) 2017 Intevation GmbH 5 Copyright (c) 2020 g10 Code GmbH 6 Software engineering by Ingo Klöcker <dev@ingo-kloecker.de> 7 8 QGpgME is free software; you can redistribute it and/or 9 modify it under the terms of the GNU General Public License as 10 published by the Free Software Foundation; either version 2 of the 11 License, or (at your option) any later version. 12 13 QGpgME is distributed in the hope that it will be useful, 14 but WITHOUT ANY WARRANTY; without even the implied warranty of 15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 16 General Public License for more details. 17 18 You should have received a copy of the GNU General Public License along 19 with this program; if not, write to the Free Software Foundation, Inc., 20 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 21 22 In addition, as a special exception, the copyright holders give 23 permission to link the code of this program with any edition of 24 the Qt library by Trolltech AS, Norway (or with modified versions 25 of Qt that use the same license as Qt), and distribute linked 26 combinations including the two. You must obey the GNU General 27 Public License in all respects for all of the code used other than 28 Qt. If you modify this file, you may extend this exception to 29 your version of the file, but you are not obligated to do so. If 30 you do not wish to do so, delete this exception statement from 31 your version. 32 */ 33 #ifndef QGPGME_QUICKJOB_H 34 #define QGPGME_QUICKJOB_H 35 36 #include "job.h" 37 38 #include "qgpgme_export.h" 39 40 #include <QDateTime> 41 42 #ifdef BUILDING_QGPGME 43 # include "key.h" 44 #else 45 # include <gpgme++/key.h> 46 #endif 47 48 class QString; 49 50 namespace QGpgME{ 51 52 /** 53 * Interface to the modern key manipulation functions. 54 */ 55 class QGPGME_EXPORT QuickJob : public Job 56 { 57 Q_OBJECT 58 public: 59 explicit QuickJob(QObject *parent = Q_NULLPTR); 60 ~QuickJob(); 61 62 /** Start --quick-gen-key */ 63 virtual void startCreate(const QString &uid, 64 const char *algo, 65 const QDateTime &expires = QDateTime(), 66 const GpgME::Key &key = GpgME::Key(), 67 unsigned int flags = 0) = 0; 68 69 /** Start --quick-adduid */ 70 virtual void startAddUid(const GpgME::Key &key, const QString &uid) = 0; 71 72 /** Start --quick-revuid */ 73 virtual void startRevUid(const GpgME::Key &key, const QString &uid) = 0; 74 75 /** Start --quick-add-key */ 76 virtual void startAddSubkey(const GpgME::Key &key, const char *algo, 77 const QDateTime &expires = QDateTime(), 78 unsigned int flags = 0) = 0; 79 80 /** 81 Starts the operation to revoke the signatures made with the key \a signingKey on the 82 user IDs \a userIds of the key \a key. If \a userIds is an empty list, then all 83 signatures made with \a signingKey on the user IDs of \a key will be revoked. 84 */ 85 virtual void startRevokeSignature(const GpgME::Key &key, const GpgME::Key &signingKey, 86 const std::vector<GpgME::UserID> &userIds = std::vector<GpgME::UserID>()) = 0; 87 88 Q_SIGNALS: 89 void result(const GpgME::Error &error, 90 const QString &auditLogAsHtml = QString(), const GpgME::Error &auditLogError = GpgME::Error()); 91 }; 92 93 } 94 #endif 95