freewtp/lib/element_returnedmessage.c

114 lines
3.9 KiB
C

#include "capwap.h"
#include "element.h"
/********************************************************************
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
| Reason | Length | Message Element...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
Type: 34 for Returned Message Element
Length: >= 6
********************************************************************/
/* */
static void capwap_returnedmessage_element_create(void* data, capwap_message_elements_handle handle, struct capwap_write_message_elements_ops* func) {
struct capwap_returnedmessage_element* element = (struct capwap_returnedmessage_element*)data;
ASSERT(data != NULL);
ASSERT(element->length >= 4);
ASSERT((element->reason == CAPWAP_RETURNED_MESSAGE_UNKNOWN_MESSAGE_ELEMENT) || (element->reason == CAPWAP_RETURNED_MESSAGE_UNSUPPORTED_MESSAGE_ELEMENT) ||
(element->reason == CAPWAP_RETURNED_MESSAGE_UNKNOWN_MESSAGE_ELEMENT_VALUE) || (element->reason == CAPWAP_RETURNED_MESSAGE_UNSUPPORTED_MESSAGE_ELEMENT_VALUE));
func->write_u8(handle, element->reason);
func->write_u8(handle, element->length);
func->write_block(handle, element->message, element->length);
}
/* */
static void* capwap_returnedmessage_element_clone(void* data) {
struct capwap_returnedmessage_element* cloneelement;
ASSERT(data != NULL);
cloneelement = capwap_clone(data, sizeof(struct capwap_returnedmessage_element));
if (cloneelement->length > 0) {
cloneelement->message = capwap_clone(((struct capwap_returnedmessage_element*)data)->message, cloneelement->length);
}
return cloneelement;
}
/* */
static void capwap_returnedmessage_element_free(void* data) {
struct capwap_returnedmessage_element* element = (struct capwap_returnedmessage_element*)data;
ASSERT(data != NULL);
if (element->message) {
capwap_free(element->message);
}
capwap_free(data);
}
/* */
static void* capwap_returnedmessage_element_parsing(capwap_message_elements_handle handle, struct capwap_read_message_elements_ops* func) {
unsigned short length;
struct capwap_returnedmessage_element* data;
ASSERT(handle != NULL);
ASSERT(func != NULL);
length = func->read_ready(handle);
if (length < 6) {
log_printf(LOG_DEBUG, "Invalid Returned Message element: underbuffer");
return NULL;
}
length -= 2;
if (length > CAPWAP_RETURNED_MESSAGE_MAX_LENGTH) {
log_printf(LOG_DEBUG, "Invalid Returned Message element: overbuffer");
return NULL;
}
/* */
data = (struct capwap_returnedmessage_element*)capwap_alloc(sizeof(struct capwap_returnedmessage_element));
memset(data, 0, sizeof(struct capwap_returnedmessage_element));
/* Retrieve data */
func->read_u8(handle, &data->reason);
func->read_u8(handle, &data->length);
if ((data->reason != CAPWAP_RETURNED_MESSAGE_UNKNOWN_MESSAGE_ELEMENT) &&
(data->reason != CAPWAP_RETURNED_MESSAGE_UNSUPPORTED_MESSAGE_ELEMENT) &&
(data->reason != CAPWAP_RETURNED_MESSAGE_UNKNOWN_MESSAGE_ELEMENT_VALUE) &&
(data->reason != CAPWAP_RETURNED_MESSAGE_UNSUPPORTED_MESSAGE_ELEMENT_VALUE)) {
capwap_returnedmessage_element_free((void*)data);
log_printf(LOG_DEBUG, "Invalid Returned Message element: invalid reason");
return NULL;
} else if (data->length != length) {
capwap_returnedmessage_element_free((void*)data);
log_printf(LOG_DEBUG, "Invalid Returned Message element: invalid length");
return NULL;
}
data->message = (uint8_t*)capwap_alloc(data->length);
func->read_block(handle, data->message, data->length);
return data;
}
/* */
const struct capwap_message_elements_ops capwap_element_returnedmessage_ops = {
.category = CAPWAP_MESSAGE_ELEMENT_ARRAY,
.create = capwap_returnedmessage_element_create,
.parse = capwap_returnedmessage_element_parsing,
.clone = capwap_returnedmessage_element_clone,
.free = capwap_returnedmessage_element_free
};