mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-08-18 19:18:29 -04:00

* Fix #8952 - move translations for Cipher and KDF strings into evaluated code instead of globally defined code. The strings were being baked prior to the language being set resulting in only english being displayed.
136 lines
4.1 KiB
C++
136 lines
4.1 KiB
C++
/*
|
|
* Copyright (C) 2010 Felix Geyer <debfx@fobos.de>
|
|
*
|
|
* This program 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 or (at your option)
|
|
* version 3 of the License.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef KEEPASSX_KEEPASS2_H
|
|
#define KEEPASSX_KEEPASS2_H
|
|
|
|
#include <QSharedPointer>
|
|
#include <QUuid>
|
|
#include <QVariant>
|
|
|
|
class Kdf;
|
|
|
|
namespace KeePass2
|
|
{
|
|
constexpr quint32 SIGNATURE_1 = 0x9AA2D903;
|
|
constexpr quint32 SIGNATURE_2 = 0xB54BFB67;
|
|
|
|
constexpr quint32 FILE_VERSION_CRITICAL_MASK = 0xFFFF0000;
|
|
constexpr quint32 FILE_VERSION_4_1 = 0x00040001;
|
|
constexpr quint32 FILE_VERSION_4 = 0x00040000;
|
|
constexpr quint32 FILE_VERSION_3_1 = 0x00030001;
|
|
constexpr quint32 FILE_VERSION_3 = 0x00030000;
|
|
constexpr quint32 FILE_VERSION_2 = 0x00020000;
|
|
constexpr quint32 FILE_VERSION_MIN = FILE_VERSION_2;
|
|
constexpr quint32 FILE_VERSION_MAX = FILE_VERSION_4_1;
|
|
|
|
constexpr quint16 VARIANTMAP_VERSION = 0x0100;
|
|
constexpr quint16 VARIANTMAP_CRITICAL_MASK = 0xFF00;
|
|
|
|
constexpr QSysInfo::Endian BYTEORDER = QSysInfo::LittleEndian;
|
|
|
|
extern const QUuid CIPHER_AES128;
|
|
extern const QUuid CIPHER_AES256;
|
|
extern const QUuid CIPHER_TWOFISH;
|
|
extern const QUuid CIPHER_CHACHA20;
|
|
|
|
extern const QUuid KDF_AES_KDBX3;
|
|
extern const QUuid KDF_AES_KDBX4;
|
|
extern const QUuid KDF_ARGON2D;
|
|
extern const QUuid KDF_ARGON2ID;
|
|
|
|
extern const QByteArray INNER_STREAM_SALSA20_IV;
|
|
|
|
extern const QString KDFPARAM_UUID;
|
|
extern const QString KDFPARAM_AES_ROUNDS;
|
|
extern const QString KDFPARAM_AES_SEED;
|
|
extern const QString KDFPARAM_ARGON2_SALT;
|
|
extern const QString KDFPARAM_ARGON2_PARALLELISM;
|
|
extern const QString KDFPARAM_ARGON2_MEMORY;
|
|
extern const QString KDFPARAM_ARGON2_ITERATIONS;
|
|
extern const QString KDFPARAM_ARGON2_VERSION;
|
|
extern const QString KDFPARAM_ARGON2_SECRET;
|
|
extern const QString KDFPARAM_ARGON2_ASSOCDATA;
|
|
|
|
extern const QList<QUuid> CIPHERS;
|
|
extern const QList<QUuid> KDFS;
|
|
|
|
enum class HeaderFieldID
|
|
{
|
|
EndOfHeader = 0,
|
|
Comment = 1,
|
|
CipherID = 2,
|
|
CompressionFlags = 3,
|
|
MasterSeed = 4,
|
|
TransformSeed = 5,
|
|
TransformRounds = 6,
|
|
EncryptionIV = 7,
|
|
ProtectedStreamKey = 8,
|
|
StreamStartBytes = 9,
|
|
InnerRandomStreamID = 10,
|
|
KdfParameters = 11,
|
|
PublicCustomData = 12
|
|
};
|
|
|
|
enum class InnerHeaderFieldID : quint8
|
|
{
|
|
End = 0,
|
|
InnerRandomStreamID = 1,
|
|
InnerRandomStreamKey = 2,
|
|
Binary = 3
|
|
};
|
|
|
|
enum class ProtectedStreamAlgo
|
|
{
|
|
ArcFourVariant = 1,
|
|
Salsa20 = 2,
|
|
ChaCha20 = 3,
|
|
InvalidProtectedStreamAlgo = -1
|
|
};
|
|
|
|
enum class VariantMapFieldType : quint8
|
|
{
|
|
End = 0,
|
|
// Byte = 0x02,
|
|
// UInt16 = 0x03,
|
|
UInt32 = 0x04,
|
|
UInt64 = 0x05,
|
|
// Signed mask: 0x08
|
|
Bool = 0x08,
|
|
// SByte = 0x0A,
|
|
// Int16 = 0x0B,
|
|
Int32 = 0x0C,
|
|
Int64 = 0x0D,
|
|
// Float = 0x10,
|
|
// Double = 0x11,
|
|
// Decimal = 0x12,
|
|
// Char = 0x17, // 16-bit Unicode character
|
|
String = 0x18,
|
|
// Array mask: 0x40
|
|
ByteArray = 0x42
|
|
};
|
|
|
|
QByteArray hmacKey(const QByteArray& masterSeed, const QByteArray& transformedMasterKey);
|
|
QSharedPointer<Kdf> kdfFromParameters(const QVariantMap& p);
|
|
QVariantMap kdfToParameters(const QSharedPointer<Kdf>& kdf);
|
|
QSharedPointer<Kdf> uuidToKdf(const QUuid& uuid);
|
|
ProtectedStreamAlgo idToProtectedStreamAlgo(quint32 id);
|
|
QString cipherToString(QUuid cipherUuid);
|
|
QString kdfToString(QUuid kdfUuid);
|
|
} // namespace KeePass2
|
|
|
|
#endif // KEEPASSX_KEEPASS2_H
|