2013-05-01 14:52:55 +02:00
|
|
|
#include "capwap.h"
|
|
|
|
#include "capwap_element.h"
|
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
|
|
|
|
0
|
|
|
|
0 1 2 3 4 5 6 7
|
|
|
|
+-+-+-+-+-+-+-+-+
|
|
|
|
| Name ...
|
|
|
|
+-+-+-+-+-+-+-+-+
|
|
|
|
|
|
|
|
Type: 45 for WTP Name
|
2013-05-27 21:33:23 +02:00
|
|
|
|
2013-05-01 14:52:55 +02:00
|
|
|
Length: >= 1
|
|
|
|
|
|
|
|
********************************************************************/
|
|
|
|
|
|
|
|
/* */
|
2013-05-27 21:33:23 +02:00
|
|
|
static void capwap_wtpname_element_create(void* data, capwap_message_elements_handle handle, struct capwap_write_message_elements_ops* func) {
|
2013-06-09 17:41:52 +02:00
|
|
|
int length;
|
2013-05-27 21:33:23 +02:00
|
|
|
struct capwap_wtpname_element* element = (struct capwap_wtpname_element*)data;
|
2013-05-01 14:52:55 +02:00
|
|
|
|
2013-05-27 21:33:23 +02:00
|
|
|
ASSERT(data != NULL);
|
2013-05-01 14:52:55 +02:00
|
|
|
|
2013-06-09 17:41:52 +02:00
|
|
|
length = strlen((char*)element->name);
|
|
|
|
ASSERT(length > 0);
|
|
|
|
|
|
|
|
func->write_block(handle, element->name, length);
|
2013-05-01 14:52:55 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/* */
|
2013-05-27 21:33:23 +02:00
|
|
|
static void* capwap_wtpname_element_parsing(capwap_message_elements_handle handle, struct capwap_read_message_elements_ops* func) {
|
|
|
|
unsigned short length;
|
2013-05-01 14:52:55 +02:00
|
|
|
struct capwap_wtpname_element* data;
|
|
|
|
|
2013-05-27 21:33:23 +02:00
|
|
|
ASSERT(handle != NULL);
|
|
|
|
ASSERT(func != NULL);
|
|
|
|
|
|
|
|
length = func->read_ready(handle);
|
|
|
|
if ((length < 1) || (length > CAPWAP_WTPNAME_MAXLENGTH)) {
|
2016-03-30 14:47:57 +02:00
|
|
|
log_printf(LOG_DEBUG, "Invalid WTP Name element: underbuffer");
|
2013-05-01 14:52:55 +02:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2013-08-18 19:07:19 +02:00
|
|
|
/* Retrieve data */
|
2013-05-01 14:52:55 +02:00
|
|
|
data = (struct capwap_wtpname_element*)capwap_alloc(sizeof(struct capwap_wtpname_element));
|
2013-06-09 17:41:52 +02:00
|
|
|
data->name = (uint8_t*)capwap_alloc(length + 1);
|
2013-05-27 21:33:23 +02:00
|
|
|
func->read_block(handle, data->name, length);
|
2013-06-09 17:41:52 +02:00
|
|
|
data->name[length] = 0;
|
2013-05-27 21:33:23 +02:00
|
|
|
|
2013-05-01 14:52:55 +02:00
|
|
|
return data;
|
|
|
|
}
|
|
|
|
|
2013-10-01 16:39:27 +02:00
|
|
|
/* */
|
|
|
|
static void* capwap_wtpname_element_clone(void* data) {
|
|
|
|
struct capwap_wtpname_element* cloneelement;
|
|
|
|
|
|
|
|
ASSERT(data != NULL);
|
|
|
|
|
|
|
|
cloneelement = capwap_clone(data, sizeof(struct capwap_wtpname_element));
|
|
|
|
if (cloneelement->name) {
|
|
|
|
cloneelement->name = (uint8_t*)capwap_duplicate_string((char*)((struct capwap_wtpname_element*)data)->name);
|
|
|
|
}
|
|
|
|
|
|
|
|
return cloneelement;
|
|
|
|
}
|
|
|
|
|
2013-05-01 14:52:55 +02:00
|
|
|
/* */
|
2013-05-27 21:33:23 +02:00
|
|
|
static void capwap_wtpname_element_free(void* data) {
|
2013-06-09 17:41:52 +02:00
|
|
|
struct capwap_wtpname_element* element = (struct capwap_wtpname_element*)data;
|
|
|
|
|
2013-05-01 14:52:55 +02:00
|
|
|
ASSERT(data != NULL);
|
2013-06-09 17:41:52 +02:00
|
|
|
|
|
|
|
if (element->name) {
|
|
|
|
capwap_free(element->name);
|
|
|
|
}
|
|
|
|
|
2013-05-01 14:52:55 +02:00
|
|
|
capwap_free(data);
|
|
|
|
}
|
2013-05-27 21:33:23 +02:00
|
|
|
|
|
|
|
/* */
|
2016-03-07 18:07:46 +01:00
|
|
|
const struct capwap_message_elements_ops capwap_element_wtpname_ops = {
|
2016-03-07 18:08:35 +01:00
|
|
|
.category = CAPWAP_MESSAGE_ELEMENT_SINGLE,
|
2016-03-07 17:12:48 +01:00
|
|
|
.create = capwap_wtpname_element_create,
|
|
|
|
.parse = capwap_wtpname_element_parsing,
|
|
|
|
.clone = capwap_wtpname_element_clone,
|
|
|
|
.free = capwap_wtpname_element_free
|
2013-05-27 21:33:23 +02:00
|
|
|
};
|