2018-09-06 13:47:33 +00:00
|
|
|
/**
|
|
|
|
* Copyright (C) 2017-2018, U.S. Government
|
|
|
|
*/
|
|
|
|
#ifndef HIRS_PROVISIONERTPM2_INCLUDE_UTILS_H_
|
|
|
|
#define HIRS_PROVISIONERTPM2_INCLUDE_UTILS_H_
|
|
|
|
|
|
|
|
#include <re2/re2.h>
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
#include <unordered_map>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
namespace hirs {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Namespace for describing file utility functions.
|
|
|
|
*/
|
|
|
|
namespace file_utils {
|
|
|
|
/**
|
|
|
|
* Returns whether or not the argument directory exists.
|
|
|
|
* @return True if the directory exists. False, otherwise.
|
|
|
|
*/
|
|
|
|
bool dirExists(const std::string& filename);
|
|
|
|
|
|
|
|
bool fileExists(const std::string& filename);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads the contents of an entire file into a string.
|
|
|
|
* @param filename the name and path of the file to read.
|
|
|
|
* @return the contents of the specified file as a string.
|
|
|
|
*/
|
|
|
|
std::string fileToString(const std::string& filename);
|
|
|
|
|
|
|
|
std::string fileToString(const std::string& filename,
|
|
|
|
const std::string& defaultVal);
|
|
|
|
|
|
|
|
std::string getFileAsOneLineOrEmptyString(const std::string& filename);
|
|
|
|
|
|
|
|
void writeBinaryFile(const std::string& bytes,
|
|
|
|
const std::string& filename);
|
|
|
|
|
|
|
|
int getFileSize(const std::string& filename);
|
|
|
|
|
|
|
|
void splitFile(const std::string& inFilename,
|
|
|
|
const std::string& outFilename,
|
|
|
|
int startPos,
|
|
|
|
int readSize);
|
|
|
|
} // namespace file_utils
|
|
|
|
|
2018-10-12 02:03:25 +00:00
|
|
|
namespace json_utils {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Utility class that provides functions to parse information from ACA
|
|
|
|
* output.
|
|
|
|
*/
|
|
|
|
class JSONFieldParser {
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Parses the target field of the provided JSON object as a string.
|
|
|
|
*
|
|
|
|
* @param jsonObject the JSON-formatted object
|
|
|
|
* @param jsonFieldName the name of the field to parse from the JSON object
|
|
|
|
* @return the value of the target field in the JSON object
|
|
|
|
*/
|
|
|
|
static std::string parseJsonStringField(const std::string& jsonObject,
|
|
|
|
const std::string& jsonFieldName);
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace json_utils
|
|
|
|
|
2018-09-06 13:47:33 +00:00
|
|
|
namespace string_utils {
|
|
|
|
/**
|
|
|
|
* Converts a binary string to a hex string.
|
|
|
|
*
|
|
|
|
* @param bin the binary character array to convert
|
|
|
|
* @return hex string representation of bin
|
|
|
|
*/
|
|
|
|
std::string binaryToHex(const std::string& bin);
|
|
|
|
|
2018-10-02 20:21:35 +00:00
|
|
|
/**
|
|
|
|
* Checks if a string contains another string.
|
|
|
|
*
|
|
|
|
* @param str containing string
|
|
|
|
* @param substring string to search for
|
|
|
|
* @return true, if the string is found / false, otherwise
|
|
|
|
*/
|
|
|
|
bool contains(const std::string& str, const std::string& substring);
|
|
|
|
|
2018-09-06 13:47:33 +00:00
|
|
|
/**
|
|
|
|
* Converts an unsigned long (uint32) value to a hex string.
|
|
|
|
*
|
|
|
|
* @param value the unsigned long to convert
|
|
|
|
* @return hex string representation of the value
|
|
|
|
*/
|
|
|
|
std::string longToHex(const uint32_t& value);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks provided string contains only hexadecimal characters.
|
|
|
|
*
|
|
|
|
* @param str the string to check if hexadecimal only
|
|
|
|
* @return true, if hex chars only / false, otherwise
|
|
|
|
*/
|
|
|
|
bool isHexString(const std::string& str);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Converts a hex string to a string of bytes.
|
|
|
|
* Requires the hex string to have an even number of chars.
|
|
|
|
*
|
|
|
|
* @param hexString string of hex chars to be converted to bytes
|
|
|
|
* @return a byte string or, if error detected, empty string
|
|
|
|
*/
|
|
|
|
std::string hexToBytes(const std::string& hexString);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Takes a given hex string and converts it to a long value.
|
|
|
|
*
|
|
|
|
* @param hexString the hex string to be converted
|
|
|
|
* @return the value of the hex string when converted to a long value
|
|
|
|
* or 0 if an error occurred
|
|
|
|
*/
|
|
|
|
uint32_t hexToLong(const std::string& hexString);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes any new line characters in the input string and returns the
|
|
|
|
* pruned, input string.
|
|
|
|
* @param str string to remove new line characters from.
|
|
|
|
* @return str with new line characters removed.
|
|
|
|
*/
|
|
|
|
std::string trimNewLines(std::string str);
|
|
|
|
|
2018-10-02 20:21:35 +00:00
|
|
|
/**
|
|
|
|
* Removes any double-quote characters in the input string and returns the
|
|
|
|
* pruned, input string.
|
|
|
|
* @param str string to remove double-quotes characters from.
|
|
|
|
* @return str with double-quote characters removed.
|
|
|
|
*/
|
|
|
|
std::string trimQuotes(std::string str);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes any occurrences of the target character in the input string and
|
|
|
|
* returns the pruned, input string.
|
|
|
|
* @param str string to characters from.
|
|
|
|
* @param targetChar char to prune from the string
|
|
|
|
* @return str with the characters removed.
|
|
|
|
*/
|
|
|
|
std::string trimChar(std::string str, char targetChar);
|
|
|
|
|
2018-09-06 13:47:33 +00:00
|
|
|
std::string trimWhitespaceFromLeft(std::string str);
|
|
|
|
|
|
|
|
std::string trimWhitespaceFromRight(std::string str);
|
|
|
|
|
|
|
|
std::string trimWhitespaceFromBothEnds(std::string str);
|
|
|
|
} // namespace string_utils
|
|
|
|
|
|
|
|
namespace tpm2_tools_utils {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enum class that provides list of supported tpm2_tools versions
|
|
|
|
*/
|
|
|
|
enum class Tpm2ToolsVersion {
|
|
|
|
VERSION_1_1_0,
|
2018-10-02 20:21:35 +00:00
|
|
|
VERSION_2_1_0,
|
2018-09-06 13:47:33 +00:00
|
|
|
VERSION_3_0_1
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Utility class that determines the version of tpm2_tools present on the
|
|
|
|
* system.
|
|
|
|
*/
|
|
|
|
class Tpm2ToolsVersionChecker {
|
|
|
|
private:
|
|
|
|
static const std::unordered_map<std::string, Tpm2ToolsVersion> kVersionMap;
|
2018-10-02 20:21:35 +00:00
|
|
|
static const std::unordered_map<std::string,
|
|
|
|
Tpm2ToolsVersion> kMaxSupportedVersionMap;
|
|
|
|
|
|
|
|
static std::string getDistribution();
|
2018-09-06 13:47:33 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Makes a simple tpm2-tools call to determine the version available on the
|
|
|
|
* current system.
|
|
|
|
*
|
|
|
|
* @return enum specifying the version of tpm2-tools available locally
|
|
|
|
*/
|
|
|
|
static Tpm2ToolsVersion findTpm2ToolsVersion();
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2018-10-12 02:03:25 +00:00
|
|
|
/**
|
2018-09-06 13:47:33 +00:00
|
|
|
* Utility class that provides functions to parse information from tpm2_tools
|
|
|
|
* output.
|
|
|
|
*/
|
|
|
|
class Tpm2ToolsOutputParser {
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Parses the provided Non-volatile (NV) Index List for the data size of
|
|
|
|
* the index at the prescribed NV handle. Expects output from tpm2_nvlist.
|
|
|
|
*
|
|
|
|
* @param nvHandle memory address to search the nvListOutput for
|
|
|
|
* @param nvListOutput the NV Index List to search for the data size
|
|
|
|
* @return the size of the desired NV index or 0 if the index isn't found
|
|
|
|
*/
|
|
|
|
static uint16_t parseNvDataSize(const std::string& nvHandle,
|
|
|
|
const std::string& nvListOutput);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Pulls the data out of the output from a tpm2_nvread command.
|
|
|
|
*
|
|
|
|
* @param nvReadOutput the output from a call to tpm2_nvread
|
|
|
|
* @return the data serialized as bytes, or an empty string if
|
|
|
|
* nvReadOutput improperly formatted
|
|
|
|
*/
|
|
|
|
static std::string parseNvReadOutput(const std::string& nvReadOutput);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Parses the provided Persistent Object List for the provided handle.
|
|
|
|
*
|
|
|
|
* @param handle memory address to search the nvListPersistentOutput for
|
|
|
|
* @param listPersistentOutput the Persistent Object list to search
|
|
|
|
* @return true, if handle is found / false, otherwise
|
|
|
|
*/
|
|
|
|
static bool parsePersistentObjectExists(const std::string& handle,
|
|
|
|
const std::string& listPersistentOutput);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Parses the provided tpm2-tool output for a TPM Error Code.
|
|
|
|
*
|
|
|
|
* @param toolOutput the output from a call to any of the tpm2-tools
|
|
|
|
* @return a TPM error code if found, or an empty string, otherwise
|
|
|
|
*/
|
|
|
|
static std::string parseTpmErrorCode(const std::string& toolOutput);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Parses the provided tpm2-tool output for a tpm2_tools version.
|
|
|
|
*
|
|
|
|
* @param toolOutput the output from a call to any of the tpm2-tools
|
|
|
|
* @return a tpm2_tools version if found, or an empty string, otherwise
|
|
|
|
*/
|
|
|
|
static std::string parseTpm2ToolsVersion(const std::string& toolOutput);
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace tpm2_tools_utils
|
|
|
|
|
|
|
|
} // namespace hirs
|
|
|
|
|
|
|
|
#endif // HIRS_PROVISIONERTPM2_INCLUDE_UTILS_H_
|