diff options
Diffstat (limited to 'libkpgp/kpgpbase.h')
-rw-r--r-- | libkpgp/kpgpbase.h | 239 |
1 files changed, 239 insertions, 0 deletions
diff --git a/libkpgp/kpgpbase.h b/libkpgp/kpgpbase.h new file mode 100644 index 000000000..f0f1d190d --- /dev/null +++ b/libkpgp/kpgpbase.h @@ -0,0 +1,239 @@ +/* + kpgpbase.h + + Copyright (C) 2001,2002 the KPGP authors + See file AUTHORS.kpgp for details + + This file is part of KPGP, the KDE PGP/GnuPG support library. + + KPGP 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. + + 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 + */ + +#ifndef KPGPBASE_H +#define KPGPBASE_H + +#include <qstring.h> +#include <qcstring.h> +#include <qstringlist.h> + +#include "kpgpkey.h" +#include "kpgpblock.h" + +namespace Kpgp { + +class Base +{ +public: + + /** virtual class used internally by kpgp */ + Base(); + virtual ~Base(); + + + /** Encrypts the message with the given keys. */ + virtual int encrypt( Block& , const KeyIDList& ) { return OK; } + + /** Clearsigns the message with the currently set key. */ + virtual int clearsign( Block& , const char *) { return OK; } + + /** Encrypts and signs the message with the given keys. */ + virtual int encsign( Block& , const KeyIDList& , + const char * = 0) { return OK; } + + /** Decrypts the message. */ + virtual int decrypt( Block& , const char * = 0) { return OK; } + + /** Verifies the message. */ + virtual int verify( Block& block ) { return decrypt( block, 0 ); } + + + /** Reads the key data for the given key and returns it. If + <em>readTrust</em> is true then the trust of this key will be determined. + If <em>key</em> is not null then the key data will be stored in given + key. + */ + virtual Key* readPublicKey( const KeyID&, const bool = false, + Key* = 0 ) + { return 0; } + + /** Returns the list of public keys in the users public keyring. */ + virtual KeyList publicKeys( const QStringList & = QStringList() ) + { return KeyList(); } + + /** Returns the list of secret keys in the users secret keyring. */ + virtual KeyList secretKeys( const QStringList & = QStringList() ) + { return KeyList(); } + + /** Returns the ascii armored data of the public key with the + given key id. */ + virtual QCString getAsciiPublicKey(const KeyID& ) { return QCString(); } + + /** Signs the given key with the currently set user key. This is currently + not implemented. */ + virtual int signKey(const KeyID& , const char *) { return OK; } + + + /** Returns an error message if an error occurred during the last + operation. */ + virtual QString lastErrorMessage() const; + + +protected: + virtual int run( const char *cmd, const char *passphrase = 0, + bool onlyReadFromPGP = false ); + virtual int runGpg( const char *cmd, const char *passphrase = 0, + bool onlyReadFromGnuPG = false ); + virtual void clear(); + + QCString addUserId(); + + QCString input; + QCString output; + QCString error; + QString errMsg; + + QCString mVersion; + + int status; + +}; + +// --------------------------------------------------------------------------- + +class Base2 : public Base +{ + +public: + Base2(); + virtual ~Base2(); + + virtual int encrypt( Block& block, const KeyIDList& recipients ); + virtual int clearsign( Block& block, const char *passphrase ); + virtual int encsign( Block& block, const KeyIDList& recipients, + const char *passphrase = 0 ); + virtual int decrypt( Block& block, const char *passphrase = 0 ); + virtual int verify( Block& block ) { return decrypt( block, 0 ); } + + virtual Key* readPublicKey( const KeyID& keyID, + const bool readTrust = false, + Key* key = 0 ); + virtual KeyList publicKeys( const QStringList & patterns = QStringList() ); + virtual KeyList secretKeys( const QStringList & patterns = QStringList() ); + virtual QCString getAsciiPublicKey( const KeyID& keyID ); + virtual int signKey( const KeyID& keyID, const char *passphrase ); + +protected: + KeyList doGetPublicKeys( const QCString & cmd, + const QStringList & patterns ); + virtual KeyList parseKeyList( const QCString&, bool ); + +private: + Key* parsePublicKeyData( const QCString& output, Key* key = 0 ); + void parseTrustDataForKey( Key* key, const QCString& str ); +}; + +class BaseG : public Base +{ + +public: + BaseG(); + virtual ~BaseG(); + + virtual int encrypt( Block& block, const KeyIDList& recipients ); + virtual int clearsign( Block& block, const char *passphrase ); + virtual int encsign( Block& block, const KeyIDList& recipients, + const char *passphrase = 0 ); + virtual int decrypt( Block& block, const char *passphrase = 0 ); + virtual int verify( Block& block ) { return decrypt( block, 0 ); } + + virtual Key* readPublicKey( const KeyID& keyID, + const bool readTrust = false, + Key* key = 0 ); + virtual KeyList publicKeys( const QStringList & patterns = QStringList() ); + virtual KeyList secretKeys( const QStringList & patterns = QStringList() ); + virtual QCString getAsciiPublicKey( const KeyID& keyID ); + virtual int signKey( const KeyID& keyID, const char *passphrase ); + +private: + Key* parseKeyData( const QCString& output, int& offset, Key* key = 0 ); + KeyList parseKeyList( const QCString&, bool ); +}; + + +class Base5 : public Base +{ + +public: + Base5(); + virtual ~Base5(); + + virtual int encrypt( Block& block, const KeyIDList& recipients ); + virtual int clearsign( Block& block, const char *passphrase ); + virtual int encsign( Block& block, const KeyIDList& recipients, + const char *passphrase = 0 ); + virtual int decrypt( Block& block, const char *passphrase = 0 ); + virtual int verify( Block& block ) { return decrypt( block, 0 ); } + + virtual Key* readPublicKey( const KeyID& keyID, + const bool readTrust = false, + Key* key = 0 ); + virtual KeyList publicKeys( const QStringList & patterns = QStringList() ); + virtual KeyList secretKeys( const QStringList & patterns = QStringList() ); + virtual QCString getAsciiPublicKey( const KeyID& keyID ); + virtual int signKey( const KeyID& keyID, const char *passphrase ); + +private: + Key* parseKeyData( const QCString& output, int& offset, Key* key = 0 ); + Key* parseSingleKey( const QCString& output, Key* key = 0 ); + KeyList parseKeyList( const QCString& output, bool ); + void parseTrustDataForKey( Key* key, const QCString& str ); +}; + + +class Base6 : public Base2 +{ + +public: + Base6(); + virtual ~Base6(); + + virtual int decrypt( Block& block, const char *passphrase = 0 ); + virtual int verify( Block& block ) { return decrypt( block, 0 ); } + + virtual Key* readPublicKey( const KeyID& keyID, + const bool readTrust = false, + Key* key = 0 ); + virtual KeyList publicKeys( const QStringList & patterns = QStringList() ); + virtual KeyList secretKeys( const QStringList & patterns = QStringList() ); + + virtual int isVersion6(); + +protected: + virtual KeyList parseKeyList( const QCString &, bool ); + +private: + Key* parseKeyData( const QCString& output, int& offset, Key* key = 0 ); + Key* parseSingleKey( const QCString& output, Key* key = 0 ); + void parseTrustDataForKey( Key* key, const QCString& str ); +}; + +// --------------------------------------------------------------------------- +// inlined functions + +inline QString +Base::lastErrorMessage() const +{ + return errMsg; +} + + +} // namespace Kpgp + +#endif |