Annotation of embedaddon/strongswan/src/libcharon/encoding/payloads/id_payload.h, revision 1.1
1.1 ! misho 1: /*
! 2: * Copyright (C) 2007 Tobias Brunner
! 3: * Copyright (C) 2005-2006 Martin Willi
! 4: * Copyright (C) 2005 Jan Hutter
! 5: * HSR Hochschule fuer Technik Rapperswil
! 6: *
! 7: * This program is free software; you can redistribute it and/or modify it
! 8: * under the terms of the GNU General Public License as published by the
! 9: * Free Software Foundation; either version 2 of the License, or (at your
! 10: * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
! 11: *
! 12: * This program is distributed in the hope that it will be useful, but
! 13: * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
! 14: * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
! 15: * for more details.
! 16: */
! 17:
! 18: /**
! 19: * @defgroup id_payload id_payload
! 20: * @{ @ingroup payloads
! 21: */
! 22:
! 23: #ifndef ID_PAYLOAD_H_
! 24: #define ID_PAYLOAD_H_
! 25:
! 26: typedef struct id_payload_t id_payload_t;
! 27:
! 28: #include <library.h>
! 29: #include <utils/identification.h>
! 30: #include <encoding/payloads/payload.h>
! 31: #include <selectors/traffic_selector.h>
! 32:
! 33: /**
! 34: * Object representing an IKEv1 or an IKEv2 ID payload.
! 35: */
! 36: struct id_payload_t {
! 37:
! 38: /**
! 39: * The payload_t interface.
! 40: */
! 41: payload_t payload_interface;
! 42:
! 43: /**
! 44: * Creates an identification object of this id payload.
! 45: *
! 46: * @return identification_t object
! 47: */
! 48: identification_t *(*get_identification) (id_payload_t *this);
! 49:
! 50: /**
! 51: * Creates a traffic selector form a ID_ADDR_SUBNET/RANGE identity.
! 52: *
! 53: * @return traffic selector, NULL on failure
! 54: */
! 55: traffic_selector_t* (*get_ts)(id_payload_t *this);
! 56:
! 57: /**
! 58: * Get encoded payload without fixed payload header (used for IKEv1).
! 59: *
! 60: * @return encoded payload (gets allocated)
! 61: */
! 62: chunk_t (*get_encoded)(id_payload_t *this);
! 63:
! 64: /**
! 65: * Destroys an id_payload_t object.
! 66: */
! 67: void (*destroy) (id_payload_t *this);
! 68: };
! 69:
! 70: /**
! 71: * Creates an empty id_payload_t object.
! 72: *
! 73: * @param type one of PLV2_ID_INITIATOR, PLV2_ID_RESPONDER, PLV1_ID and PLV1_NAT_OA
! 74: * @return id_payload_t object
! 75: */
! 76: id_payload_t *id_payload_create(payload_type_t type);
! 77:
! 78: /**
! 79: * Creates an id_payload_t from an existing identification_t object.
! 80: *
! 81: * @param type one of PLV2_ID_INITIATOR, PLV2_ID_RESPONDER, PLV1_ID and PLV1_NAT_OA
! 82: * @param id identification_t object
! 83: * @return id_payload_t object
! 84: */
! 85: id_payload_t *id_payload_create_from_identification(payload_type_t type,
! 86: identification_t *id);
! 87:
! 88: /**
! 89: * Create an IKEv1 ID_ADDR_SUBNET/RANGE identity from a traffic selector.
! 90: *
! 91: * @param ts traffic selector
! 92: * @return PLV1_ID id_payload_t object.
! 93: */
! 94: id_payload_t *id_payload_create_from_ts(traffic_selector_t *ts);
! 95:
! 96: #endif /** ID_PAYLOAD_H_ @}*/
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>