Work in progress
FossilOrigin-Name: 155605fd55cbb193d4f5ac8c704930c050a11cda541f1a5cdb93c57a8c51534f
This commit is contained in:
@ -40,7 +40,7 @@ OBJDIR := ../../../obj/mod_cisco/$(ARCH)
|
||||
SNAME := $(LIBARCHDIR)/libmod_cisco.a
|
||||
DNAME := $(LIBARCHDIR)/mod_cisco.so
|
||||
MODNAME := $(LIBDIR)/mod_cisco.so
|
||||
SLIBS := -lcw -lmod_cipwap -lmod_capwap -lconfuse
|
||||
SLIBS := -lcw -lmod_capwap -lconfuse
|
||||
|
||||
|
||||
include ../Mod.mak
|
||||
|
@ -33,7 +33,7 @@
|
||||
|
||||
#include "include/capwap_actions.h"
|
||||
|
||||
#include "mod_cisco.h"
|
||||
|
||||
#include "cisco.h"
|
||||
|
||||
#include "cisco_items.h"
|
||||
@ -134,7 +134,7 @@ static cw_action_in_t actions_in[] = {
|
||||
{
|
||||
.capwap_state = CAPWAP_STATE_DISCOVERY,
|
||||
.msg_id = CAPWAP_MSG_DISCOVERY_REQUEST,
|
||||
.end = cw_in_check_disc_req
|
||||
/* .end = cw_in_check_disc_req*/
|
||||
}
|
||||
,
|
||||
|
||||
@ -262,7 +262,7 @@ static cw_action_in_t actions_in[] = {
|
||||
/* We have to deal with zero-length strings */
|
||||
.capwap_state = CW_STATE_CONFIGURE,
|
||||
.msg_id = CAPWAP_MSG_CONFIGURATION_STATUS_REQUEST,
|
||||
.elem_id = CW_ELEM_AC_NAME,
|
||||
.elem_id = CAPWAP_ELEM_AC_NAME,
|
||||
.item_id = CW_ITEM_AC_NAME,
|
||||
.start = cw_in_generic,
|
||||
.min_len = 0,
|
||||
@ -507,7 +507,7 @@ static cw_action_out_t actions_out[]={
|
||||
.vendor_id = CW_VENDOR_ID_CISCO,
|
||||
.elem_id = CW_CISCO_RAD_NAME,
|
||||
.out=cw_out_generic,
|
||||
.get = cw_out_get_outgoing
|
||||
/*.get = cw_out_get_outgoing*/
|
||||
}
|
||||
,
|
||||
|
||||
@ -528,7 +528,7 @@ static cw_action_out_t actions_out[]={
|
||||
.elem_id = CW_CISCO_AP_LED_STATE_CONFIG,
|
||||
.item_id = CISCO_ITEM_AP_LED_STATE_CONFIG,
|
||||
.out = cw_out_generic,
|
||||
.get = cw_out_get_outgoing,
|
||||
/*.get = cw_out_get_outgoing,*/
|
||||
.mand = 0
|
||||
}
|
||||
,
|
||||
@ -541,7 +541,7 @@ static cw_action_out_t actions_out[]={
|
||||
.elem_id = CW_CISCO_AP_LED_FLASH_CONFIG,
|
||||
.item_id = CISCO_ITEM_AP_LED_FLASH_CONFIG,
|
||||
.out = cw_out_generic,
|
||||
.get = cw_out_get_outgoing,
|
||||
/*.get = cw_out_get_outgoing,*/
|
||||
.mand = 0
|
||||
}
|
||||
,
|
||||
@ -553,7 +553,7 @@ static cw_action_out_t actions_out[]={
|
||||
.elem_id = CW_CISCO_AP_MODE_AND_TYPE,
|
||||
.item_id = CISCO_ITEM_AP_MODE_AND_TYPE,
|
||||
.out = cw_out_generic,
|
||||
.get = cw_out_get_outgoing,
|
||||
/*.get = cw_out_get_outgoing,*/
|
||||
}
|
||||
,
|
||||
|
||||
@ -601,7 +601,7 @@ static cw_action_in_t actions80211_in[] = {
|
||||
.msg_id = CAPWAP_MSG_DISCOVERY_REQUEST,
|
||||
.elem_id = CW_ELEM80211_WTP_RADIO_INFORMATION,
|
||||
.item_id = CW_RADIOITEM80211_WTP_RADIO_INFORMATION,
|
||||
.start = cw_in_radio_generic,
|
||||
/*.start = cw_in_radio_generic, */
|
||||
.mand = 0,
|
||||
.min_len = 5,
|
||||
.max_len = 5
|
||||
@ -618,7 +618,7 @@ static cw_action_in_t actions80211_in[] = {
|
||||
.msg_id = CAPWAP_MSG_CONFIGURATION_STATUS_REQUEST,
|
||||
.elem_id = CW_CISCO_SUPPORTED_RATES,
|
||||
.item_id = CW_RADIOITEM80211_SUPPORTED_RATES,
|
||||
.start = cw_in_radio_generic,
|
||||
/*.start = cw_in_radio_generic, */
|
||||
.mand = 0,
|
||||
.min_len = 5,
|
||||
.max_len = 5
|
||||
|
@ -31,7 +31,7 @@
|
||||
|
||||
#include "include/cipwap_items.h"
|
||||
|
||||
#include "mod_cisco.h"
|
||||
/*#include "mod_cisco.h"*/
|
||||
|
||||
#include "cisco.h"
|
||||
#include "cisco80211.h"
|
||||
@ -284,7 +284,7 @@ static cw_action_out_t actions_out[]={
|
||||
.elem_id = CW_CISCO_RAD_NAME,
|
||||
.item_id = CW_ITEM_WTP_NAME,
|
||||
.out = cw_out_generic,
|
||||
.get = cw_out_get_config,
|
||||
/* .get = cw_out_get_config,*/
|
||||
.mand = 1
|
||||
}
|
||||
,
|
||||
@ -321,7 +321,7 @@ static cw_action_out_t actions_out[]={
|
||||
.elem_id = CW_CISCO_AP_GROUP_NAME,
|
||||
.item_id = CIPWAP_ITEM_WTP_GROUP_NAME,
|
||||
.out = cw_out_generic,
|
||||
.get = cw_out_get_config,
|
||||
/*.get = cw_out_get_config,*/
|
||||
.mand = 1
|
||||
}
|
||||
,
|
||||
@ -333,7 +333,7 @@ static cw_action_out_t actions_out[]={
|
||||
.elem_id = CW_CISCO_BOARD_DATA_OPTIONS,
|
||||
.item_id = CW_ITEM_CISCO_BOARD_DATA_OPTIONS,
|
||||
.out = cisco_out_board_data_options,
|
||||
.get = cw_out_get_config,
|
||||
/* .get = cw_out_get_config,*/
|
||||
.mand = 1
|
||||
}
|
||||
,
|
||||
@ -359,7 +359,7 @@ static cw_action_out_t actions_out[]={
|
||||
.elem_id = CW_CISCO_AP_MODE_AND_TYPE,
|
||||
.item_id = CISCO_ITEM_AP_MODE_AND_TYPE,
|
||||
.out = cw_out_generic,
|
||||
.get = cw_out_get_config,
|
||||
/* .get = cw_out_get_config,*/
|
||||
.mand = 1
|
||||
}
|
||||
,
|
||||
@ -493,7 +493,7 @@ static cw_action_out_t actions80211_out[]={
|
||||
.elem_id = CW_ELEM80211_WTP_RADIO_INFORMATION,
|
||||
.item_id = CW_RADIOITEM80211_WTP_RADIO_INFORMATION,
|
||||
.out = cisco_out_80211_wtp_radio_cfg,
|
||||
.get = cw_out_get_config,
|
||||
/*.get = cw_out_get_config,*/
|
||||
.mand = 1
|
||||
}
|
||||
,
|
||||
|
@ -1,28 +1,20 @@
|
||||
#include "cw/log.h"
|
||||
#include "cw/conn.h"
|
||||
#include "cw/capwap_items.h"
|
||||
#include "cw/cw.h"
|
||||
|
||||
|
||||
#include "cisco.h"
|
||||
#include "cw/ktv.h"
|
||||
#include "cw/keys.h"
|
||||
#include "cw/dbg.h"
|
||||
|
||||
|
||||
|
||||
int cisco_out_wtp_descriptor(struct cw_ElemHandler * eh, struct cw_ElemHandlerParams * params
|
||||
, uint8_t * dst)
|
||||
int cisco_out_wtp_descriptor(struct cw_ElemHandler * eh,
|
||||
struct cw_ElemHandlerParams * params, uint8_t * dst)
|
||||
{
|
||||
char key[256];
|
||||
char key[CW_KTV_MAX_KEY_LEN];
|
||||
int len;
|
||||
/* // XXX Dummy WTP Descriptor Header */
|
||||
uint8_t *d;
|
||||
cw_KTV_t * val;
|
||||
|
||||
d = dst+4;
|
||||
|
||||
/*cw_ktv_init_byte(&val,8);*/
|
||||
|
||||
sprintf(key,"%s/%s",eh->key,CW_SKEY_MAX_RADIOS);
|
||||
val = cw_ktv_get(params->conn->local_cfg,key, CW_TYPE_BYTE);
|
||||
if (val != NULL)
|
||||
@ -32,7 +24,7 @@ int cisco_out_wtp_descriptor(struct cw_ElemHandler * eh, struct cw_ElemHandlerPa
|
||||
d+=cw_put_byte(d,0);
|
||||
}
|
||||
|
||||
sprintf(key,"%s/%s",eh->key,CW_SKEY_RADIOS_IN_USE);
|
||||
sprintf(key,"%s/%s",eh->key,CW_SKEY_RADIOS_IN_USE);
|
||||
val = cw_ktv_get(params->conn->local_cfg,key, CW_TYPE_BYTE);
|
||||
if (val != NULL){
|
||||
d+=val->type->put(val,d);
|
||||
@ -41,28 +33,8 @@ int cisco_out_wtp_descriptor(struct cw_ElemHandler * eh, struct cw_ElemHandlerPa
|
||||
d+=cw_put_byte(d,0); /*radios in use*/
|
||||
}
|
||||
|
||||
|
||||
/*len = handler->type->put(elem,dst+start);*/
|
||||
|
||||
|
||||
|
||||
d+=cw_put_encryption_capabilities_7(d,1);
|
||||
|
||||
|
||||
/* d += cw_put_dword(d, bstrv_get_vendor_id(v));
|
||||
d += cw_put_dword(d, (subelem_id << 16) | bstrv_len(v));
|
||||
d += cw_put_data(d, bstrv_data(v), bstrv_len(v));
|
||||
*/
|
||||
|
||||
/* sprintf(key,"%s/%s/%s",eh->key,CW_SKEY_HARDWARE,CW_SKEY_VENDOR);
|
||||
vendor = cw_ktv_get(params->conn->local_cfg,key,CW_TYPE_DWORD);
|
||||
sprintf(key,"%s/%s/%s",eh->key,CW_SKEY_HARDWARE,CW_SKEY_VENDOR);
|
||||
version = cw_ktv_get(params->conn->local_cfg,key,CW_TYPE_BSTR16);
|
||||
|
||||
if (vendor == NULL){
|
||||
cw_log(LOG_ERR, "Can't send %s, not found.", key);
|
||||
}
|
||||
*/
|
||||
|
||||
/* hardware version sub element */
|
||||
sprintf(key,"%s/%s",eh->key,CW_SKEY_HARDWARE);
|
||||
@ -74,43 +46,11 @@ int cisco_out_wtp_descriptor(struct cw_ElemHandler * eh, struct cw_ElemHandlerPa
|
||||
d+=cw_write_descriptor_subelem (d, params->conn->local_cfg,
|
||||
CW_SUBELEM_WTP_SOFTWARE_VERSION, key);
|
||||
|
||||
/* bootloader version sub element */
|
||||
/* bootloader version sub element */
|
||||
sprintf(key,"%s/%s",eh->key,CW_SKEY_BOOTLOADER);
|
||||
d+=cw_write_descriptor_subelem (d, params->conn->local_cfg,
|
||||
CW_SUBELEM_WTP_BOOTLOADER_VERSION, key);
|
||||
|
||||
|
||||
|
||||
|
||||
/* mbag_item_t * i;
|
||||
i = mbag_get(mbag,CW_ITEM_WTP_HARDWARE_VERSION);
|
||||
*/
|
||||
/* if ( i ) {
|
||||
d += cw_put_version(d,CW_SUBELEM_WTP_HARDWARE_VERSION,i->u2.data);
|
||||
}
|
||||
else {
|
||||
cw_log(LOG_ERR, "Can't send Hardware Version in WTP Descriptor, not set.");
|
||||
}
|
||||
*/
|
||||
|
||||
/*i = mbag_get(mbag,CW_ITEM_WTP_SOFTWARE_VERSION);*/
|
||||
/*
|
||||
if ( i ) {
|
||||
d += cw_put_version(d,CW_SUBELEM_WTP_SOFTWARE_VERSION,i->u2.data);
|
||||
}
|
||||
else {
|
||||
cw_log(LOG_ERR, "Can't send Software Version in WTP descriptor, not set.");
|
||||
}
|
||||
|
||||
i = mbag_get(mbag,CW_ITEM_WTP_BOOTLOADER_VERSION);
|
||||
if ( i ) {
|
||||
d += cw_put_version(d,CW_SUBELEM_WTP_BOOTLOADER_VERSION,i->u2.data);
|
||||
}
|
||||
else {
|
||||
cw_log(LOG_ERR, "Can't send Bootloader Version in WTP descriptor, not set.");
|
||||
}
|
||||
*/
|
||||
|
||||
len = d-dst-4;
|
||||
return len + cw_put_elem_hdr(dst,eh->id,len);
|
||||
}
|
||||
}
|
||||
|
@ -1,9 +0,0 @@
|
||||
#ifndef __MOD_CISCO_H
|
||||
#define __MOD_CISCO_H
|
||||
|
||||
struct cw_Mod * mod_cisco_ac();
|
||||
struct cw_Mod * mod_cisco_wtp();
|
||||
|
||||
struct cw_MsgSet * cisco_register_msg_set(struct cw_MsgSet * set, int mode);
|
||||
|
||||
#endif
|
@ -7,7 +7,7 @@
|
||||
|
||||
#include "cw/action.h"
|
||||
|
||||
#include "mod_cisco.h"
|
||||
/*#include "mod_cisco.h"*/
|
||||
#include "../modload.h"
|
||||
|
||||
#include "cw/vendors.h"
|
||||
|
Reference in New Issue
Block a user