New message handler format
FossilOrigin-Name: bb2a1847072e2bf5e381dfdf0c4465b064c3feaab0faf51f93a7f4b8d2bcd999
This commit is contained in:
@ -25,7 +25,6 @@
|
||||
|
||||
#include "mod_capwap.h"
|
||||
|
||||
|
||||
static struct cw_ElemHandler handlers[] = {
|
||||
|
||||
{
|
||||
@ -65,7 +64,7 @@ static struct cw_ElemHandler handlers[] = {
|
||||
4,128, /* min/max length */
|
||||
NULL, /* type */
|
||||
"wtp_descriptor", /* Key */
|
||||
capwap_in_wtp_descriptor /* get */
|
||||
capwap_in_wtp_descriptor /* get */
|
||||
}
|
||||
,
|
||||
{
|
||||
@ -73,11 +72,23 @@ static struct cw_ElemHandler handlers[] = {
|
||||
CAPWAP_ELEM_WTP_FRAME_TUNNEL_MODE, /* Element ID */
|
||||
0,0, /* Vendor / Proto */
|
||||
1,1, /* min/max length */
|
||||
CW_TYPE_BYTE, /* type */
|
||||
CW_TYPE_BYTE, /* type */
|
||||
"wtp_frame_tunnel_mode", /* Key */
|
||||
cw_in_generic /* get */
|
||||
cw_in_generic /* get */
|
||||
}
|
||||
,
|
||||
|
||||
{
|
||||
"Vendor Specific Payload", /* name */
|
||||
CAPWAP_ELEM_VENDOR_SPECIFIC_PAYLOAD, /* Element ID */
|
||||
0,0, /* Vendor / Proto */
|
||||
0,0, /* min/max length */
|
||||
NULL, /* type */
|
||||
"vendor_specific_payload", /* Key */
|
||||
cw_in_vendor_specific_payload /* get */
|
||||
}
|
||||
,
|
||||
|
||||
{0,0,0,0,0,0,0,0}
|
||||
|
||||
};
|
||||
@ -85,11 +96,12 @@ static struct cw_ElemHandler handlers[] = {
|
||||
|
||||
static int discovery_request_states[] = {CAPWAP_STATE_DISCOVERY,0};
|
||||
static struct cw_ElemDef discovery_request_elements[] ={
|
||||
{0,0,CAPWAP_ELEM_DISCOVERY_TYPE, 1, 0},
|
||||
{0,0,CAPWAP_ELEM_WTP_MAC_TYPE, 1, 0},
|
||||
{0,0,CAPWAP_ELEM_WTP_BOARD_DATA, 1, 0},
|
||||
{0,0,CAPWAP_ELEM_WTP_DESCRIPTOR, 1, 0},
|
||||
{0,0,CAPWAP_ELEM_WTP_FRAME_TUNNEL_MODE, 1, 0},
|
||||
{0,0,CAPWAP_ELEM_DISCOVERY_TYPE, 1, 0},
|
||||
{0,0,CAPWAP_ELEM_WTP_MAC_TYPE, 1, 0},
|
||||
{0,0,CAPWAP_ELEM_WTP_BOARD_DATA, 1, 0},
|
||||
{0,0,CAPWAP_ELEM_WTP_DESCRIPTOR, 1, 0},
|
||||
{0,0,CAPWAP_ELEM_WTP_FRAME_TUNNEL_MODE, 1, 0},
|
||||
{0,0,CAPWAP_ELEM_VENDOR_SPECIFIC_PAYLOAD, 0, 0},
|
||||
{0,0,0,0,0}
|
||||
|
||||
};
|
||||
|
@ -150,7 +150,7 @@ static cw_action_in_t actions_in[] = {
|
||||
{
|
||||
.capwap_state = CAPWAP_STATE_JOIN,
|
||||
.msg_id = CAPWAP_MSG_JOIN_RESPONSE,
|
||||
.elem_id = CW_ELEM_ECN_SUPPORT,
|
||||
.elem_id = CAPWAP_ELEM_ECN_SUPPORT,
|
||||
.item_id = CW_ITEM_ECN_SUPPORT,
|
||||
.start = cw_in_generic2,
|
||||
.min_len = 1,
|
||||
@ -589,7 +589,7 @@ static cw_action_out_t actions_out[] = {
|
||||
/* ECN Support - Join Request */
|
||||
{
|
||||
.msg_id = CAPWAP_MSG_JOIN_REQUEST,
|
||||
.elem_id = CW_ELEM_ECN_SUPPORT,
|
||||
.elem_id = CAPWAP_ELEM_ECN_SUPPORT,
|
||||
.item_id = CW_ITEM_ECN_SUPPORT,
|
||||
.out = cw_out_generic,
|
||||
.get = cw_out_get_config,
|
||||
|
@ -24,16 +24,22 @@
|
||||
#include "cw/dbg.h"
|
||||
#include "cw/cw.h"
|
||||
|
||||
#include "cw/kvstore.h"
|
||||
#include "cw/cw_types.h"
|
||||
#include "cw/keys.h"
|
||||
|
||||
/*
|
||||
static void readsubelems_wtp_board_data(mbag_t itemstore, uint8_t * msgelem,
|
||||
|
||||
static void readsubelems_wtp_board_data(mavl_t cfg, uint8_t * msgelem,
|
||||
int len)
|
||||
{
|
||||
int i = 0;
|
||||
uint32_t val;
|
||||
const char * key;
|
||||
|
||||
if (len<4)
|
||||
return;
|
||||
|
||||
int i = 0;
|
||||
uint32_t val;
|
||||
|
||||
do {
|
||||
val = ntohl(*((uint32_t *) (msgelem + i)));
|
||||
int subtype = (val >> 16) & 0xffff;
|
||||
@ -50,46 +56,66 @@ static void readsubelems_wtp_board_data(mbag_t itemstore, uint8_t * msgelem,
|
||||
subtype, sublen);
|
||||
|
||||
switch (subtype) {
|
||||
|
||||
|
||||
case CW_BOARDDATA_MODELNO:
|
||||
mbag_set_bstrn(itemstore,
|
||||
/* mbag_set_bstrn(itemstore,
|
||||
CW_ITEM_WTP_BOARD_MODELNO,
|
||||
msgelem + i, sublen);
|
||||
*/
|
||||
key = "model_no";
|
||||
break;
|
||||
case CW_BOARDDATA_SERIALNO:
|
||||
mbag_set_bstrn(itemstore,
|
||||
/* mbag_set_bstrn(itemstore,
|
||||
CW_ITEM_WTP_BOARD_SERIALNO,
|
||||
msgelem + i, sublen);
|
||||
|
||||
*/
|
||||
key = "serial_no";
|
||||
break;
|
||||
case CW_BOARDDATA_MACADDRESS:
|
||||
mbag_set_bstrn(itemstore,
|
||||
/* mbag_set_bstrn(itemstore,
|
||||
CW_ITEM_WTP_BOARD_MACADDRESS,
|
||||
msgelem + i, sublen);
|
||||
|
||||
*/
|
||||
key = "mac_address";
|
||||
break;
|
||||
case CW_BOARDDATA_BOARDID:
|
||||
mbag_set_bstrn(itemstore, CW_ITEM_WTP_BOARD_ID,
|
||||
/* mbag_set_bstrn(itemstore, CW_ITEM_WTP_BOARD_ID,
|
||||
msgelem + i, sublen);
|
||||
*/
|
||||
key = "board_id";
|
||||
break;
|
||||
case CW_BOARDDATA_REVISION:
|
||||
mbag_set_bstrn(itemstore,
|
||||
/* mbag_set_bstrn(itemstore,
|
||||
CW_ITEM_WTP_BOARD_REVISION,
|
||||
msgelem + i, sublen);
|
||||
*/
|
||||
key = "revision";
|
||||
default:
|
||||
key = NULL;
|
||||
break;
|
||||
}
|
||||
if (key){
|
||||
char add_key[256];
|
||||
sprintf(add_key,"wtp_board_data/%s",key);
|
||||
cw_kvstore_add(cfg,add_key,CW_TYPE_BSTR16,msgelem+i,sublen);
|
||||
|
||||
}
|
||||
|
||||
|
||||
i += sublen;
|
||||
|
||||
} while (i < len);
|
||||
}
|
||||
|
||||
*/
|
||||
|
||||
|
||||
/**
|
||||
* Parse a WTP Board Data messag element and put results to itemstore.
|
||||
*/
|
||||
int capwap_in_wtp_board_data(struct conn *conn, struct cw_ElemHandler *eh, uint8_t * data,
|
||||
int len, struct sockaddr *from)
|
||||
int capwap_in_wtp_board_data(struct cw_ElemHandler *eh, struct cw_ElemHandlerParams *params,
|
||||
uint8_t * data, int len)
|
||||
{
|
||||
|
||||
/*
|
||||
@ -101,18 +127,22 @@ int capwap_in_wtp_board_data(struct conn *conn, struct cw_ElemHandler *eh, uint8
|
||||
}
|
||||
*/
|
||||
|
||||
char vendor_key[64];
|
||||
|
||||
printf("Have to read WTP Board Data\n");
|
||||
sprintf(vendor_key,"%s/%s",eh->key,"vendor");
|
||||
char vendor_key[128];
|
||||
mavl_t cfg = params->conn->remote_cfg;
|
||||
|
||||
|
||||
sprintf(vendor_key,"%s/%s",eh->key,CW_KEY_VENDOR);
|
||||
|
||||
cw_kvstore_add(cfg,vendor_key,CW_TYPE_DWORD,data,len);
|
||||
|
||||
/*
|
||||
mbag_t itemstore = conn->incomming;
|
||||
mbag_set_dword(itemstore, CW_ITEM_WTP_BOARD_VENDOR, cw_get_dword(data));
|
||||
*/
|
||||
|
||||
/* readsubelems_wtp_board_data(itemstore, data + 4, len - 4);
|
||||
*/
|
||||
readsubelems_wtp_board_data(cfg, data + 4, len - 4);
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -22,15 +22,15 @@
|
||||
|
||||
#include "mod_capwap.h"
|
||||
|
||||
int capwap_in_wtp_descriptor(struct conn *conn, struct cw_ElemHandler *eh, uint8_t * data,
|
||||
int len, struct sockaddr *from)
|
||||
int capwap_in_wtp_descriptor(struct cw_ElemHandler *eh, struct cw_ElemHandlerParams *params, uint8_t * data,
|
||||
int len)
|
||||
{
|
||||
int rc;
|
||||
printf("WTP Descriptor reader\n");
|
||||
//printf("WTP Descriptor reader\n");
|
||||
/*
|
||||
// mbag_t mbag = conn->incomming;
|
||||
*/
|
||||
rc =cw_read_wtp_descriptor(conn->remote_cfg, conn, eh, data, len, NULL);
|
||||
rc =cw_read_wtp_descriptor(params->conn->remote_cfg, params->conn, eh, data, len, NULL);
|
||||
|
||||
return rc;
|
||||
}
|
||||
|
@ -8,12 +8,17 @@ struct cw_Mod *mod_capwap_wtp();
|
||||
#include "cw/conn.h"
|
||||
|
||||
|
||||
extern int capwap_in_wtp_descriptor(struct conn *conn, struct cw_ElemHandler *eh,
|
||||
uint8_t * data, int len, struct sockaddr *from);
|
||||
|
||||
/*extern int capwap_in_wtp_descriptor(struct conn *conn, struct cw_ElemHandler *eh,
|
||||
uint8_t * data, int len, struct sockaddr *from);*/
|
||||
|
||||
int capwap_in_wtp_descriptor(struct cw_ElemHandler *eh, struct cw_ElemHandlerParams *params, uint8_t * data,
|
||||
int len);
|
||||
/*
|
||||
extern int capwap_in_wtp_board_data(struct conn *conn, struct cw_ElemHandler *a,
|
||||
uint8_t * data, int len, struct sockaddr *from);
|
||||
*/
|
||||
int capwap_in_wtp_board_data(struct cw_ElemHandler *eh, struct cw_ElemHandlerParams *params,
|
||||
uint8_t * data, int len);
|
||||
|
||||
/*
|
||||
extern int capwap_out_wtp_descriptor(struct conn *conn, struct cw_action_out *a,
|
||||
|
@ -6,8 +6,13 @@
|
||||
|
||||
extern int cisco_out_ap_timesync(struct conn *conn, struct cw_action_out *a,
|
||||
uint8_t * dst);
|
||||
/*
|
||||
extern int cisco_in_wtp_descriptor(struct conn *conn, struct cw_action_in *a,
|
||||
uint8_t * data, int len, struct sockaddr *from);
|
||||
uint8_t * data, int len, struct sockaddr *from);*/
|
||||
|
||||
int cisco_in_wtp_descriptor(struct cw_ElemHandler *eh, struct cw_ElemHandlerParams * params, uint8_t * data,
|
||||
int len);
|
||||
|
||||
extern int cisco_out_ac_descriptor(struct conn *conn, struct cw_action_out *a,
|
||||
uint8_t * dst);
|
||||
extern int cisco_out_wtp_descriptor(struct conn *conn, struct cw_action_out *a,
|
||||
|
@ -38,11 +38,13 @@
|
||||
|
||||
#include "cisco_items.h"
|
||||
|
||||
|
||||
#include "include/cipwap_items.h"
|
||||
|
||||
#include "cw/message_set.h"
|
||||
#include "cw/cw_types.h"
|
||||
|
||||
|
||||
static struct cw_ElemHandler handlers[] = {
|
||||
{
|
||||
"WTP Descriptor (Draft 7)", /* name */
|
||||
@ -51,7 +53,28 @@ static struct cw_ElemHandler handlers[] = {
|
||||
4,128, /* min/max length */
|
||||
NULL, /* type */
|
||||
"wtp_descriptor", /* Key */
|
||||
cisco_in_wtp_descriptor /* get */
|
||||
cisco_in_wtp_descriptor /* get */
|
||||
}
|
||||
,
|
||||
{
|
||||
"RAD Name -> CAPWAP WTP Name", /* name */
|
||||
CW_CISCO_RAD_NAME, /* Element ID */
|
||||
CW_VENDOR_ID_CISCO,0, /* Vendor / Proto */
|
||||
1,512, /* min/max length */
|
||||
CW_TYPE_BSTR16, /* type */
|
||||
"wtp_name", /* Key */
|
||||
cw_in_generic /* handler */
|
||||
}
|
||||
|
||||
,
|
||||
{
|
||||
"Board Data Options", /* name */
|
||||
CW_CISCO_BOARD_DATA_OPTIONS, /* Element ID */
|
||||
CW_VENDOR_ID_CISCO,0, /* Vendor / Proto */
|
||||
2,2, /* min/max length */
|
||||
CW_TYPE_DWORD, /* type */
|
||||
"cisco_board_data_options", /* Key */
|
||||
cw_in_generic /* handler */
|
||||
}
|
||||
,
|
||||
{0,0,0,0,0,0,0,0}
|
||||
@ -61,7 +84,8 @@ static struct cw_ElemHandler handlers[] = {
|
||||
|
||||
static int discovery_request_states[] = {CAPWAP_STATE_DISCOVERY,0};
|
||||
static struct cw_ElemDef discovery_request_elements[] ={
|
||||
{0,0,CAPWAP_ELEM_WTP_DESCRIPTOR, 1, 0},
|
||||
{0,0, CAPWAP_ELEM_WTP_DESCRIPTOR, 1, 0},
|
||||
{0,CW_VENDOR_ID_CISCO, CW_CISCO_RAD_NAME, 1, 0},
|
||||
{0,0,0,00}
|
||||
|
||||
};
|
||||
@ -213,7 +237,7 @@ static cw_action_in_t actions_in[] = {
|
||||
* about ECN support, so make it non-mandatory */
|
||||
.capwap_state = CAPWAP_STATE_JOIN,
|
||||
.msg_id = CAPWAP_MSG_JOIN_REQUEST,
|
||||
.elem_id = CW_ELEM_ECN_SUPPORT,
|
||||
.elem_id = CAPWAP_ELEM_ECN_SUPPORT,
|
||||
.item_id = CW_ITEM_ECN_SUPPORT,
|
||||
.start = cw_in_generic,
|
||||
.mand = 0,
|
||||
@ -418,7 +442,7 @@ static cw_action_out_t actions_out[]={
|
||||
/* ECN Support - Join Response */
|
||||
{
|
||||
.msg_id = CAPWAP_MSG_JOIN_RESPONSE,
|
||||
.elem_id = CW_ELEM_ECN_SUPPORT,
|
||||
.elem_id = CAPWAP_ELEM_ECN_SUPPORT,
|
||||
.item_id = CW_ITEM_ECN_SUPPORT
|
||||
}
|
||||
,
|
||||
|
@ -68,7 +68,7 @@ static cw_action_in_t actions_in[] = {
|
||||
/* Make ECN Support non-mand */
|
||||
.capwap_state = CAPWAP_STATE_JOIN,
|
||||
.msg_id = CAPWAP_MSG_JOIN_RESPONSE,
|
||||
.elem_id = CW_ELEM_ECN_SUPPORT,
|
||||
.elem_id = CAPWAP_ELEM_ECN_SUPPORT,
|
||||
.item_id = CW_ITEM_ECN_SUPPORT,
|
||||
.start = cw_in_generic,
|
||||
.mand = 0,
|
||||
@ -345,7 +345,7 @@ static cw_action_out_t actions_out[]={
|
||||
/* Cisco doesn't know ECN support, so we
|
||||
define no output method */
|
||||
.msg_id = CAPWAP_MSG_JOIN_REQUEST,
|
||||
.elem_id = CW_ELEM_ECN_SUPPORT,
|
||||
.elem_id = CAPWAP_ELEM_ECN_SUPPORT,
|
||||
.item_id = CW_ITEM_ECN_SUPPORT,
|
||||
.mand = 0
|
||||
}
|
||||
|
@ -22,8 +22,8 @@
|
||||
#include "cw/capwap_items.h"
|
||||
|
||||
|
||||
int cisco_in_wtp_descriptor(struct conn *conn, struct cw_ElemHandler *eh, uint8_t * data,
|
||||
int len, struct sockaddr *from)
|
||||
int cisco_in_wtp_descriptor(struct cw_ElemHandler *eh, struct cw_ElemHandlerParams * params, uint8_t * data,
|
||||
int len)
|
||||
{
|
||||
|
||||
static struct cw_DescriptorSubelemDef allowed[] = {
|
||||
@ -35,7 +35,7 @@ int cisco_in_wtp_descriptor(struct conn *conn, struct cw_ElemHandler *eh, uint8_
|
||||
};
|
||||
|
||||
|
||||
return cw_read_wtp_descriptor_7(conn->remote_cfg, conn, eh, data, len, allowed);
|
||||
return cw_read_wtp_descriptor_7(params->conn->remote_cfg, params->conn, eh, data, len, allowed);
|
||||
}
|
||||
|
||||
|
||||
|
@ -135,7 +135,7 @@ static cw_action_in_t actions_in[] = {
|
||||
* about ECN support, so make it non-mandatory */
|
||||
.capwap_state = CAPWAP_STATE_JOIN,
|
||||
.msg_id = CW_MSG_JOIN_REQUEST,
|
||||
.elem_id = CW_ELEM_ECN_SUPPORT,
|
||||
.elem_id = CAPWAP_ELEM_ECN_SUPPORT,
|
||||
.item_id = CW_ITEM_ECN_SUPPORT,
|
||||
.start = cw_in_generic2,
|
||||
.mand = 0,
|
||||
@ -216,7 +216,7 @@ static cw_action_out_t actions_out[]={
|
||||
/* ECN Support - Join Response */
|
||||
{
|
||||
.msg_id = CW_MSG_JOIN_RESPONSE,
|
||||
.elem_id = CW_ELEM_ECN_SUPPORT,
|
||||
.elem_id = CAPWAP_ELEM_ECN_SUPPORT,
|
||||
.item_id = CW_ITEM_ECN_SUPPORT
|
||||
}
|
||||
,
|
||||
|
@ -62,7 +62,7 @@ static cw_action_in_t actions_in[] = {
|
||||
/* Make ECN Support non-mand */
|
||||
.capwap_state = CAPWAP_STATE_JOIN,
|
||||
.msg_id = CW_MSG_JOIN_RESPONSE,
|
||||
.elem_id = CW_ELEM_ECN_SUPPORT,
|
||||
.elem_id = CAPWAP_ELEM_ECN_SUPPORT,
|
||||
.item_id = CW_ITEM_ECN_SUPPORT,
|
||||
.start = cw_in_generic2,
|
||||
.mand = 0,
|
||||
@ -222,7 +222,7 @@ static cw_action_out_t actions_out[]={
|
||||
/* Cisco doesn't know ECN support, so we
|
||||
define no output method */
|
||||
.msg_id = CW_MSG_JOIN_REQUEST,
|
||||
.elem_id = CW_ELEM_ECN_SUPPORT,
|
||||
.elem_id = CAPWAP_ELEM_ECN_SUPPORT,
|
||||
.item_id = CW_ITEM_ECN_SUPPORT,
|
||||
.mand = 0
|
||||
}
|
||||
|
Reference in New Issue
Block a user