ORE Studio 0.0.4
Loading...
Searching...
No Matches
encryption.hpp
1/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2 *
3 * Copyright (C) 2025 Marco Craveiro <marco.craveiro@gmail.com>
4 *
5 * This program is free software; you can redistribute it and/or modify it under
6 * the terms of the GNU General Public License as published by the Free Software
7 * Foundation; either version 3 of the License, or (at your option) any later
8 * version.
9 *
10 * This program is distributed in the hope that it will be useful, but WITHOUT
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
12 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
13 * details.
14 *
15 * You should have received a copy of the GNU General Public License along with
16 * this program; if not, write to the Free Software Foundation, Inc., 51
17 * Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 *
19 */
20#ifndef ORES_SECURITY_CRYPTO_ENCRYPTION_HPP
21#define ORES_SECURITY_CRYPTO_ENCRYPTION_HPP
22
23#include <string>
24#include <vector>
25
26namespace ores::security::crypto {
27
40class encryption final {
41public:
42 static constexpr size_t SALT_LEN = 16;
43 static constexpr size_t IV_LEN = 12;
44 static constexpr size_t TAG_LEN = 16;
45 static constexpr size_t KEY_LEN = 32; // AES-256
46 static constexpr int PBKDF2_ITERATIONS = 600000; // OWASP recommendation
47
54 static std::string encrypt(const std::string& plaintext,
55 const std::string& password);
56
64 static std::string decrypt(const std::string& encrypted_data,
65 const std::string& password);
66
73 static bool verify_password(const std::string& encrypted_data,
74 const std::string& password);
75
76private:
77 static std::vector<unsigned char> derive_key(
78 const std::string& password,
79 const std::vector<unsigned char>& salt);
80};
81
82}
83
84#endif
AES-256-GCM encryption service.
Definition encryption.hpp:40
static std::string encrypt(const std::string &plaintext, const std::string &password)
Encrypt plaintext using a password.
Definition encryption.cpp:48
static bool verify_password(const std::string &encrypted_data, const std::string &password)
Verify if a password can decrypt the given data.
Definition encryption.cpp:181
static std::string decrypt(const std::string &encrypted_data, const std::string &password)
Decrypt ciphertext using a password.
Definition encryption.cpp:114