2011-08-20 21:37:37 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2011 Sansar Choinyambuu
|
|
|
|
* HSR Hochschule fuer Technik Rapperswil
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License as published by the
|
|
|
|
* Free Software Foundation; either version 2 of the License, or (at your
|
|
|
|
* option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @defgroup pts pts
|
|
|
|
* @{ @ingroup pts
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PTS_H_
|
|
|
|
#define PTS_H_
|
|
|
|
|
|
|
|
typedef struct pts_t pts_t;
|
|
|
|
|
2011-09-09 09:23:19 +00:00
|
|
|
#include "pts_error.h"
|
2011-08-21 08:38:51 +00:00
|
|
|
#include "pts_proto_caps.h"
|
|
|
|
#include "pts_meas_algo.h"
|
2011-09-01 13:42:35 +00:00
|
|
|
#include "pts_file_meas.h"
|
2011-09-14 13:41:57 +00:00
|
|
|
#include "pts_file_meta.h"
|
2011-09-21 14:32:25 +00:00
|
|
|
#include "pts_dh_group.h"
|
2011-08-31 13:04:05 +00:00
|
|
|
|
2011-08-20 21:37:37 +00:00
|
|
|
#include <library.h>
|
|
|
|
|
2011-09-09 09:23:19 +00:00
|
|
|
/**
|
|
|
|
* UTF-8 encoding of the character used to delimiter the filename
|
|
|
|
*/
|
2011-09-14 13:41:57 +00:00
|
|
|
#define SOLIDUS_UTF 0x2F
|
|
|
|
#define REVERSE_SOLIDUS_UTF 0x5C
|
2011-09-09 09:23:19 +00:00
|
|
|
|
2011-09-23 14:06:29 +00:00
|
|
|
/**
|
|
|
|
* Lenght of the generated nonce used for calculation of shared secret
|
|
|
|
*/
|
|
|
|
#define NONCE_LEN 20
|
|
|
|
|
2011-08-20 21:37:37 +00:00
|
|
|
/**
|
|
|
|
* Class implementing the TCG Platform Trust System (PTS)
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
struct pts_t {
|
|
|
|
|
|
|
|
/**
|
2011-08-21 08:38:51 +00:00
|
|
|
* Get PTS Protocol Capabilities
|
|
|
|
*
|
2011-09-02 07:39:11 +00:00
|
|
|
* @return protocol capabilities flags
|
2011-08-21 08:38:51 +00:00
|
|
|
*/
|
|
|
|
pts_proto_caps_flag_t (*get_proto_caps)(pts_t *this);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set PTS Protocol Capabilities
|
|
|
|
*
|
2011-09-02 07:39:11 +00:00
|
|
|
* @param flags protocol capabilities flags
|
2011-08-21 08:38:51 +00:00
|
|
|
*/
|
|
|
|
void (*set_proto_caps)(pts_t *this, pts_proto_caps_flag_t flags);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get PTS Measurement Algorithm
|
2011-08-20 21:37:37 +00:00
|
|
|
*
|
2011-09-02 07:39:11 +00:00
|
|
|
* @return measurement algorithm
|
2011-08-21 08:38:51 +00:00
|
|
|
*/
|
|
|
|
pts_meas_algorithms_t (*get_meas_algorithm)(pts_t *this);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set PTS Measurement Algorithm
|
|
|
|
*
|
2011-09-02 07:39:11 +00:00
|
|
|
* @param algorithm measurement algorithm
|
2011-08-21 08:38:51 +00:00
|
|
|
*/
|
|
|
|
void (*set_meas_algorithm)(pts_t *this, pts_meas_algorithms_t algorithm);
|
|
|
|
|
2011-09-21 14:32:25 +00:00
|
|
|
/**
|
|
|
|
* Get PTS Diffie Hellman Group
|
|
|
|
*
|
|
|
|
* @return DH Group
|
|
|
|
*/
|
|
|
|
pts_dh_group_t (*get_dh_group)(pts_t *this);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set PTS Diffie Hellman Group
|
|
|
|
*
|
|
|
|
* @param dh_group DH Group
|
|
|
|
*/
|
|
|
|
void (*set_dh_group)(pts_t *this, pts_dh_group_t dh_group);
|
|
|
|
|
2011-09-23 14:06:29 +00:00
|
|
|
/**
|
|
|
|
* Set PTS Diffie Hellman Object
|
|
|
|
*
|
|
|
|
* @param dh D-H object
|
|
|
|
*/
|
|
|
|
bool (*create_dh)(pts_t *this, pts_dh_group_t group);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets Own Diffie Hellman Public Value
|
|
|
|
*
|
|
|
|
* @return D-H Public Value
|
|
|
|
*/
|
|
|
|
chunk_t (*get_my_pub_val)(pts_t *this);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the public value of partner.
|
|
|
|
*
|
|
|
|
* @param value public value of partner
|
|
|
|
*/
|
|
|
|
void (*set_other_pub_val) (pts_t *this, chunk_t value);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Calculates secret assessment value to be used for TPM Quote as an external data
|
|
|
|
*
|
|
|
|
* @param initiator_nonce Initiator nonce (IMV nonce)
|
|
|
|
* @param responder_nonce Responder nonce (IMC nonce)
|
|
|
|
* @param algorithm Hashing algorithm
|
|
|
|
* @return TRUE, FALSE if not both DH public values and
|
|
|
|
* nonces are set
|
|
|
|
*/
|
|
|
|
bool (*calculate_secret) (pts_t *this, chunk_t initiator_nonce,
|
|
|
|
chunk_t responder_nonce, pts_meas_algorithms_t algorithm);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns secret assessment value to be used for TPM Quote as an external data
|
|
|
|
*
|
|
|
|
* @return Secret assessment value
|
|
|
|
*/
|
|
|
|
chunk_t (*get_secret) (pts_t *this);
|
|
|
|
|
2011-09-01 13:42:35 +00:00
|
|
|
/**
|
|
|
|
* Get Platform and OS Info
|
|
|
|
*
|
|
|
|
* @return platform and OS info
|
|
|
|
*/
|
|
|
|
char* (*get_platform_info)(pts_t *this);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set Platform and OS Info
|
|
|
|
*
|
|
|
|
* @param info platform and OS info
|
|
|
|
*/
|
|
|
|
void (*set_platform_info)(pts_t *this, char *info);
|
|
|
|
|
2011-08-21 08:38:51 +00:00
|
|
|
/**
|
|
|
|
* Get TPM 1.2 Version Info
|
|
|
|
*
|
|
|
|
* @param info chunk containing a TPM_CAP_VERSION_INFO struct
|
2011-09-02 07:39:11 +00:00
|
|
|
* @return TRUE if TPM Version Info available
|
2011-08-20 21:37:37 +00:00
|
|
|
*/
|
|
|
|
bool (*get_tpm_version_info)(pts_t *this, chunk_t *info);
|
|
|
|
|
|
|
|
/**
|
2011-08-21 08:38:51 +00:00
|
|
|
* Set TPM 1.2 Version Info
|
2011-08-20 21:37:37 +00:00
|
|
|
*
|
2011-09-02 07:39:11 +00:00
|
|
|
* @param info chunk containing a TPM_CAP_VERSION_INFO struct
|
2011-08-20 21:37:37 +00:00
|
|
|
*/
|
|
|
|
void (*set_tpm_version_info)(pts_t *this, chunk_t info);
|
2011-09-28 13:14:02 +00:00
|
|
|
|
2011-08-26 12:16:12 +00:00
|
|
|
/**
|
2011-09-05 09:15:34 +00:00
|
|
|
* Get Attestation Identity Certificate or Public Key
|
2011-08-26 12:16:12 +00:00
|
|
|
*
|
2011-09-05 09:15:34 +00:00
|
|
|
* @return AIK Certificate or Public Key
|
2011-08-26 12:16:12 +00:00
|
|
|
*/
|
2011-09-05 09:15:34 +00:00
|
|
|
certificate_t* (*get_aik)(pts_t *this);
|
2011-09-28 13:14:02 +00:00
|
|
|
|
2011-09-02 14:07:39 +00:00
|
|
|
/**
|
2011-09-05 09:15:34 +00:00
|
|
|
* Set Attestation Identity Certificate or Public Key
|
2011-09-02 14:07:39 +00:00
|
|
|
*
|
2011-09-05 09:15:34 +00:00
|
|
|
* @param aik AIK Certificate or Public Key
|
2011-09-02 14:07:39 +00:00
|
|
|
*/
|
2011-09-05 09:15:34 +00:00
|
|
|
void (*set_aik)(pts_t *this, certificate_t *aik);
|
2011-09-02 14:07:39 +00:00
|
|
|
|
2011-09-09 09:23:19 +00:00
|
|
|
/**
|
|
|
|
* Check whether path is valid file/directory on filesystem
|
|
|
|
*
|
|
|
|
* @param path Absolute path
|
|
|
|
* @param error_code Output variable for PTS error code
|
|
|
|
* @return TRUE if path is valid or file/directory doesn't exist
|
|
|
|
* or path is invalid
|
2011-11-03 18:30:17 +00:00
|
|
|
* FALSE if local error occurred within stat function
|
2011-09-09 09:23:19 +00:00
|
|
|
*/
|
|
|
|
bool (*is_path_valid)(pts_t *this, char *path, pts_error_code_t *error_code);
|
|
|
|
|
2011-08-24 07:34:55 +00:00
|
|
|
/**
|
2011-09-01 13:42:35 +00:00
|
|
|
* Do PTS File Measurements
|
2011-08-24 07:34:55 +00:00
|
|
|
*
|
2011-09-01 13:42:35 +00:00
|
|
|
* @param request_id ID of PTS File Measurement Request
|
|
|
|
* @param pathname Absolute pathname of file to be measured
|
|
|
|
* @param is_directory if TRUE directory contents are measured
|
2011-09-02 07:39:11 +00:00
|
|
|
* @return PTS File Measurements of NULL if FAILED
|
2011-08-24 07:34:55 +00:00
|
|
|
*/
|
2011-09-01 13:42:35 +00:00
|
|
|
pts_file_meas_t* (*do_measurements)(pts_t *this, u_int16_t request_id,
|
2011-09-05 09:15:34 +00:00
|
|
|
char *pathname, bool is_directory);
|
2011-09-14 13:41:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Obtain file metadata
|
|
|
|
*
|
|
|
|
* @param pathname Absolute pathname of file/directory
|
|
|
|
* @param is_directory if TRUE directory contents are requested
|
|
|
|
* @return PTS File Metadata or NULL if FAILED
|
|
|
|
*/
|
|
|
|
pts_file_meta_t* (*get_metadata)(pts_t *this, char *pathname, bool is_directory);
|
2011-09-28 13:14:02 +00:00
|
|
|
|
2011-08-20 21:37:37 +00:00
|
|
|
/**
|
|
|
|
* Destroys a pts_t object.
|
|
|
|
*/
|
|
|
|
void (*destroy)(pts_t *this);
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates an pts_t object
|
2011-08-21 08:38:51 +00:00
|
|
|
*
|
|
|
|
* @param is_imc TRUE if running on an IMC
|
2011-08-20 21:37:37 +00:00
|
|
|
*/
|
2011-08-21 08:38:51 +00:00
|
|
|
pts_t* pts_create(bool is_imc);
|
2011-08-20 21:37:37 +00:00
|
|
|
|
2011-09-28 13:14:02 +00:00
|
|
|
#endif /** PTS_H_ @}*/
|