mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-07-16 05:51:55 +00:00
There is no need to have `RSAPrivateKey`, `RSAPublicKey`, `ECPrivateKey` and `ECPublicKey` to be templatize to utilize different implementation of numbers.
112 lines
2.6 KiB
C++
112 lines
2.6 KiB
C++
/*
|
|
* Copyright (c) 2024-2025, Altomani Gianluca <altomanigianluca@gmail.com>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/ByteBuffer.h>
|
|
#include <AK/StringView.h>
|
|
#include <LibCrypto/Curves/SECPxxxr1.h>
|
|
#include <LibCrypto/PK/PK.h>
|
|
|
|
namespace Crypto::PK {
|
|
|
|
class ECPublicKey {
|
|
public:
|
|
ECPublicKey(UnsignedBigInteger x, UnsignedBigInteger y, size_t scalar_size)
|
|
: m_x(move(x))
|
|
, m_y(move(y))
|
|
, m_scalar_size(scalar_size)
|
|
{
|
|
}
|
|
|
|
ECPublicKey(Curves::SECPxxxr1Point point)
|
|
: m_x(move(point.x))
|
|
, m_y(move(point.y))
|
|
, m_scalar_size(point.size)
|
|
{
|
|
}
|
|
|
|
ECPublicKey()
|
|
: m_x(0)
|
|
, m_y(0)
|
|
, m_scalar_size(0)
|
|
{
|
|
}
|
|
|
|
size_t scalar_size() const { return m_scalar_size; }
|
|
|
|
ErrorOr<ByteBuffer> x_bytes() const
|
|
{
|
|
return Curves::SECPxxxr1Point::scalar_to_bytes(m_x, m_scalar_size);
|
|
}
|
|
|
|
ErrorOr<ByteBuffer> y_bytes() const
|
|
{
|
|
return Curves::SECPxxxr1Point::scalar_to_bytes(m_y, m_scalar_size);
|
|
}
|
|
|
|
Curves::SECPxxxr1Point to_secpxxxr1_point() const
|
|
{
|
|
return Curves::SECPxxxr1Point { m_x, m_y, m_scalar_size };
|
|
}
|
|
|
|
ErrorOr<ByteBuffer> to_uncompressed() const
|
|
{
|
|
return to_secpxxxr1_point().to_uncompressed();
|
|
}
|
|
|
|
private:
|
|
UnsignedBigInteger m_x;
|
|
UnsignedBigInteger m_y;
|
|
size_t m_scalar_size;
|
|
};
|
|
|
|
// https://www.rfc-editor.org/rfc/rfc5915#section-3
|
|
class ECPrivateKey {
|
|
public:
|
|
ECPrivateKey(UnsignedBigInteger d, size_t scalar_size, Optional<Vector<int>> parameters, Optional<ECPublicKey> public_key)
|
|
: m_d(move(d))
|
|
, m_scalar_size(scalar_size)
|
|
, m_parameters(parameters)
|
|
, m_public_key(public_key)
|
|
{
|
|
}
|
|
|
|
ECPrivateKey() = default;
|
|
|
|
UnsignedBigInteger const& d() const { return m_d; }
|
|
ErrorOr<ByteBuffer> d_bytes() const
|
|
{
|
|
return Curves::SECPxxxr1Point::scalar_to_bytes(m_d, m_scalar_size);
|
|
}
|
|
|
|
Optional<Vector<int> const&> parameters() const { return m_parameters; }
|
|
Optional<ECPublicKey const&> public_key() const { return m_public_key; }
|
|
|
|
ErrorOr<ByteBuffer> export_as_der() const;
|
|
|
|
private:
|
|
UnsignedBigInteger m_d;
|
|
size_t m_scalar_size;
|
|
|
|
Optional<Vector<int>> m_parameters;
|
|
Optional<ECPublicKey> m_public_key;
|
|
};
|
|
|
|
template<typename PubKey, typename PrivKey>
|
|
struct ECKeyPair {
|
|
PubKey public_key;
|
|
PrivKey private_key;
|
|
};
|
|
|
|
class EC : public PKSystem<ECPrivateKey, ECPublicKey> {
|
|
public:
|
|
using KeyPairType = ECKeyPair<PublicKeyType, PrivateKeyType>;
|
|
|
|
static ErrorOr<KeyPairType> parse_ec_key(ReadonlyBytes der, bool is_private, Vector<StringView> current_scope);
|
|
};
|
|
|
|
}
|