discovery uses cw_DiscoveryResult struct now

FossilOrigin-Name: 0024624d719534d3a7ee07380d889b339f95f59d2b8276f96f09c07f24824553
This commit is contained in:
7u83@mail.ru 2018-03-30 21:58:21 +00:00
parent bbc64dd0a7
commit 8a9ca46554
4 changed files with 97 additions and 33 deletions

View File

@ -22,7 +22,6 @@
<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

@ -17,20 +17,26 @@
#include "wtp.h" #include "wtp.h"
mavl_t cw_select_ac(mavl_t local_cfg, mlist_t aclist)
int cw_select_ac(mavl_t local_cfg, struct cw_DiscoveryResult * dis)
{ {
mlistelem_t *e; mlistelem_t *e;
mavl_t iplist; /*mavl_t iplist;*/
int en; int en;
iplist = cw_ktv_create(); /*iplist = cw_ktv_create();
if (iplist == NULL) if (iplist == NULL){
return 0; cw_log_errno("cw_select_ac: Can't allocate memory for aciplist");
return NULL;
}
*/
en = 0; en = 0;
/* for each discovery response */ /* for each discovery response */
mlist_foreach(e, aclist) { mlist_foreach(e, dis->results) {
char acname[CAPWAP_MAX_AC_NAME_LEN + 1]; char acname[CAPWAP_MAX_AC_NAME_LEN + 1];
char key[CW_KTV_MAX_KEY_LEN]; char key[CW_KTV_MAX_KEY_LEN];
mavl_t remote_cfg; mavl_t remote_cfg;
@ -61,13 +67,12 @@ mavl_t cw_select_ac(mavl_t local_cfg, mlist_t aclist)
if (val == NULL) if (val == NULL)
break; break;
sprintf(key, "%s.%d", "capwap-control-ip-address/address", i); sprintf(key, "%s.%d", "capwap-control-ip-address/address", i);
ipval = cw_ktv_get(remote_cfg, key, CW_TYPE_IPADDRESS); ipval = cw_ktv_get(remote_cfg, key, CW_TYPE_IPADDRESS);
sprintf(key, "%04d%05d%04d", prio, val->val.word, en); sprintf(key, "%04d%05d%04d", prio, val->val.word, en);
cw_ktv_add(iplist, key, CW_TYPE_SYSPTR, (uint8_t *) (&ipval), cw_ktv_add(dis->prio_ip, key, CW_TYPE_SYSPTR, (uint8_t *) (&ipval),
sizeof(ipval)); sizeof(ipval));
i++; i++;
en++; en++;
@ -75,32 +80,48 @@ mavl_t cw_select_ac(mavl_t local_cfg, mlist_t aclist)
} }
cw_dbg_ktv_dump(iplist, DBG_INFO, "=== IP list ===", "IP", "=== END IP List ===");
{
mavliter_t i;
mavliter_init(&i, iplist);
mavliter_foreach(&i) {
char ipstr[100];
char *rk;
cw_KTV_t *val;
val = mavliter_get(&i);
rk = val->key;
val = val->val.ptr;
val->type->to_str(val, ipstr, 100);
printf("PTRVAL(%s): %s - %s\n", rk, val->key, ipstr);
}
}
return 1;
}
void cw_discovery_free_results(struct cw_DiscoveryResult * dis)
{
if (dis->prio_ac != NULL)
mavl_destroy(dis->prio_ac);
if (dis->prio_ip != NULL)
mavl_destroy(dis->prio_ip);
if (dis->results != NULL)
mlist_destroy(dis->results);
}
int cw_discovery_init_results(struct cw_DiscoveryResult *dis)
{
dis->results = mlist_create(NULL, NULL, sizeof(void *));
if (dis->results==NULL)
goto errX;
dis->prio_ac=cw_ktv_create();
if (dis->prio_ac==NULL)
goto errX;
dis->prio_ip=cw_ktv_create();
if (dis->prio_ac==NULL)
goto errX;
return 1;
errX:
cw_discovery_free_results(dis);
return 0; return 0;
} }
static int run_discovery(struct conn *conn)
static int run_discovery(struct conn *conn, struct cw_DiscoveryResult * dis)
{ {
time_t timer; time_t timer;
mlist_t discovery_results;
struct sockaddr_storage from; struct sockaddr_storage from;
int delay, min, max; int delay, min, max;
min = cw_ktv_get_byte(conn->local_cfg,"capwap-timers/min-discovery-interval", min = cw_ktv_get_byte(conn->local_cfg,"capwap-timers/min-discovery-interval",
@ -127,7 +148,9 @@ static int run_discovery(struct conn *conn)
timer = cw_timer_start(cw_ktv_get_byte(conn->local_cfg, "discovery-interval", timer = cw_timer_start(cw_ktv_get_byte(conn->local_cfg, "discovery-interval",
CAPWAP_DISCOVERY_INTERVAL))-1; CAPWAP_DISCOVERY_INTERVAL))-1;
discovery_results = mlist_create(NULL, NULL, sizeof(void *)); /*discovery_results = mlist_create(NULL, NULL, sizeof(void *));*/
while (!cw_timer_timeout(timer) while (!cw_timer_timeout(timer)
&& conn->capwap_state == CAPWAP_STATE_DISCOVERY) { && conn->capwap_state == CAPWAP_STATE_DISCOVERY) {
int rc; int rc;
@ -149,26 +172,35 @@ static int run_discovery(struct conn *conn)
} }
cw_dbg(DBG_INFO, "Received Discovery Response from %s", cw_dbg(DBG_INFO, "Received Discovery Response from %s",
sock_addr2str(&from, addr_str)); sock_addr2str(&from, addr_str));
mlist_append_ptr(discovery_results, conn->remote_cfg); mlist_append_ptr(dis->results, conn->remote_cfg);
} }
cw_select_ac(conn->local_cfg, discovery_results); cw_select_ac(conn->local_cfg, dis);
return 1; return 1;
} }
/** /**
* Run discovery for on address (eg broadcast 255.255.255.255) * Run discovery for on address (eg broadcast 255.255.255.255)
*/ */
int cw_run_discovery(struct conn *conn, const char *addr, const char *bindaddr) int cw_run_discovery(struct conn *conn, const char *addr, const char *bindaddr,
struct cw_DiscoveryResult * dis)
{ {
char sock_buf[SOCK_ADDR_BUFSIZE]; char sock_buf[SOCK_ADDR_BUFSIZE];
struct sockaddr_storage dstaddr; struct sockaddr_storage dstaddr;
char caddr[256], control_port[64]; char caddr[256], control_port[64];
int rc; int rc;
/*struct cw_DiscoveryResult dis;*/
/*dis.results = mlist_create(NULL, NULL, sizeof(void *));*/
/* get addr of destination */ /* get addr of destination */
struct addrinfo hints; struct addrinfo hints;
@ -258,7 +290,7 @@ int cw_run_discovery(struct conn *conn, const char *addr, const char *bindaddr)
cw_dbg(DBG_INFO, "Discovery to %s", cw_dbg(DBG_INFO, "Discovery to %s",
sock_addr2str_p(&conn->addr, sock_buf)); sock_addr2str_p(&conn->addr, sock_buf));
run_discovery(conn); run_discovery(conn, dis);
conn->readfrom = NULL; conn->readfrom = NULL;
close(sockfd); close(sockfd);

View File

@ -14,9 +14,20 @@ extern int configure();
extern int run(); extern int run();
extern int changestate(); extern int changestate();
int cw_run_discovery(struct conn *conn, const char *acaddr, const char *bindaddr);
struct cw_DiscoveryResult{
mavl_t prio_ip;
mavl_t prio_ac;
mlist_t results;
};
int cw_run_discovery(struct conn *conn, const char *acaddr, const char *bindaddr,
struct cw_DiscoveryResult * dis);
int cw_discovery_init_results(struct cw_DiscoveryResult *dis);
void cw_discovery_free_results(struct cw_DiscoveryResult * dis);
struct conn * get_conn(); struct conn * get_conn();
#endif #endif

View File

@ -156,7 +156,29 @@ int main (int argc, char **argv)
conn->receiver = CW_RECEIVER_WTP; conn->receiver = CW_RECEIVER_WTP;
conn->wbid=1; conn->wbid=1;
cw_run_discovery(conn, "255.255.255.255",NULL); struct cw_DiscoveryResult dis;
cw_discovery_init_results(&dis);
cw_run_discovery(conn, "255.255.255.255",NULL, &dis);
cw_dbg_ktv_dump(dis.prio_ip, DBG_INFO, "=== IP list ===", "IP", "=== END IP List ===");
{
mavliter_t i;
mavliter_init(&i, dis.prio_ip);
mavliter_foreach(&i) {
char ipstr[100];
char *rk;
cw_KTV_t *val;
val = mavliter_get(&i);
rk = val->key;
val = val->val.ptr;
val->type->to_str(val, ipstr, 100);
printf("PTRVAL(%s): %s - %s\n", rk, val->key, ipstr);
}
}
return (EXIT_SUCCESS); return (EXIT_SUCCESS);