6#include <QtCore/QDebug>
7#include <QtCore/QMessageAuthenticationCode>
8#include <QtCore/QtEndian>
11#include "qtcore-config_p.h"
15#if QT_CONFIG(opensslv30) && QT_CONFIG(openssl_linked)
16#define USING_OPENSSL30
17#include <openssl/core_names.h>
18#include <openssl/kdf.h>
19#include <openssl/params.h>
20#include <openssl/provider.h>
64#ifndef QT_CRYPTOGRAPHICHASH_ONLY_SHA1
68 qWarning(
"The only supported algorithms for pbkdf1 are SHA-1 and MD5!");
72 if (salt.
size() != 8) {
73 qWarning(
"The salt must be 8 bytes long!");
76 if (iterations < 1 || dkLen < 1)
80 qWarning() <<
"Derived key too long:\n"
81 << algorithm <<
"was chosen which produces output of length"
92 for (
int i = 1;
i < iterations;
i++) {
97 return key.left(dkLen);
100#ifdef USING_OPENSSL30
105#define CASE(Enum, Name) \
106 case QCryptographicHash:: Enum : \
112 CASE(Sha224,
"SHA224");
113 CASE(Sha256,
"SHA256");
114 CASE(Sha384,
"SHA384");
115 CASE(Sha512,
"SHA512");
116 CASE(RealSha3_224,
"SHA3-224");
117 CASE(RealSha3_256,
"SHA3-256");
118 CASE(RealSha3_384,
"SHA3-384");
119 CASE(RealSha3_512,
"SHA3-512");
120 CASE(Keccak_224,
"SHA3-224");
121 CASE(Keccak_256,
"SHA3-256");
122 CASE(Keccak_384,
"SHA3-384");
123 CASE(Keccak_512,
"SHA3-512");
124 CASE(Blake2b_512,
"BLAKE2B512");
125 CASE(Blake2s_256,
"BLAKE2S256");
127 default:
return nullptr;
133 uint64_t iterations,
quint64 dkLen)
135 EVP_KDF *kdf = EVP_KDF_fetch(
nullptr,
"PBKDF2",
nullptr);
144 EVP_KDF_CTX *
ctx = EVP_KDF_CTX_new(kdf);
150 EVP_KDF_CTX_free(
ctx);
158 int checkDisabled = 1;
160 params.append(OSSL_PARAM_construct_utf8_string(OSSL_KDF_PARAM_DIGEST,
const_cast<char*
>(methodToName(algorithm)), 0));
161 params.append(OSSL_PARAM_construct_octet_string(OSSL_KDF_PARAM_SALT,
const_cast<char*
>(salt.
data()), salt.
size()));
162 params.append(OSSL_PARAM_construct_octet_string(OSSL_KDF_PARAM_PASSWORD,
const_cast<char*
>(
data.data()),
data.size()));
163 params.append(OSSL_PARAM_construct_uint64(OSSL_KDF_PARAM_ITER, &iterations));
164 params.append(OSSL_PARAM_construct_int(OSSL_KDF_PARAM_PKCS5, &checkDisabled));
165 params.append(OSSL_PARAM_construct_end());
167 if (EVP_KDF_CTX_set_params(
ctx,
params.data()) <= 0)
172 if (!EVP_KDF_derive(
ctx,
reinterpret_cast<unsigned char*
>(
derived.data()),
derived.size(),
nullptr))
202 const quint64 maxLen =
quint64(std::numeric_limits<quint32>::max() - 1) * hashLen;
203 if (dkLen > maxLen) {
204 qWarning().nospace() <<
"Derived key too long:\n"
205 << algorithm <<
" was chosen which produces output of length "
206 << maxLen <<
" but " << dkLen <<
" was requested.";
210 if (iterations < 1 || dkLen < 1)
213#ifdef USING_OPENSSL30
214 if (methodToName(algorithm))
215 return opensslDeriveKeyPbkdf2(algorithm,
data, salt, iterations, dkLen);
237 std::bit_xor<char>());
char * data()
\macro QT_NO_CAST_FROM_BYTEARRAY
qsizetype size() const noexcept
Returns the number of bytes in this byte array.
const_iterator cbegin() const noexcept
const_iterator cend() const noexcept
QByteArray left(qsizetype len) const
Returns a byte array that contains the first len bytes of this byte array.
iterator begin()
Returns an \l{STL-style iterators}{STL-style iterator} pointing to the first byte in the byte-array.
static int hashLength(Algorithm method)
Returns the size of the output of the selected hash method in bytes.
void addData(const char *data, qsizetype length)
This is an overloaded member function, provided for convenience. It differs from the above function o...
QByteArray result() const
Returns the final authentication code.
void reset() noexcept
Resets message data.
QHash< int, QWidget * > hash
[35multi]
Q_NETWORK_EXPORT QByteArray deriveKeyPbkdf1(QCryptographicHash::Algorithm algorithm, const QByteArray &data, const QByteArray &salt, int iterations, quint64 dkLen)
Q_NETWORK_EXPORT QByteArray deriveKeyPbkdf2(QCryptographicHash::Algorithm algorithm, const QByteArray &data, const QByteArray &salt, int iterations, quint64 dkLen)
Combined button and popup list for selecting options.
constexpr Initialization Uninitialized
DBusConnection const char DBusError DBusBusType DBusError return DBusConnection DBusHandleMessageFunction void DBusFreeFunction return DBusConnection return DBusConnection return const char DBusError return DBusConnection DBusMessage dbus_uint32_t return DBusConnection dbus_bool_t DBusConnection DBusAddWatchFunction DBusRemoveWatchFunction DBusWatchToggledFunction void DBusFreeFunction return DBusConnection DBusDispatchStatusFunction void DBusFreeFunction DBusTimeout return DBusTimeout return DBusWatch return DBusWatch unsigned int return DBusError const DBusError return const DBusMessage return DBusMessage return DBusMessage return DBusMessage return DBusMessage return DBusMessage return DBusMessageIter * iter
DBusConnection const char DBusError DBusBusType DBusError return DBusConnection DBusHandleMessageFunction void DBusFreeFunction return DBusConnection return DBusConnection return const char DBusError return DBusConnection DBusMessage dbus_uint32_t return DBusConnection dbus_bool_t DBusConnection DBusAddWatchFunction DBusRemoveWatchFunction DBusWatchToggledFunction void DBusFreeFunction return DBusConnection DBusDispatchStatusFunction void DBusFreeFunction DBusTimeout return DBusTimeout return DBusWatch return DBusWatch unsigned int return DBusError const DBusError return const DBusMessage return DBusMessage return DBusMessage return DBusMessage return DBusMessage return DBusMessage return DBusMessageIter int const void return DBusMessageIter DBusMessageIter return DBusMessageIter void DBusMessageIter void int return DBusMessage DBusMessageIter return DBusMessageIter return DBusMessageIter DBusMessageIter const char const char const char const char * method
constexpr T qToBigEndian(T source)
GLint GLsizei GLsizei GLenum GLenum GLsizei void * data
QScopeGuard< typename std::decay< F >::type > qScopeGuard(F &&f)
[qScopeGuard]
unsigned long long quint64