/* * Copyright (C) 2005-2006 Martin Willi * Copyright (C) 2005 Jan Hutter * 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 configuration_attribute configuration_attribute * @{ @ingroup payloads */ #ifndef CONFIGURATION_ATTRIBUTE_H_ #define CONFIGURATION_ATTRIBUTE_H_ typedef enum configuration_attribute_type_t configuration_attribute_type_t; typedef struct configuration_attribute_t configuration_attribute_t; #include #include /** * Configuration attribute header length in bytes. */ #define CONFIGURATION_ATTRIBUTE_HEADER_LENGTH 4 /** * Type of the attribute, as in IKEv2 RFC 3.15.1. */ enum configuration_attribute_type_t { INTERNAL_IP4_ADDRESS = 1, INTERNAL_IP4_NETMASK = 2, INTERNAL_IP4_DNS = 3, INTERNAL_IP4_NBNS = 4, INTERNAL_ADDRESS_EXPIRY = 5, INTERNAL_IP4_DHCP = 6, APPLICATION_VERSION = 7, INTERNAL_IP6_ADDRESS = 8, INTERNAL_IP6_DNS = 10, INTERNAL_IP6_NBNS = 11, INTERNAL_IP6_DHCP = 12, INTERNAL_IP4_SUBNET = 13, SUPPORTED_ATTRIBUTES = 14, INTERNAL_IP6_SUBNET = 15, /* proprietary Microsoft attributes */ INTERNAL_IP4_SERVER = 23456, INTERNAL_IP6_SERVER = 23457 }; /** * enum names for configuration_attribute_type_t. */ extern enum_name_t *configuration_attribute_type_names; /** * Class representing an IKEv2-CONFIGURATION Attribute. * * The CONFIGURATION ATTRIBUTE format is described in RFC section 3.15.1. */ struct configuration_attribute_t { /** * The payload_t interface. */ payload_t payload_interface; /** * Returns the currently set value of the attribute. * * @warning Returned data are not copied. * * @return chunk_t pointing to the value */ chunk_t (*get_value) (configuration_attribute_t *this); /** * Sets the value of the attribute. * * Value is getting copied. * * @param value chunk_t pointing to the value to set */ void (*set_value) (configuration_attribute_t *this, chunk_t value); /** * Sets the type of the attribute. * * @param type type to set (most significant bit is set to zero) */ void (*set_type) (configuration_attribute_t *this, u_int16_t type); /** * get the type of the attribute. * * @return type of the value */ u_int16_t (*get_type) (configuration_attribute_t *this); /** * get the length of an attribute. * * @return type of the value */ u_int16_t (*get_length) (configuration_attribute_t *this); /** * Destroys an configuration_attribute_t object. */ void (*destroy) (configuration_attribute_t *this); }; /** * Creates an empty configuration_attribute_t object. * * @return created configuration_attribute_t object */ configuration_attribute_t *configuration_attribute_create(void); #endif /** CONFIGURATION_ATTRIBUTE_H_ @}*/