listen addrs are stored in cfg obj now

This commit is contained in:
7u83 2022-08-01 10:06:18 +02:00
parent 04d469b970
commit 156466eab9
2 changed files with 25 additions and 44 deletions

View File

@ -36,6 +36,7 @@
#include "conf.h" #include "conf.h"
#include "ac.h" #include "ac.h"
#include "cw/cfg.h"
#include "cw/mavltypes.h" #include "cw/mavltypes.h"
@ -60,8 +61,6 @@ long conf_max_wtps = CONF_DEFAULT_MAXWTPS;
char *conf_logfilename = CONF_DEFAULT_LOGFILENAME; char *conf_logfilename = CONF_DEFAULT_LOGFILENAME;
struct sockaddr_storage *conf_salist = NULL; struct sockaddr_storage *conf_salist = NULL;
char **conf_listen_addrs;
int conf_listen_addrs_len = 0;
char **conf_mcast_groups = 0; char **conf_mcast_groups = 0;
@ -215,41 +214,23 @@ static int init_control_port()
#include <ifaddrs.h> #include <ifaddrs.h>
static int init_listen_addrs() static int init_listen_addrs(cw_Cfg_t * cfg)
{ {
char key[CW_CFG_MAX_KEY_LEN];
struct ifaddrs *ifap, *ifa; struct ifaddrs *ifap, *ifa;
int rc; int rc;
int ctr; int ctr;
const char * a0;
if (conf_listen_addrs != 0) a0 = cw_cfg_get(cfg,"actube/listen.0",NULL);
if (a0)
return 1; return 1;
rc = getifaddrs(&ifap); rc = getifaddrs(&ifap);
if (rc == -1) if (rc == -1)
return 0; return 0;
/* count the addresses */
ctr = 0;
for (ifa = ifap; ifa != 0; ifa = ifa->ifa_next) {
if (!ifa->ifa_addr)
continue;
if (ifa->ifa_addr->sa_family == AF_INET && conf_ipv4)
ctr++;
if (ifa->ifa_addr->sa_family == AF_INET6 && conf_ipv6)
ctr++;
}
conf_listen_addrs = malloc(sizeof(char *) * ctr);
if (!conf_listen_addrs) {
rc = 0;
goto errX;
}
memset(conf_listen_addrs, 0, sizeof(char *) * ctr);
ctr = 0; ctr = 0;
/* get the addresses */ /* get the addresses */
for (ifa = ifap; ifa != 0; ifa = ifa->ifa_next) { for (ifa = ifap; ifa != 0; ifa = ifa->ifa_next) {
@ -267,12 +248,9 @@ static int init_listen_addrs()
if (ifa->ifa_addr->sa_family == AF_INET && conf_ipv4) { if (ifa->ifa_addr->sa_family == AF_INET && conf_ipv4) {
sock_addrtostr(ifa->ifa_addr, str, 100,0); sock_addrtostr(ifa->ifa_addr, str, 100,0);
conf_listen_addrs[ctr] =
(char *) cw_setstr((uint8_t **) & conf_listen_addrs[ctr],
(uint8_t *) str, strlen(str));
if (conf_listen_addrs[ctr])
ctr++;
sprintf(key,"actube/listen.%d",ctr++);
cw_cfg_set(cfg,key,str);
} }
if (ifa->ifa_addr->sa_family == AF_INET6 && conf_ipv6) { if (ifa->ifa_addr->sa_family == AF_INET6 && conf_ipv6) {
sock_addrtostr(ifa->ifa_addr, str, 100,0); sock_addrtostr(ifa->ifa_addr, str, 100,0);
@ -281,14 +259,10 @@ static int init_listen_addrs()
strcat(str, "%"); strcat(str, "%");
strcat(str, ifa->ifa_name); strcat(str, ifa->ifa_name);
} }
conf_listen_addrs[ctr] = sprintf(key,"actube/listen.%d",ctr++);
(char *) cw_setstr((uint8_t **) & conf_listen_addrs[ctr], cw_cfg_set(cfg,key,str);
(uint8_t *) str, strlen(str));
if (conf_listen_addrs[ctr])
ctr++;
} }
} }
conf_listen_addrs_len = ctr;
rc = 1; rc = 1;
errX: errX:
freeifaddrs(ifap); freeifaddrs(ifap);
@ -703,9 +677,6 @@ int read_config(const char *filename)
/* read debug options */ /* read debug options */
conf_read_dbg_level(cfg); conf_read_dbg_level(cfg);
/* read the listen addresses */
conf_read_strings(cfg, "listen", &conf_listen_addrs, &conf_listen_addrs_len);
/* read multi cast groups */ /* read multi cast groups */
conf_read_strings(cfg, "mcast_groups", &conf_mcast_groups, conf_read_strings(cfg, "mcast_groups", &conf_mcast_groups,
&conf_mcast_groups_len); &conf_mcast_groups_len);
@ -763,7 +734,6 @@ int read_config(const char *filename)
init_listen_addrs();
init_mcast_groups(); init_mcast_groups();
init_bcast_addrs(); init_bcast_addrs();
@ -775,3 +745,13 @@ void free_config()
{ {
} }
void ac_conf_init(cw_Cfg_t *cfg)
{
printf("ac conf\n");
init_listen_addrs(cfg);
}

View File

@ -31,7 +31,7 @@
#include "cw/bstr.h" #include "cw/bstr.h"
#include "cw/mod.h" #include "cw/mod.h"
#include "cw/vendors.h" #include "cw/vendors.h"
#include "cw/cfg.h"
extern struct cw_Mod ** conf_mods; extern struct cw_Mod ** conf_mods;
@ -94,8 +94,6 @@ extern bstr_t conf_cisco_software_version;
extern char **conf_listen_addrs;
extern int conf_listen_addrs_len;
extern struct sockaddr *conf_ac_ips; extern struct sockaddr *conf_ac_ips;
extern int conf_ac_ips_len; extern int conf_ac_ips_len;
@ -141,5 +139,8 @@ extern int conf_parse_listen_addr(const char *addr, char *saddr, char *port, int
#define CFG_ENTRY_MODS "mods" #define CFG_ENTRY_MODS "mods"
#define CONF_PREFIX "actube"
void ac_conf_init(cw_Cfg_t *cfg);
#endif #endif