/* * Copyright (C) 2002 Ueli Galizzi, Ariane Seiler * Copyright (C) 2003 Martin Berner, Lukas Suter * Copyright (C) 2002-2008 Andreas Steffen * * 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. * * $Id: ac.h 3300 2007-10-12 21:53:18Z andreas $ */ /** * @defgroup ac ac * @{ @ingroup certificates */ #ifndef AC_H_ #define AC_H_ #include #include typedef struct ac_t ac_t; /** * X.509 attribute certificate interface. * * This interface adds additional methods to the certificate_t type to * allow further operations on these certificates. */ struct ac_t { /** * Implements the certificate_t interface */ certificate_t certificate; /** * Get the attribute certificate's serial number. * * @return chunk pointing to serialNumber */ chunk_t (*get_serial)(ac_t *this); /** * Get the serial number of the holder certificate. * * @return chunk pointing to serialNumber */ chunk_t (*get_holderSerial)(ac_t *this); /** * Get the issuer of the holder certificate. * * @return holderIssuer as identification_t* */ identification_t* (*get_holderIssuer)(ac_t *this); /** * Get the thauthorityKeyIdentifier. * * @return authKeyIdentifier as identification_t* */ identification_t* (*get_authKeyIdentifier)(ac_t *this); /** * @brief Checks if two attribute certificates belong to the same holder * * @param this calling attribute certificate * @param that other attribute certificate * @return TRUE if same holder */ bool (*equals_holder) (ac_t *this, ac_t *other); }; #endif /** AC_H_ @}*/