mirror of
https://github.com/RGBCube/serenity
synced 2025-05-16 23:15:07 +00:00

These are only used by Userland and contain infallible String allocations, so let's just ifdef them out of the Kernel.
53 lines
1 KiB
C++
53 lines
1 KiB
C++
/*
|
|
* Copyright (c) 2020, Ali Mohammad Pur <mpfard@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/ByteBuffer.h>
|
|
|
|
#ifndef KERNEL
|
|
# include <AK/String.h>
|
|
#endif
|
|
|
|
namespace Crypto {
|
|
namespace PK {
|
|
|
|
// FIXME: Fixing name up for grabs
|
|
template<typename PrivKeyT, typename PubKeyT>
|
|
class PKSystem {
|
|
public:
|
|
using PublicKeyType = PubKeyT;
|
|
using PrivateKeyType = PrivKeyT;
|
|
|
|
PKSystem(PublicKeyType& pubkey, PrivateKeyType& privkey)
|
|
: m_public_key(pubkey)
|
|
, m_private_key(privkey)
|
|
{
|
|
}
|
|
|
|
PKSystem() = default;
|
|
|
|
virtual void encrypt(ReadonlyBytes in, Bytes& out) = 0;
|
|
virtual void decrypt(ReadonlyBytes in, Bytes& out) = 0;
|
|
|
|
virtual void sign(ReadonlyBytes in, Bytes& out) = 0;
|
|
virtual void verify(ReadonlyBytes in, Bytes& out) = 0;
|
|
|
|
#ifndef KERNEL
|
|
virtual String class_name() const = 0;
|
|
#endif
|
|
|
|
virtual size_t output_size() const = 0;
|
|
|
|
protected:
|
|
virtual ~PKSystem() = default;
|
|
|
|
PublicKeyType m_public_key;
|
|
PrivateKeyType m_private_key;
|
|
};
|
|
|
|
}
|
|
}
|