2021-06-27 21:25:29 +00:00
|
|
|
/***
|
|
|
|
Copyright (C) 2021 J Reece Wilson (a/k/a "Reece"). All rights reserved.
|
|
|
|
|
2021-07-01 09:18:42 +00:00
|
|
|
File: ECC.hpp
|
|
|
|
Date: 2021-7-1
|
2021-06-27 21:25:29 +00:00
|
|
|
Author: Reece
|
|
|
|
***/
|
|
|
|
#pragma once
|
|
|
|
|
2021-09-14 23:56:26 +00:00
|
|
|
namespace Aurora::Crypto::ECC
|
|
|
|
{
|
|
|
|
class IECCPublic
|
|
|
|
{
|
|
|
|
public:
|
2021-09-15 18:55:22 +00:00
|
|
|
virtual bool Verify(const Memory::MemoryViewRead &payload,
|
|
|
|
const Memory::MemoryViewRead &signature) = 0;
|
2021-09-14 23:56:26 +00:00
|
|
|
|
|
|
|
|
2021-09-15 18:55:22 +00:00
|
|
|
virtual bool AsPublicECC(AuList<AuUInt8> &out) = 0;
|
2021-09-14 23:56:26 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
class IECCPrivate
|
|
|
|
{
|
|
|
|
public:
|
2021-09-15 18:55:22 +00:00
|
|
|
virtual bool Sign(const Memory::MemoryViewRead &payload,
|
2021-09-14 23:56:26 +00:00
|
|
|
EHashType method,
|
|
|
|
AuList<AuUInt8> &out) = 0;
|
|
|
|
|
2021-09-15 18:55:22 +00:00
|
|
|
virtual bool ECDH(const AuSPtr<IECCPublic> &partnerPublic,
|
|
|
|
AuList<AuUInt8> &sharedKey) = 0;
|
2021-09-14 23:56:26 +00:00
|
|
|
|
2021-09-15 18:55:22 +00:00
|
|
|
virtual bool AsPublicECC(AuList<AuUInt8> &out) = 0;
|
|
|
|
virtual bool AsPrivateECC(AuList<AuUInt8> &out) = 0;
|
2021-09-14 23:56:26 +00:00
|
|
|
};
|
2021-09-15 18:55:22 +00:00
|
|
|
|
|
|
|
enum EECCCurve
|
|
|
|
{
|
|
|
|
eCurve256,
|
|
|
|
eCurve384,
|
|
|
|
eCurveX25519,
|
|
|
|
eCurveEd25519
|
|
|
|
};
|
|
|
|
|
|
|
|
AUKN_SHARED_API(NewECC, IECCPrivate, EECCCurve curve);
|
|
|
|
AUKN_SHARED_API(OpenPrivateECC, IECCPrivate, EECCCurve curve, const Memory::MemoryViewRead &pk);
|
|
|
|
AUKN_SHARED_API(OpenPublicECC, IECCPublic, EECCCurve curve, const Memory::MemoryViewRead &pk);
|
|
|
|
AUKN_SHARED_API(OpenPublicECCFromCert, IECCPublic, EECCCurve curve, const Memory::MemoryViewRead &certificate);
|
2021-09-14 23:56:26 +00:00
|
|
|
}
|
|
|
|
|
2021-07-01 09:18:42 +00:00
|
|
|
#include "25519/25519.hpp"
|
|
|
|
#include "NIST/NIST.hpp"
|