9 #ifndef NDN_SECURITY_SEC_TPM_FILE_HPP
10 #define NDN_SECURITY_SEC_TPM_FILE_HPP
12 #include "../common.hpp"
51 m_inTerminal = inTerminal;
67 unlockTpm(
const char* password,
size_t passwordLength,
bool usePassword)
78 virtual shared_ptr<PublicKey>
82 signInTpm(
const uint8_t* data,
size_t dataLength,
86 decryptInTpm(
const uint8_t* data,
size_t dataLength,
const Name& keyName,
bool isSymmetric);
89 encryptInTpm(
const uint8_t* data,
size_t dataLength,
const Name& keyName,
bool isSymmetric);
120 shared_ptr<Impl> m_impl;
126 #endif //NDN_SECURITY_SEC_TPM_FILE_HPP
virtual bool unlockTpm(const char *password, size_t passwordLength, bool usePassword)
Unlock the TPM.
virtual void resetTpmPassword()
reset password of TPM
virtual void generateSymmetricKeyInTpm(const Name &keyName, KeyType keyType, int keySize)
Generate a symmetric key.
Error(const std::string &what)
virtual bool doesKeyExistInTpm(const Name &keyName, KeyClass keyClass)
Check if a particular key exists.
virtual void setTpmPassword(const uint8_t *password, size_t passwordLength)
set password of TPM
virtual bool getInTerminal()
get inTerminal flag
Class representing wire element of the NDN packet.
SecTpmFile(const std::string &dir="")
ptr_lib::shared_ptr< const Buffer > ConstBufferPtr
virtual void deleteKeyPairInTpm(const Name &keyName)
Delete a key pair of asymmetric keys.
virtual shared_ptr< PublicKey > getPublicKeyFromTpm(const Name &keyName)
Get a public key.
virtual ConstBufferPtr decryptInTpm(const uint8_t *data, size_t dataLength, const Name &keyName, bool isSymmetric)
Decrypt data.
SecTpm is the base class of the TPM classes.
virtual bool generateRandomBlock(uint8_t *res, size_t size)
Generate a random block.
A Name holds an array of Name::Component and represents an NDN name.
virtual ConstBufferPtr exportPrivateKeyPkcs8FromTpm(const Name &keyName)
Export a private key in PKCS#8 format.
virtual void setInTerminal(bool inTerminal)
set inTerminal flag
virtual Block signInTpm(const uint8_t *data, size_t dataLength, const Name &keyName, DigestAlgorithm digestAlgorithm)
Sign data.
virtual bool importPublicKeyPkcs1IntoTpm(const Name &keyName, const uint8_t *buf, size_t size)
Import a public key in PKCS#1 format.
virtual ConstBufferPtr encryptInTpm(const uint8_t *data, size_t dataLength, const Name &keyName, bool isSymmetric)
Encrypt data.
virtual void addAppToACL(const Name &keyName, KeyClass keyClass, const std::string &appPath, AclType acl)
Add the application into the ACL of a particular key.
virtual bool importPrivateKeyPkcs8IntoTpm(const Name &keyName, const uint8_t *buf, size_t size)
Import a private key in PKCS#8 format.
virtual void generateKeyPairInTpm(const Name &keyName, KeyType keyType, int keySize)
Generate a pair of asymmetric keys.
virtual bool locked()
check if TPM is locked.