Return to unknown_payload.h CVS log | Up to [ELWIX - Embedded LightWeight unIX -] / embedaddon / strongswan / src / libcharon / encoding / payloads |
1.1 misho 1: /* 2: * Copyright (C) 2015 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 unknown_payload unknown_payload 20: * @{ @ingroup payloads 21: */ 22: 23: #ifndef UNKNOWN_PAYLOAD_H_ 24: #define UNKNOWN_PAYLOAD_H_ 25: 26: typedef struct unknown_payload_t unknown_payload_t; 27: 28: #include <library.h> 29: #include <encoding/payloads/payload.h> 30: 31: /** 32: * Payload which can't be processed further. 33: * 34: * When the parser finds an unknown payload, he builds an instance of 35: * this class. This allows further processing of this payload, such as 36: * a check for the critical bit in the header. 37: */ 38: struct unknown_payload_t { 39: 40: /** 41: * The payload_t interface. 42: */ 43: payload_t payload_interface; 44: 45: /** 46: * Get the original payload type as sent by the peer. 47: * 48: * @return type of the original payload 49: */ 50: payload_type_t (*get_type) (unknown_payload_t *this); 51: 52: /** 53: * Get the raw data of this payload, without 54: * the generic payload header. 55: * 56: * Returned data are NOT copied and must not be freed. 57: * 58: * @return data as chunk_t 59: */ 60: chunk_t (*get_data) (unknown_payload_t *this); 61: 62: /** 63: * Get the critical flag. 64: * 65: * @return TRUE if payload is critical, FALSE if not 66: */ 67: bool (*is_critical) (unknown_payload_t *this); 68: 69: /** 70: * Destroys an unknown_payload_t object. 71: */ 72: void (*destroy) (unknown_payload_t *this); 73: }; 74: 75: /** 76: * Creates an empty unknown_payload_t. 77: * 78: * @param type of the payload 79: * @return unknown_payload_t object 80: */ 81: unknown_payload_t *unknown_payload_create(payload_type_t type); 82: 83: /** 84: * Create an unknown payload with data. 85: * 86: * @param type type of payload to create 87: * @param critical TRUE to set critical bit 88: * @param data data to set for this payload, gets owned by payload 89: * @return payload object 90: */ 91: unknown_payload_t *unknown_payload_create_data(payload_type_t type, 92: bool critical, chunk_t data); 93: 94: #endif /** UNKNOWN_PAYLOAD_H_ @}*/