Test implementation for config to SQL

Also deleted some old out-commented code.

FossilOrigin-Name: 2e5f59266c755e726ac080998003ad84a0286aa1ede029d7371b6dc35ba8e455
This commit is contained in:
7u83@mail.ru 2015-04-29 17:26:04 +00:00
parent c93bccac83
commit 3dcf0d92cf

View File

@ -276,47 +276,6 @@ static int wtpman_join(void *arg, time_t timer)
} }
/*
static int wtpman_send_image_file(struct wtpman *wtpman, struct cwrmsg *cwrmsg)
{
struct cwimage_data data;
memset(&data, 0, sizeof(struct cwimage_data));
uint8_t id[1025];
data.identifier = id;
char filename[2048];
id[0] = 0;
cw_read_image_data_request(&data, cwrmsg->msgelems, cwrmsg->msgelems_len);
if (!strlen(id)) {
cw_dbg(DBG_MSG_ERR, "No image identifier in image data request");
cw_send_image_data_response(wtpman->conn, cwrmsg->seqnum,
CW_RESULT_FAILURE);
return 0;
}
sprintf(filename, "%s/%s", conf_image_dir, id);
FILE *infile;
infile = fopen(filename, "rb");
if (infile) {
cw_send_image_data_response(wtpman->conn, cwrmsg->seqnum,
CW_RESULT_SUCCESS);
cw_log(LOG_INFO, "Sending image file %s to %s", filename,
sock_addr2str(&wtpman->conn->addr));
cw_send_image_file(wtpman->conn, infile);
return 1;
}
cw_log(LOG_ERR, "Can't open image file %s:%s", filename, strerror(errno));
cw_send_image_data_response(wtpman->conn, cwrmsg->seqnum, CW_RESULT_FAILURE);
return 0;
}
*/
static void wtpman_image_data(struct wtpman *wtpman) static void wtpman_image_data(struct wtpman *wtpman)
{ {
struct conn * conn = wtpman->conn; struct conn * conn = wtpman->conn;
@ -369,6 +328,36 @@ static void wtpman_image_data(struct wtpman *wtpman)
} }
#include "db.h"
void config_to_sql(struct conn *conn)
{
// XXX for the moment we use just the IP adress as ID
char *wtp_id=sock_addr2str(&conn->addr);
MAVLITER_DEFINE(it,conn->incomming);
mavliter_foreach(&it){
mbag_item_t * i = mavliter_get(&it);
struct cw_item * cwi = cw_item_get_by_id(i->id,capwap_itemdefs);
if (cwi){
// DBGX("ID %d,%s",i->id,cwi->cfgname);
// printf("%s != %s ?\n",i->type->name,cwi->type->name);
char str[256];
if (i->type->to_str)
i->type->to_str(i,str);
db_put_wtp_prop(wtp_id,-1,cwi->cfgname,str);
}
else{
// DBGX("ID %d",i->id);
}
}
}
static void wtpman_run(void *arg) static void wtpman_run(void *arg)
{ {
@ -435,8 +424,13 @@ static void wtpman_run(void *arg)
} }
conn->capwap_state=CW_STATE_RUN; conn->capwap_state=CW_STATE_RUN;
// XXX testing ...
config_to_sql(conn);
rc = 0; rc = 0;
while (wtpman->conn->capwap_state == CW_STATE_RUN) { while (wtpman->conn->capwap_state == CW_STATE_RUN) {
rc = cw_read_messages(wtpman->conn); rc = cw_read_messages(wtpman->conn);
@ -449,7 +443,7 @@ static void wtpman_run(void *arg)
wtpman_remove(wtpman);
return; return;
} }
@ -483,7 +477,7 @@ struct wtpman *wtpman_create(int socklistindex, struct sockaddr *srcaddr)
wtpman->conn->strict_hdr = conf_strict_headers; wtpman->conn->strict_hdr = conf_strict_headers;
wtpman->conn->radios=mbag_create(); wtpman->conn->radios=mbag_create();
wtpman->conn->local = ac_config; wtpman->conn->local = ac_config;
wtpman->conn->capwap_mode=0; //CW_MODE_STD; //CISCO; //wtpman->conn->capwap_mode=0; //CW_MODE_STD; //CISCO;
wtpman->conn->capwap_mode=CW_MODE_CISCO; wtpman->conn->capwap_mode=CW_MODE_CISCO;
//wtpman->conn->strict_capwap_hdr=0; //wtpman->conn->strict_capwap_hdr=0;