2 * Copyright (C) 2011 Sansar Choinyambuu
3 * HSR Hochschule fuer Technik Rapperswil
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License as published by the
7 * Free Software Foundation; either version 2 of the License, or (at your
8 * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
12 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
17 * @defgroup tcg_pts_attr_file_meas tcg_pts_attr_file_meas
18 * @{ @ingroup tcg_pts_attr_file_meas
21 #ifndef TCG_PTS_ATTR_FILE_MEAS_H_
22 #define TCG_PTS_ATTR_FILE_MEAS_H_
24 typedef struct tcg_pts_attr_file_meas_t tcg_pts_attr_file_meas_t
;
27 #include "pa_tnc/pa_tnc_attr.h"
30 * Class implementing the TCG PTS File Measurement attribute
33 struct tcg_pts_attr_file_meas_t
{
36 * Public PA-TNC attribute interface
38 pa_tnc_attr_t pa_tnc_attribute
;
41 * Get Number of Files included
43 * @return Number of Files included
45 u_int64_t (*get_number_of_files
)(tcg_pts_attr_file_meas_t
*this);
48 * Set Number of Files included
50 * @param num_files Number of Files included
52 void (*set_number_of_files
)(tcg_pts_attr_file_meas_t
*this,
60 u_int16_t (*get_request_id
)(tcg_pts_attr_file_meas_t
*this);
65 * @param request_id Request ID
67 void (*set_request_id
)(tcg_pts_attr_file_meas_t
*this,
68 u_int16_t request_id
);
71 * Get Measurement Length
73 * @return Measurement Length
75 u_int16_t (*get_meas_len
)(tcg_pts_attr_file_meas_t
*this);
78 * Set Measurement Length
80 * @param meas_len Measurement Length
82 void (*set_meas_len
)(tcg_pts_attr_file_meas_t
*this,
86 * Add a file measurement entry
88 * @param measurement Measurement value
89 * @param file_name File Name
91 void (*add_file_meas
)(tcg_pts_attr_file_meas_t
*this, chunk_t measurement
,
95 * Enumerates over all file measurements
96 * Format: chunk_t *measurement, chunk_t *file_name
100 enumerator_t
* (*create_file_meas_enumerator
)(tcg_pts_attr_file_meas_t
*this);
104 * Creates an tcg_pts_attr_file_meas_t object
106 * @param directory_flag Directory Contents Flag
107 * @param request_id Request ID
108 * @param delimiter Delimiter Character
109 * @param path File Path
111 pa_tnc_attr_t
* tcg_pts_attr_file_meas_create(u_int64_t number_of_files
,
112 u_int16_t request_id
,
116 * Creates an tcg_pts_attr_file_meas_t object from received data
118 * @param value unparsed attribute value
120 pa_tnc_attr_t
* tcg_pts_attr_file_meas_create_from_data(chunk_t value
);
122 #endif /** TCG_PTS_ATTR_FILE_MEAS_H_ @}*/