Some improvemts for the ktv file parser

FossilOrigin-Name: 51c8ae52f86aa8fc824e07fe22d35b7ba5e82f5e4d7506cb5ff9c302ef87056a
This commit is contained in:
7u83@mail.ru 2018-03-17 15:21:23 +00:00
parent 6722bb159c
commit 5edd4ab621
16 changed files with 61 additions and 160 deletions

View File

@ -22,6 +22,7 @@
<File Name="src/ac/dataman.h"/> <File Name="src/ac/dataman.h"/>
<File Name="src/ac/socklist.h"/> <File Name="src/ac/socklist.h"/>
</VirtualDirectory> </VirtualDirectory>
<File Name="src/wtp/discovery.c"/>
</VirtualDirectory> </VirtualDirectory>
<Description/> <Description/>
<Dependencies/> <Dependencies/>

View File

@ -1,11 +1,11 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<CodeLite_Workspace Name="actube" Database=""> <CodeLite_Workspace Name="actube" Database="">
<Project Name="ac" Path="ac.project" Active="No"/> <Project Name="ac" Path="ac.project" Active="No"/>
<Project Name="wtp" Path="wtp.project" Active="Yes"/> <Project Name="wtp" Path="wtp.project" Active="No"/>
<Project Name="mod_cipwap" Path="mod_cipwap.project" Active="No"/> <Project Name="mod_cipwap" Path="mod_cipwap.project" Active="No"/>
<Project Name="mod_capwap" Path="mod_capwap.project" Active="No"/> <Project Name="mod_capwap" Path="mod_capwap.project" Active="No"/>
<Project Name="mod_cisco" Path="mod_cisco.project" Active="No"/> <Project Name="mod_cisco" Path="mod_cisco.project" Active="No"/>
<Project Name="libcw" Path="libcw.project" Active="No"/> <Project Name="libcw" Path="libcw.project" Active="Yes"/>
<Project Name="mod_capwap80211" Path="mod_capwap80211.project" Active="No"/> <Project Name="mod_capwap80211" Path="mod_capwap80211.project" Active="No"/>
<Project Name="mod_fortinet" Path="mod_fortinet.project" Active="No"/> <Project Name="mod_fortinet" Path="mod_fortinet.project" Active="No"/>
<BuildMatrix> <BuildMatrix>

View File

@ -327,7 +327,6 @@
<File Name="src/cw/cw_ktv_get_byte.c"/> <File Name="src/cw/cw_ktv_get_byte.c"/>
<File Name="src/cw/cw_ktv_std_types.c"/> <File Name="src/cw/cw_ktv_std_types.c"/>
</VirtualDirectory> </VirtualDirectory>
<File Name="src/mod/capwap/capwap_out_wtp_descriptor.c"/>
</VirtualDirectory> </VirtualDirectory>
<Description/> <Description/>
<Dependencies/> <Dependencies/>

View File

@ -20,6 +20,7 @@
<File Name="src/mod/capwap/capwap_in_vendor_specific_payload.c"/> <File Name="src/mod/capwap/capwap_in_vendor_specific_payload.c"/>
<File Name="src/mod/capwap/capwap_in_mtu_discovery_padding.c"/> <File Name="src/mod/capwap/capwap_in_mtu_discovery_padding.c"/>
<File Name="src/mod/capwap/capwap_out_wtp_board_data.c"/> <File Name="src/mod/capwap/capwap_out_wtp_board_data.c"/>
<File Name="src/mod/capwap/capwap_out_wtp_descriptor.c"/>
</VirtualDirectory> </VirtualDirectory>
</VirtualDirectory> </VirtualDirectory>
</VirtualDirectory> </VirtualDirectory>

View File

@ -413,70 +413,6 @@
struct cwimage_data {
uint8_t *data;
uint8_t type;
int len;
uint32_t vendor_id;
uint8_t *identifier;
};
/*
struct cwimage_identifier{
uint32_t vendor_id;
char *name;
};
*/
/*
//extern void cwmsg_addelem_wtp_radio_infos(struct cwmsg * cwmsg,struct wtpinfo * wtpinfo);
*/
/*
extern void cwmsg_addelem_wtp_radio_infos(struct cwmsg *msg,
struct radioinfo *radioinfos);*/
/*
//extern void cwmsg_addelem_result_code(struct cwmsg *msg, int rc);
*/
/*
extern void cwmsg_addelem_vendor_specific_payload(struct cwmsg *msg, int vendor_id,
int type, uint8_t * payload, int len);
*/
/*
extern int hdr_print(char *str, uint8_t * packet, int len);
*/
/*
extern int cw_readelem_ecn_support(uint8_t * ecn_support, int type, uint8_t * msgelem,
int len);
*/
/*
//extern int cw_readelem_maximum_message_length(uint16_t * dst, int type, uint8_t * msgelem,
// int len);
//extern int cw_readelem_ac_name(uint8_t ** dst, int type, uint8_t * msgelem, int len);
//extern int cw_readelem_wtp_reboot_statistics(struct wtp_reboot_statistics *s, int type,
// uint8_t * msgelem, int len);
//extern int cw_readelem_cw_local_ip_addr(struct sockaddr *local_ip, int type,
// uint8_t * msgelem, int len);
//extern int cw_readelem_radio_administrative_state(struct radioinfo *radioinfo, int type,
// uint8_t * msgelem, int len);
//extern int cw_readelem_radio_operational_state(struct radioinfo *radioinfo, int type,
// uint8_t * msgelem, int len);
*/
/*
extern int cw_readelem_statistics_timer(uint16_t * timer, int type, uint8_t * msgelem,
int len);
extern int cw_readelem_result_code(uint32_t * result_code, int type, uint8_t * msgelem,
int len);
extern int cw_readelem_vendor_specific_payload(void *data, int msgtype, int elemtype,
uint8_t * msgelem, int len);
*/
@ -585,14 +521,21 @@ enum cw_reboot_failure_types {
*/ */
struct cwimage_data {
uint8_t *data;
uint8_t type;
int len;
uint32_t vendor_id;
uint8_t *identifier;
};
extern void cw_read_image_data_request(struct cwimage_data *, uint8_t * msg, int len); extern void cw_read_image_data_request(struct cwimage_data *, uint8_t * msg, int len);
/*
//extern int cw_readelem_ac_descriptor(struct ac_info *acinfo, int type, uint8_t * msgelem,
// int len);
//extern int cw_readelem_capwap_local_ip_addr(struct sockaddr *local_ip, int type,
// uint8_t * msgelem, int len);
*/
extern int cw_send_echo_response(struct conn *conn, int seqnum, extern int cw_send_echo_response(struct conn *conn, int seqnum,
@ -651,54 +594,6 @@ const char *cw_strelemp_(cw_strheap_t h, int msg_id);
#define cw_strelemp(p,id) cw_strelemp_((p)->strelem,id) #define cw_strelemp(p,id) cw_strelemp_((p)->strelem,id)
/*
//int cw_process_msg(struct conn *conn, uint8_t * rawmsg, int len);
*/
/*
extern int cw_in_vendor_specific_payload(struct conn *conn, struct cw_action_in *a,
uint8_t * data, int len,struct sockaddr *from);
*/
/*
extern int cw_in_wtp_name(struct conn *conn, struct cw_action_in *a, uint8_t * data,
int len,struct sockaddr *from);
extern int cw_in_wtp_board_data(struct conn *conn, struct cw_action_in *a, uint8_t * data,
int len,struct sockaddr *from);
extern int cw_in_wtp_descriptor(struct conn *conn, struct cw_action_in *a, uint8_t * data,
int len,struct sockaddr *from);
*/
/*
//extern int cw_out_generic(struct conn *conn,struct cw_action_in * a,uint8_t *data,int len);
*/
/*
extern int cw_out_generic(struct conn *conn, struct cw_action_out *a, uint8_t * dst);
*/
/*
//extern int cw_out_ac_descriptor(struct conn *conn, uint32_t elem_id, uint8_t * dst,
//struct mbag_item *item);
*/
/*
//extern int cw_out_capwap_control_ip_addrs(struct conn *conn, uint32_t elem_id,
// uint8_t * dst, struct mbag_item *item);
*/
/*
extern int cw_out_capwap_control_ip_addr_list(struct conn *conn, struct cw_action_out *a,
uint8_t * dst);
*/
/*
extern int cw_put_msg(struct conn *conn, uint8_t * rawout);
int cw_out_image_data(struct conn *conn, struct cw_action_out *a, uint8_t * dst);
*/
struct cw_ac_status { struct cw_ac_status {
int stations; int stations;
int limit; int limit;

View File

@ -436,6 +436,8 @@ extern int cw_put_local_ip_address(int sock, uint8_t * dst, int ipv4elem_id,
extern int cw_put_radio_operational_states(mbag_t radios, uint8_t * dst, int *nerror, extern int cw_put_radio_operational_states(mbag_t radios, uint8_t * dst, int *nerror,
int d7mode); int d7mode);
void cw_init_request(struct conn *conn, int msg_id);
/** /**
* @} * @}
@ -463,6 +465,7 @@ int cw_out_radio_generic(struct conn *conn, struct cw_action_out *a, uint8_t * d
int cw_put_elem_session_id(uint8_t *dst, uint8_t *session_id, int len); int cw_put_elem_session_id(uint8_t *dst, uint8_t *session_id, int len);
int cw_result_is_ok( int rc ); int cw_result_is_ok( int rc );
int cw_put_msg(struct conn *conn, uint8_t * rawout);
/** /**
* @} * @}

View File

@ -1,10 +1,11 @@
#include "ktv.h" #include "ktv.h"
int cw_ktv_read_file(FILE * file, mavl_t ktv, mavl_t types) int cw_ktv_read_file(FILE * file, mavl_t ktv, mavl_t types)
{ {
char key[256]; char key[CW_KTV_MAX_KEY_LEN];
char xtype[256]; char type[256];
char val[2048]; char val[2048];
@ -13,38 +14,26 @@ int cw_ktv_read_file(FILE * file, mavl_t ktv, mavl_t types)
do { do {
cw_KTV_t nktv, *nres;
rc = cw_ktv_read_line(file,key,type,val);
rc = cw_ktv_read_line(file,key,xtype,val); if (rc != 0){
if (rc == 0){ continue;
printf("Got a line %s:%s:%s\n",key,xtype,val);
} }
typesearch.name=xtype; typesearch.name=type;
/* printf("Searching for type: '%s'\n",xtype);*/
cwtype = mavl_get_ptr(types,&typesearch); cwtype = mavl_get_ptr(types,&typesearch);
if (cwtype != NULL){ if (cwtype != NULL){
// printf("Yes! I know the type: %s\n",cwtype->name); /*// printf("Yes! I know the type: %s\n",cwtype->name);*/
} }
else { else {
printf("Unknown type: %s\n",typesearch.name); printf("Unknown type: %s\n",typesearch.name);
continue; continue;
} }
cw_ktv_add_from_str(ktv,key,cwtype,val); cw_ktv_add_from_str(ktv,key,cwtype,val);
/* nres = cwtype->from_str(&nktv,val);
if (nres !=NULL ){
// printf("Yea, created from string\n");
nktv.key=cw_strdup(key);
mavl_add(ktv, &nktv, NULL);
}
*/
}while(rc==0); }while(rc==0);
return 0; return 0;

View File

@ -6,15 +6,17 @@
int lw_put_ac_descriptor(uint8_t * dst) int lw_put_ac_descriptor(uint8_t * dst)
{ {
uint8_t *d=dst; /* uint8_t *d=dst;
d+=lw_put_byte(d,0); /* Cisco MWAR type */ d+=lw_put_byte(d,0); / Cisco MWAR type /
// d+=lw_put_bstr(d,acinfo->hardware_version); /* length must be 4 */ // d+=lw_put_bstr(d,acinfo->hardware_version); / length must be 4
// d+=lw_put_bstr(d,acinfo->software_version); /* length must be 4 */ // d+=lw_put_bstr(d,acinfo->software_version); / length must be 4
d+=lw_put_word(d,200); d+=lw_put_word(d,200);
d+=lw_put_word(d,1000); d+=lw_put_word(d,1000);
d+=lw_put_word(d,2); d+=lw_put_word(d,2);
d+=lw_put_word(d,2); d+=lw_put_word(d,2);
//d+=lw_put_byte(d,acinfo->security); //d+=lw_put_byte(d,acinfo->security);
return d-dst; return d-dst;
*/
return 0;
} }

View File

@ -181,9 +181,9 @@ struct mavliter {
typedef struct mavliter mavliter_t; typedef struct mavliter mavliter_t;
union mavldata * mavliter_next ( mavliter_t *i ); void * mavliter_next ( mavliter_t *i );
union mavldata * mavliter_seek_set ( struct mavliter *i ); void * mavliter_seek_set ( struct mavliter *i );
void mavliter_init ( mavliter_t *i, mavl_t t ); void mavliter_init ( mavliter_t *i, mavl_t t );
@ -192,7 +192,7 @@ void * mavliter_get ( mavliter_t *i );
void * mavliter_get_ptr(mavliter_t *i); void * mavliter_get_ptr(mavliter_t *i);
extern union mavldata * mavliter_seek ( mavliter_t *i, void *d ); void * mavliter_seek ( mavliter_t *i, void *d );
/** /**
* Define a AVL Iterator varialble and accociate it with * Define a AVL Iterator varialble and accociate it with

View File

@ -29,7 +29,7 @@
* @return the element or NULL if there is no next elemeent. * @return the element or NULL if there is no next elemeent.
*/ */
union mavldata * mavliter_next ( mavliter_t *i ) void * mavliter_next ( mavliter_t *i )
{ {
while ( i->stack_ptr ) { while ( i->stack_ptr ) {
i->stack_ptr--; i->stack_ptr--;

View File

@ -31,7 +31,7 @@
* @param d element to search for * @param d element to search for
* @return element found or NULL if not found * @return element found or NULL if not found
*/ */
union mavldata * mavliter_seek(mavliter_t *i,void *d) void * mavliter_seek(mavliter_t *i,void *d)
{ {
int rc; int rc;
if (!i->root) if (!i->root)

View File

@ -1,6 +1,6 @@
#include "mavl.h" #include "mavl.h"
union mavldata * mavliter_seek_set ( struct mavliter *i ) void * mavliter_seek_set ( struct mavliter *i )
{ {
i->stack_ptr = 0; i->stack_ptr = 0;
i->cur = i->root; i->cur = i->root;

View File

@ -10,6 +10,7 @@
#include "cw/log.h" #include "cw/log.h"
#include "cw/dbg.h" #include "cw/dbg.h"
#include "cw/timer.h" #include "cw/timer.h"
#include "cw/cw.h"
#include "wtp.h" #include "wtp.h"

View File

@ -24,7 +24,7 @@ int image_update()
int rc = cw_send_request(conn, CAPWAP_MSG_IMAGE_DATA_REQUEST); int rc = cw_send_request(conn, CAPWAP_MSG_IMAGE_DATA_REQUEST);
if (rc < 0) { if (rc < 0) {h
} }
if (rc != 0) { if (rc != 0) {

View File

@ -76,23 +76,32 @@ int main (int argc, char **argv)
mavl_t global_cfg, types_tree; mavl_t global_cfg, types_tree;
const cw_Type_t ** ti; const cw_Type_t ** ti;
/* read command line args, results are in bootcfg */
parse_args(argc,argv, &bootcfg); parse_args(argc,argv, &bootcfg);
/* create an empty message set */
msgset = cw_msgset_create(); msgset = cw_msgset_create();
if (msgset==NULL){ if (msgset==NULL){
cw_log(LOG_ERR, "Error creating msgset: %s", strerror(errno)); cw_log(LOG_ERR, "Error creating msgset: %s", strerror(errno));
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
global_cfg=cw_ktv_create();
/* create types tree with default types */ /* create an empty global config */
global_cfg=cw_ktv_create();
if (msgset==NULL){
cw_log(LOG_ERR, "Error creating global_cfg: %s", strerror(errno));
exit(EXIT_FAILURE);
}
/* create a types tree with default types */
types_tree = cw_ktv_create_types_tree(); types_tree = cw_ktv_create_types_tree();
for (ti=CW_KTV_STD_TYPES;*ti;ti++){ for (ti=CW_KTV_STD_TYPES;*ti;ti++){
mavl_add_ptr(types_tree,*ti); mavl_add_ptr(types_tree,*ti);
} }
/* read the initial config file */
file = fopen(bootcfg.cfgfilename,"r"); file = fopen(bootcfg.cfgfilename,"r");
if (file == NULL){ if (file == NULL){
cw_log(LOG_ERR,"Cant open file '%s':%s", strerror(errno)); cw_log(LOG_ERR,"Cant open file '%s':%s", strerror(errno));
@ -100,6 +109,7 @@ int main (int argc, char **argv)
} }
cw_ktv_read_file(file,global_cfg,types_tree); cw_ktv_read_file(file,global_cfg,types_tree);
cw_ktv_dump(global_cfg,DBG_INFO,"----- global cfg start -----","","----- global cfg end -----"); cw_ktv_dump(global_cfg,DBG_INFO,"----- global cfg start -----","","----- global cfg end -----");
@ -119,6 +129,7 @@ int main (int argc, char **argv)
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
conn->detected = 1; conn->detected = 1;
conn->dtls_verify_peer=0; conn->dtls_verify_peer=0;
conn->dtls_mtu = 12000; conn->dtls_mtu = 12000;

View File

@ -14,7 +14,6 @@
<File Name="src/wtp/conf_uci.c"/> <File Name="src/wtp/conf_uci.c"/>
<File Name="src/wtp/dot11.h"/> <File Name="src/wtp/dot11.h"/>
<File Name="src/wtp/cfg.h"/> <File Name="src/wtp/cfg.h"/>
<File Name="src/wtp/discovery.c"/>
<File Name="src/wtp/nlt_cmdnames.c"/> <File Name="src/wtp/nlt_cmdnames.c"/>
<File Name="src/wtp/configure.c"/> <File Name="src/wtp/configure.c"/>
<File Name="src/wtp/nlt_attrnames.c"/> <File Name="src/wtp/nlt_attrnames.c"/>