mirror of
https://github.com/sheumann/hush.git
synced 2025-02-28 20:31:33 +00:00
dnsd,sestatus: use libbb to parse config file (by Vladimir)
function old new delta dnsd_main 1544 1487 -57
This commit is contained in:
parent
1e8034e614
commit
a34f1ed737
@ -101,75 +101,47 @@ static void undot(uint8_t * rip)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Read one line of hostname/IP from file
|
|
||||||
* Returns 0 for each valid entry read, -1 at EOF
|
|
||||||
* Assumes all host names are lower case only
|
|
||||||
* Hostnames with more than one label are not handled correctly.
|
|
||||||
* Presently the dot is copied into name without
|
|
||||||
* converting to a length/string substring for that label.
|
|
||||||
*/
|
|
||||||
static int getfileentry(FILE *fp, struct dns_entry *s)
|
|
||||||
{
|
|
||||||
unsigned int a,b,c,d;
|
|
||||||
char *line, *r, *name;
|
|
||||||
|
|
||||||
restart:
|
|
||||||
line = r = xmalloc_fgets(fp);
|
|
||||||
if (!r)
|
|
||||||
return -1;
|
|
||||||
while (*r == ' ' || *r == '\t') {
|
|
||||||
r++;
|
|
||||||
if (!*r || *r == '#' || *r == '\n') {
|
|
||||||
free(line);
|
|
||||||
goto restart; /* skipping empty/blank and commented lines */
|
|
||||||
}
|
|
||||||
}
|
|
||||||
name = r;
|
|
||||||
while (*r != ' ' && *r != '\t')
|
|
||||||
r++;
|
|
||||||
*r++ = '\0';
|
|
||||||
if (sscanf(r, ".%u.%u.%u.%u"+1, &a, &b, &c, &d) != 4) {
|
|
||||||
free(line);
|
|
||||||
goto restart; /* skipping wrong lines */
|
|
||||||
}
|
|
||||||
|
|
||||||
sprintf(s->ip, ".%u.%u.%u.%u"+1, a, b, c, d);
|
|
||||||
sprintf(s->rip, ".%u.%u.%u.%u", d, c, b, a);
|
|
||||||
undot((uint8_t*)s->rip);
|
|
||||||
convname(s->name, (uint8_t*)name);
|
|
||||||
|
|
||||||
if (OPT_verbose)
|
|
||||||
fprintf(stderr, "\tname:%s, ip:%s\n", &(s->name[1]),s->ip);
|
|
||||||
|
|
||||||
free(line);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Read hostname/IP records from file
|
* Read hostname/IP records from file
|
||||||
*/
|
*/
|
||||||
static void dnsentryinit(void)
|
static void dnsentryinit(void)
|
||||||
{
|
{
|
||||||
FILE *fp;
|
parser_t *parser;
|
||||||
struct dns_entry *m, *prev;
|
struct dns_entry *m, *prev;
|
||||||
|
|
||||||
prev = dnsentry = NULL;
|
prev = dnsentry = NULL;
|
||||||
fp = xfopen(fileconf, "r");
|
parser = config_open(fileconf);
|
||||||
|
if (parser) {
|
||||||
|
char *token[2];
|
||||||
|
while (config_read(parser, token, 2, 0, "# \t", 0)) {
|
||||||
|
unsigned int a,b,c,d;
|
||||||
|
/*
|
||||||
|
* Assumes all host names are lower case only
|
||||||
|
* Hostnames with more than one label are not handled correctly.
|
||||||
|
* Presently the dot is copied into name without
|
||||||
|
* converting to a length/string substring for that label.
|
||||||
|
*/
|
||||||
|
if (!token[1] || sscanf(token[1], ".%u.%u.%u.%u"+1, &a, &b, &c, &d) != 4)
|
||||||
|
continue;
|
||||||
|
|
||||||
while (1) {
|
m = xzalloc(sizeof(*m));
|
||||||
m = xzalloc(sizeof(*m));
|
/*m->next = NULL;*/
|
||||||
/*m->next = NULL;*/
|
sprintf(m->ip, ".%u.%u.%u.%u"+1, a, b, c, d);
|
||||||
if (getfileentry(fp, m))
|
sprintf(m->rip, ".%u.%u.%u.%u", d, c, b, a);
|
||||||
break;
|
undot((uint8_t*)m->rip);
|
||||||
|
convname(m->name, (uint8_t*)token[0]);
|
||||||
|
|
||||||
if (prev == NULL)
|
if (OPT_verbose)
|
||||||
dnsentry = m;
|
fprintf(stderr, "\tname:%s, ip:%s\n", &(m->name[1]), m->ip);
|
||||||
else
|
|
||||||
prev->next = m;
|
if (prev == NULL)
|
||||||
prev = m;
|
dnsentry = m;
|
||||||
|
else
|
||||||
|
prev->next = m;
|
||||||
|
prev = m;
|
||||||
|
}
|
||||||
|
config_close(parser);
|
||||||
}
|
}
|
||||||
fclose(fp);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -47,31 +47,17 @@ static void display_boolean(void)
|
|||||||
|
|
||||||
static void read_config(char **pc, int npc, char **fc, int nfc)
|
static void read_config(char **pc, int npc, char **fc, int nfc)
|
||||||
{
|
{
|
||||||
char buf[256];
|
char *buf;
|
||||||
FILE *fp;
|
parser_t *parser;
|
||||||
int pc_ofs = 0, fc_ofs = 0, section = -1;
|
int pc_ofs = 0, fc_ofs = 0, section = -1;
|
||||||
|
|
||||||
pc[0] = fc[0] = NULL;
|
pc[0] = fc[0] = NULL;
|
||||||
|
|
||||||
fp = fopen("/etc/sestatus.conf", "rb");
|
parser = config_open("/etc/sestatus.conf");
|
||||||
if (fp == NULL)
|
if (!parser)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
while (fgets(buf, sizeof(buf), fp) != NULL) {
|
while (config_read(parser, &buf, 1, 1, "# \t", PARSE_LAST_IS_GREEDY)) {
|
||||||
int i, c;
|
|
||||||
|
|
||||||
/* kills comments */
|
|
||||||
for (i = 0; (c = buf[i]) != '\0'; i++) {
|
|
||||||
if (c == '#') {
|
|
||||||
buf[i] = '\0';
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
trim(buf);
|
|
||||||
|
|
||||||
if (buf[0] == '\0')
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (strcmp(buf, "[process]") == 0) {
|
if (strcmp(buf, "[process]") == 0) {
|
||||||
section = 1;
|
section = 1;
|
||||||
} else if (strcmp(buf, "[files]") == 0) {
|
} else if (strcmp(buf, "[files]") == 0) {
|
||||||
@ -86,7 +72,7 @@ static void read_config(char **pc, int npc, char **fc, int nfc)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fclose(fp);
|
config_close(parser);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void display_verbose(void)
|
static void display_verbose(void)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user