/* * 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 . * * 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 tcg_pts_attr_proto_caps tcg_pts_attr_proto_caps * @{ @ingroup tcg_attr */ #ifndef TCG_PTS_ATTR_PROTO_CAPS_H_ #define TCG_PTS_ATTR_PROTO_CAPS_H_ typedef struct tcg_pts_attr_proto_caps_t tcg_pts_attr_proto_caps_t; #include "tcg_attr.h" #include "pa_tnc/pa_tnc_attr.h" #include "pts/pts_proto_caps.h" /** * Class implementing the TCG PTS Protocol Capabilities Attribute */ struct tcg_pts_attr_proto_caps_t { /** * Public PA-TNC attribute interface */ pa_tnc_attr_t pa_tnc_attribute; /** * Get PTS procol capabilities flags * * @return set of flags */ pts_proto_caps_flag_t (*get_flags)(tcg_pts_attr_proto_caps_t *this); }; /** * Creates an tcg_pts_attr_proto_caps_t object * * @param flags set of flags * @param request TRUE for a PTS protocol capabilities request */ pa_tnc_attr_t* tcg_pts_attr_proto_caps_create(pts_proto_caps_flag_t flags, bool request); /** * Creates an tcg_pts_attr_proto_caps_t object from received data * * @param value unparsed attribute value * @param request TRUE for a PTS protocol capabilities request */ pa_tnc_attr_t* tcg_pts_attr_proto_caps_create_from_data(chunk_t value, bool request); #endif /** TCG_PTS_ATTR_PROTO_CAPS_H_ @}*/