blob: f6bd64d42ffd6ee21758848fa84c9618df4596af [file] [log] [blame]
Adrien Béraud612b55b2023-05-29 10:42:04 -04001/*
2 * Copyright (C) 2004-2023 Savoir-faire Linux Inc.
3 *
Adrien Béraudcb753622023-07-17 22:32:49 -04004 * This program is free software: you can redistribute it and/or modify
Adrien Béraud612b55b2023-05-29 10:42:04 -04005 * it under the terms of the GNU General Public License as published by
Adrien Béraudcb753622023-07-17 22:32:49 -04006 * the Free Software Foundation, either version 3 of the License, or
Adrien Béraud612b55b2023-05-29 10:42:04 -04007 * (at your option) any later version.
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Adrien Béraudcb753622023-07-17 22:32:49 -040011 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
Adrien Béraud612b55b2023-05-29 10:42:04 -040012 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
Adrien Béraudcb753622023-07-17 22:32:49 -040015 * along with this program. If not, see <https://www.gnu.org/licenses/>.
Adrien Béraud612b55b2023-05-29 10:42:04 -040016 */
Adrien Béraud612b55b2023-05-29 10:42:04 -040017#pragma once
18
19#include <gnutls/gnutls.h>
20
21#include <vector>
22#include <memory>
23#include <cstdint>
24#include <string>
25
Adrien Béraud1ae60aa2023-07-07 09:55:09 -040026namespace dhtnet {
Adrien Béraud612b55b2023-05-29 10:42:04 -040027namespace tls {
28
29class DhParams
30{
31public:
32 DhParams() = default;
33 DhParams(DhParams&&) = default;
34 DhParams(const DhParams& other) { *this = other; }
35
36 DhParams& operator=(DhParams&& other) = default;
37 DhParams& operator=(const DhParams& other);
38
39 /// \brief Construct by taking ownership of given gnutls DH params
40 ///
41 /// User should not call gnutls_dh_params_deinit on given \a raw_params.
42 /// The object is stolen and its live is manager by our object.
43 explicit DhParams(gnutls_dh_params_t p)
44 : params_ {p, gnutls_dh_params_deinit}
45 {}
46
47 /** Deserialize DER or PEM encoded DH-params */
48 DhParams(const std::vector<uint8_t>& data);
49
50 gnutls_dh_params_t get() { return params_.get(); }
51 gnutls_dh_params_t get() const { return params_.get(); }
52
53 explicit inline operator bool() const { return bool(params_); }
54
55 /** Serialize data in PEM format */
56 std::vector<uint8_t> serialize() const;
57
58 static DhParams generate();
59
60 static DhParams loadDhParams(const std::string& path);
61
62private:
63 std::unique_ptr<gnutls_dh_params_int, decltype(gnutls_dh_params_deinit)*>
64 params_ {nullptr, gnutls_dh_params_deinit};
65};
66
67} // namespace tls
Sébastien Blin464bdff2023-07-19 08:02:53 -040068} // namespace dhtnet