aboutsummaryrefslogtreecommitdiffstats
path: root/acl.c
diff options
context:
space:
mode:
authormarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-01-10 21:43:17 +0000
committermarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-01-10 21:43:17 +0000
commit2ec743267a0fc75a6d835d4bc945c28949d02b64 (patch)
treedfaa5c58e84b06bf72c88993f3baa8c10464c573 /acl.c
parentaab472d7c08263621f7298076a3be2ab30f5dde5 (diff)
Allow /x for subnetmask identification (e.g. 192.168.0.0/16)
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@1920 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'acl.c')
-rwxr-xr-xacl.c19
1 files changed, 15 insertions, 4 deletions
diff --git a/acl.c b/acl.c
index 067e36d09..ea45af838 100755
--- a/acl.c
+++ b/acl.c
@@ -72,6 +72,8 @@ struct ast_ha *ast_append_ha(char *sense, char *stuff, struct ast_ha *path)
char tmp[256] = "";
struct ast_ha *prev = NULL;
struct ast_ha *ret;
+ int x,z;
+ unsigned int y;
ret = path;
while(path) {
prev = path;
@@ -86,13 +88,22 @@ struct ast_ha *ast_append_ha(char *sense, char *stuff, struct ast_ha *path)
*nm = '\0';
nm++;
}
- if (!inet_aton(tmp, &ha->netaddr)) {
- ast_log(LOG_WARNING, "%s not a valid IP\n", tmp);
+ if (!strchr(nm, '.')) {
+ if ((sscanf(nm, "%i", &x) == 1) && (x >= 0) && (x <= 32)) {
+ y = 0;
+ for (z=0;z<x;z++) {
+ y >>= 1;
+ y |= 0x8000000;
+ }
+ ha->netmask.s_addr = htonl(y);
+ }
+ } else if (!inet_aton(nm, &ha->netmask)) {
+ ast_log(LOG_WARNING, "%s not a valid netmask\n", nm);
free(ha);
return path;
}
- if (!inet_aton(nm, &ha->netmask)) {
- ast_log(LOG_WARNING, "%s not a valid netmask\n", nm);
+ if (!inet_aton(tmp, &ha->netaddr)) {
+ ast_log(LOG_WARNING, "%s not a valid IP\n", tmp);
free(ha);
return path;
}