X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=acl.c;h=14edcf7d87c08617e175e0fff44e3c572e305160;hp=52eba1d47a4ba6d90cbffd8f6df69036acc36b6f;hb=ac153fd54a0f093581ee863984070a325d5343b8;hpb=8e300aadc904a0e8b7453be4fb571f68bab6234c diff --git a/acl.c b/acl.c index 52eba1d4..14edcf7d 100644 --- a/acl.c +++ b/acl.c @@ -73,14 +73,13 @@ no_match: * \param addr The address to add. * \param netmask The netmask to use for this entry. */ -static void acl_add_entry(struct list_head *acl, struct in_addr addr, - int netmask) +static void acl_add_entry(struct list_head *acl, char *addr, int netmask) { struct access_info *ai = para_malloc(sizeof(struct access_info)); - ai->addr = addr; + + inet_pton(AF_INET, addr, &ai->addr); ai->netmask = netmask; - PARA_INFO_LOG("adding %s/%i to access list\n", inet_ntoa(ai->addr), - ai->netmask); + PARA_INFO_LOG("adding %s/%i to access list\n", addr, ai->netmask); para_list_add(&ai->node, acl); } @@ -91,21 +90,18 @@ static void acl_add_entry(struct list_head *acl, struct in_addr addr, * \param addr The address to delete. * \param netmask The netmask of the entry to be removed from the list. */ -static void acl_del_entry(struct list_head *acl, struct in_addr addr, - int netmask) +static void acl_del_entry(struct list_head *acl, char *addr, int netmask) { struct access_info *ai, *tmp; list_for_each_entry_safe(ai, tmp, acl, node) { - char *nad = para_strdup(inet_ntoa(ai->addr)); - if (!strcmp(nad, inet_ntoa(addr)) && + if (!strcmp(addr, inet_ntoa(ai->addr)) && ai->netmask == netmask) { PARA_NOTICE_LOG("removing %s/%i from access list\n", - nad, ai->netmask); + addr, ai->netmask); list_del(&ai->node); free(ai); } - free(nad); } } @@ -146,18 +142,17 @@ void acl_init(struct list_head *acl, char * const *acl_info, int num) for (i = 0; i < num; i++) { char *arg = para_strdup(acl_info[i]); char *p = strchr(arg, '/'); - struct in_addr addr; int netmask; if (!p) goto err; *p = '\0'; - if (!inet_pton(AF_INET, arg, &addr)) + if (!is_valid_ipv4_address(arg)) goto err; netmask = atoi(++p); if (netmask < 0 || netmask > 32) goto err; - acl_add_entry(acl, addr, netmask); + acl_add_entry(acl, arg, netmask); goto success; err: PARA_CRIT_LOG("syntax error: %s\n", acl_info[i]); @@ -193,8 +188,8 @@ int acl_check_access(int fd, struct list_head *acl, int default_deny) * \param acl The access control list. * \param default_deny Whether \a acl is a whitelist. */ -void acl_allow(struct in_addr addr, int netmask, - struct list_head *acl, int default_deny) +void acl_allow(char *addr, int netmask, + struct list_head *acl, int default_deny) { if (default_deny) acl_add_entry(acl, addr, netmask); @@ -210,8 +205,8 @@ void acl_allow(struct in_addr addr, int netmask, * \param acl The access control list. * \param default_deny Whether \a acl is a whitelist. */ -void acl_deny(struct in_addr addr, int netmask, - struct list_head *acl, int default_deny) +void acl_deny(char *addr, int netmask, + struct list_head *acl, int default_deny) { acl_allow(addr, netmask, acl, !default_deny); }