8#include "Arp/System/Commons/Logging.h" 
    9#include "Arp/System/Commons/Io/Path.hpp" 
   10#include "Arp/System/Commons/Security/KeyPair.hpp" 
   11#include "Arp/System/Commons/Security/Certificate.hpp" 
   12#include "Arp/System/Commons/Security/SecurityListType.hpp" 
   13#include "Arp/System/Commons/Security/ItemInfo.hpp" 
   14#include "Arp/System/Commons/Security/KeyPairType.hpp" 
   15#include "Arp/System/Commons/Security/SecurityConfigurationError.hpp" 
   18#include <openssl/evp.h> 
   20namespace Arp { 
namespace System { 
namespace Commons { 
namespace Security
 
   28    enum KeyMustExist : 
bool 
   30        IgnoreMissingKey = 
false,
 
   31        RequireKeyExists = 
true 
   58    bool HasCertificate(
void);
 
   62    KeyPairType GetKeyType(
void);
 
   76    SecurityConfigurationError 
SetKeyPair(
const std::vector<byte>& pemData);
 
  108    SecurityConfigurationError 
ListContent(SecurityListType type, std::vector<ItemInfo>& result);
 
  113    SecurityConfigurationError 
AddElement(SecurityListType type, 
const std::vector<byte>& pemData);
 
  131    bool VerifyCertMatchesWithPrivateKey(
void);
 
  138    void loadKeyPair(KeyMustExist requireKeyExists);
 
  139    bool LoadSoftwareKeyPair();
 
  140    bool LoadHardwareKeyPair();
 
  141    void loadCertWithChain(
const String& file);
 
  142    void listIssuerList(std::vector<ItemInfo>& result);
 
  143    void listIdentityCert(std::vector<ItemInfo>& result);
 
  150    std::shared_ptr<KeyPair> keyPair;
 
  152    std::vector<Certificate> issuers;
 
  156    static const String CertificateFileName;
 
  157    static const String KeyFileName;
 
  158    static const String TpmKeyFileName;
 
  159    static const String DirectorySeparator;
 
  172    return this->storePath + DirectorySeparator + CertificateFileName;
 
  177    return this->storePath + DirectorySeparator + KeyFileName;
 
  182    return this->storePath + DirectorySeparator + TpmKeyFileName;
 
  185inline KeyPairType IdentityStore::GetKeyType(
void)
 
  187    return this->keyPair->GetKeyType();
 
Definition: Loggable.hxx:20
static String GetFileName(const String &path)
Get name of a file.
Class to handle x.509 certificates
Definition: Certificate.hpp:25
Class with represents a Identity (Certificate with Chain and private Key) and is able to initialze an...
Definition: IdentityStore.hpp:26
void CreateAllDirectories(void)
summary>list all elements in the list referenced by ListType
const std::shared_ptr< KeyPair > & GetKeyPair(void)
summary>Returns the type of the key pair
String GetName(void) const
Returns the name of the IdentityStore
Definition: IdentityStore.hpp:165
SecurityConfigurationError GenerateKeyPair(KeyPairType type)
SecurityConfigurationError DeleteElement(SecurityListType type, const String &identifier)
summary>Generate a new KeyPair for this IdentityStore
SecurityConfigurationError SetKeyPair(const std::vector< byte > &pemData)
IdentityStore(const IdentityStore &arg)=delete
Copy constructor.
SecurityConfigurationError AddElement(SecurityListType type, const std::vector< byte > &pemData)
summary>delete an elements from the list referenced by ListType, identified by identifier
std::vector< byte > GetPemCertificateWithChain(void)
std::vector< byte > GetDerCertificateWithChain(void)
summary>get the issuer certificates in PEM format
void InitSslContext(SSL_CTX *pSslCtx) const
Initializes a OpenSSL SSL_:CTX Structure with the private key and certificate
String GetFullTpmKeyFileName(void) const
summary>checks if a certificate is available for this IdentityStore
Definition: IdentityStore.hpp:180
std::vector< byte > GetPemCertificate(void)
std::vector< byte > GetPublicKey(void)
SecurityConfigurationError SetCertificate(const std::vector< byte > &pemData)
std::vector< byte > GenerateCSR()
String GetFullCertificateFileName(void) const
summary>Returns the absolute path to the key file
Definition: IdentityStore.hpp:170
IdentityStore & operator=(const IdentityStore &arg)=delete
Assignment operator.
std::vector< std::vector< byte > > GetIssuerPemCertificates(void)
summary>creates all needed directories inside the folder of this IdentityStore
SecurityConfigurationError ListContent(SecurityListType type, std::vector< ItemInfo > &result)
summary>add an element into the list referenced by ListType
std::vector< byte > GetDerCertificate(void)
~IdentityStore(void)=default
Destructs this instance and frees all resources.
IdentityStore(const String &basePath, const String &name, KeyMustExist requireKeyExists=RequireKeyExists)
Constructs an IdentityStore instance.
String GetFullKeyFileName(void) const
summary>Returns the absolute path to the tpm key file
Definition: IdentityStore.hpp:175
@ System
System components used by the System, Device, Plc or Io domains.
Root namespace for the PLCnext API