static int match_hostname(char *host, char *tok)
{
if (!host || !*host) return 0;
- return (fnmatch(tok, host, 0) == 0);
+ return wildmatch(tok, host);
}
static int match_binary(char *b1, char *b2, char *mask, int addrlen)
len = strlen(tok);
/* Fail quietly if tok is a hostname (not an address) */
- if (strspn(tok, "./0123456789") != len
+ if (strspn(tok, ".0123456789") != len
#ifdef INET6
- && !strchr(tok, ':')
+ && strchr(tok, ':') == NULL
#endif
- ) return 0;
+ ) {
+ if (p)
+ *p = '/';
+ return 0;
+ }
memset(&hints, 0, sizeof(hints));
hints.ai_family = PF_UNSPEC;
hints.ai_flags = AI_NUMERICHOST;
#endif
- gai = getaddrinfo(addr, NULL, &hints, &resa);
- if (gai) return 0;
+ if (getaddrinfo(addr, NULL, &hints, &resa) != 0) {
+ if (p)
+ *p = '/';
+ return 0;
+ }
gai = getaddrinfo(tok, NULL, &hints, &rest);
if (p)
*p++ = '/';
- if (gai) {
- rprintf(FERROR,
- "error matching address %s: %s\n",
- tok,
- gai_strerror(gai));
+ if (gai != 0) {
+ rprintf(FLOG, "error matching address %s: %s\n",
+ tok, gai_strerror(gai));
freeaddrinfo(resa);
return 0;
}
}
#endif
default:
- rprintf(FERROR,"unknown family %u\n", rest->ai_family);
+ rprintf(FLOG, "unknown family %u\n", rest->ai_family);
ret = 0;
goto out;
}
#ifdef HAVE_STRTOL
bits = strtol(p, &ep, 10);
if (!*p || *ep) {
- rprintf(FERROR,"malformed mask in %s\n", tok);
+ rprintf(FLOG, "malformed mask in %s\n", tok);
ret = 0;
goto out;
}
#else
for (pp = (unsigned char *)p; *pp; pp++) {
if (!isascii(*pp) || !isdigit(*pp)) {
- rprintf(FERROR,"malformed mask in %s\n", tok);
+ rprintf(FLOG, "malformed mask in %s\n", tok);
ret = 0;
goto out;
}
goto out;
}
if (bits < 0 || bits > (addrlen << 3)) {
- rprintf(FERROR,"malformed mask in %s\n", tok);
+ rprintf(FLOG, "malformed mask in %s\n", tok);
ret = 0;
goto out;
}