security_db_record.hh 2.65 KB
Newer Older
garciay's avatar
garciay committed
#pragma once

garciay's avatar
garciay committed
#include <string>
garciay's avatar
garciay committed
#include <vector>

#include "ec_keys.hh"

garciay's avatar
garciay committed
namespace IEEE1609dot2 {
  class CertificateBase;
};

garciay's avatar
garciay committed
/*!
 * \class security_db_record
 * \brief This class provides security record description for security database
 */
class security_db_record {
  
  ec_elliptic_curves _algorithm;
  std::string _certificate_id;                    /*!< certificate storage*/
  std::vector<unsigned char> _certificate;        /*!< Certificate storage */
  std::vector<unsigned char> _hashed_id_issuer;   /*!< Certificate hash id 8 storage */
  std::vector<unsigned char> _hashed_id;          /*!< Certificate hash id 8 storage */
  std::vector<unsigned char> _pr_key;             /*!< Private key storage */
  std::vector<unsigned char> _pu_key_x;           /*!< Public key X storage */
  std::vector<unsigned char> _pu_key_y;           /*!< Public key Y storage */
garciay's avatar
garciay committed
  bool _to_be_saved;                              /*!< Flag to indicate if the record shall be saved, i.e. has been modified */
  IEEE1609dot2::CertificateBase* _decoded_certificate;
garciay's avatar
garciay committed
  
public: /*! \publicsection */
  /*!
   * \brief Default private ctor
   */
garciay's avatar
garciay committed
  security_db_record(): _algorithm{ec_elliptic_curves::nist_p_256}, _certificate_id(), _certificate(), _hashed_id_issuer(), _hashed_id(), _pr_key(), _pu_key_x(), _pu_key_y(), _to_be_saved(false), _decoded_certificate(nullptr) { };
  security_db_record(const std::string& p_certificate_id, const std::vector<unsigned char>& p_certificate, const IEEE1609dot2::CertificateBase& p_decoded_certificate, const std::vector<unsigned char>& p_hashed_id_issuer, const std::vector<unsigned char>& p_hashed_id, const std::vector<unsigned char>& p_pr_key, const std::vector<unsigned char>& p_pu_key_x, const std::vector<unsigned char>& p_pu_key_y, const bool p_to_be_saved = true);
garciay's avatar
garciay committed
  
  /*!
   * \brief Default private dtor
   */
garciay's avatar
garciay committed
  ~security_db_record() { if (_decoded_certificate != nullptr) { delete _decoded_certificate; } };
garciay's avatar
garciay committed
  const IEEE1609dot2::CertificateBase& decoded_certificate() const;
  
garciay's avatar
garciay committed
  inline const std::string& certificate_id() const { return _certificate_id; };
  inline const std::vector<unsigned char>& certificate() const { return _certificate; };
  inline const std::vector<unsigned char>& hashed_id() const { return _hashed_id; };
garciay's avatar
garciay committed
  inline const std::vector<unsigned char>& issuer() const { return _hashed_id_issuer; };
garciay's avatar
garciay committed
  inline const std::vector<unsigned char>& private_key() const { return _pr_key; };
  inline const std::vector<unsigned char>& public_key_x() const { return _pu_key_x; };
  inline const std::vector<unsigned char>& public_key_y() const { return _pu_key_y; };
}; // End of class security_db_record