blob: e5fe12ada0ba3f67a537be9cbe26da663f453fc4 (
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
100
|
/****************************************************************************
** 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"
QT_BEGIN_NAMESPACE
class QByteArray;
class QIODevice;
QT_END_NAMESPACE
/**
* Class that provides cryptographic functionality like signing and verifying
* or encrypting and decrypting content.
*/
class KDTOOLS_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;
Private *d;
};
#endif // KDTOOLS_KDUPDATERCRYPTO_H
|