summaryrefslogtreecommitdiffstats
path: root/installerbuilder/libinstaller/kdtools/KDUpdater/kdupdatercrypto.h
blob: 15d0011a0b188e039c77efb1ed7c3eac056ac1eb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/****************************************************************************
** Copyright (C) 2001-2010 Klaralvdalens Datakonsult AB.  All rights reserved.
**
** This file is part of the KD Tools library.
**
** Licensees holding valid commercial KD Tools licenses may use this file in
** accordance with the KD Tools Commercial License Agreement provided with
** the Software.
**
**
** This file may be distributed and/or modified under the terms of the
** GNU Lesser General Public License version 2 and version 3 as published by the
** Free Software Foundation and appearing in the file LICENSE.LGPL included.
**
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
**
** Contact info@kdab.com if any conditions of this licensing are not
** clear to you.
**
**********************************************************************/

#ifndef __KDTOOLS_KDUPDATERCRYPTO_H__
#define __KDTOOLS_KDUPDATERCRYPTO_H__

#include "kdupdater.h"

class QByteArray;
class QIODevice;

#include <KDToolsCore/pimpl_ptr.h>

/**
 * Class that provides cryptographic functionality like signing and verifying
 * or encrypting and decrypting content.
 */
class KDTOOLS_UPDATER_EXPORT KDUpdaterCrypto {
    public:
        class PasswordProvider
        {
        public:
            virtual ~PasswordProvider() {}
            virtual QByteArray password() const = 0;
        };
        
        KDUpdaterCrypto();
        virtual ~KDUpdaterCrypto();

        /**
         * The private key.
         */
        QByteArray privateKey() const;
        void setPrivateKey(const QByteArray &key);
        
        /**
         * The password for the private key.
         */
        QByteArray privatePassword() const;
        void setPrivatePassword(const QByteArray &passwd);

        void setPrivatePasswordProvider( const PasswordProvider* provider );

        /**
         * The public key.
         */
        QByteArray publicKey() const;
        void setPublicKey(const QByteArray &key);

        /**
         * Encrypt content using the public key.
         */
        QByteArray encrypt(const QByteArray &plaintext);

        /**
         * Decript encrypted content using the private key.
         */
        QByteArray decrypt(const QByteArray &encryptedtext);
        
        /**
         * Sign content with the private key.
         */
        QByteArray sign(const QByteArray &data);
        QByteArray sign( const QString& path );
        QByteArray sign( QIODevice* dev );

        /**
         * Verify signed content with the public key.
         */
        bool verify(const QByteArray &data, const QByteArray &signature);
        bool verify( const QString& dataPath, const QString& signaturePath );
        bool verify( const QString& dataPath, const QByteArray& signature );
        bool verify( QIODevice* dev, const QByteArray& signature );

    private:
        class Private;
        kdtools::pimpl_ptr< Private > d;
};

#endif