[MINOR] implement acl_parse_ip and acl_match_ip

The ACL can now compare IP addresses. The client's IP address
can be checked.
This commit is contained in:
Willy Tarreau 2007-05-08 19:50:09 +02:00
parent 5c8e3e09e9
commit a67fad9d68
4 changed files with 38 additions and 2 deletions

View File

@ -118,6 +118,13 @@ int acl_parse_range(const char *text, struct acl_pattern *pattern);
/* Parse a string. It is allocated and duplicated. */ /* Parse a string. It is allocated and duplicated. */
int acl_parse_str(const char *text, struct acl_pattern *pattern); int acl_parse_str(const char *text, struct acl_pattern *pattern);
/* Parse an IP address and an optional mask in the form addr[/mask].
* The addr may either be an IPv4 address or a hostname. The mask
* may either be a dotted mask or a number of bits. Returns 1 if OK,
* otherwise 0.
*/
int acl_parse_ip(const char *text, struct acl_pattern *pattern);
/* Checks that the pattern matches the end of the tested string. */ /* Checks that the pattern matches the end of the tested string. */
int acl_match_end(struct acl_test *test, struct acl_pattern *pattern); int acl_match_end(struct acl_test *test, struct acl_pattern *pattern);
@ -139,6 +146,9 @@ int acl_match_dir(struct acl_test *test, struct acl_pattern *pattern);
*/ */
int acl_match_dom(struct acl_test *test, struct acl_pattern *pattern); int acl_match_dom(struct acl_test *test, struct acl_pattern *pattern);
/* Check that the IPv4 address in <test> matches the IP/mask in pattern */
int acl_match_ip(struct acl_test *test, struct acl_pattern *pattern);
#endif /* _PROTO_ACL_H */ #endif /* _PROTO_ACL_H */
/* /*

View File

@ -74,7 +74,10 @@ struct acl_pattern {
union { union {
int i; /* integer value */ int i; /* integer value */
struct { int min, max; } range; /* integer range */ struct { int min, max; } range; /* integer range */
struct sockaddr_in ipv4; /* IPv4 address */ struct {
struct in_addr addr;
struct in_addr mask;
} ipv4; /* IPv4 address */
struct acl_time time; /* valid hours and days */ struct acl_time time; /* valid hours and days */
} val; /* direct value */ } val; /* direct value */
union { union {

View File

@ -172,6 +172,19 @@ int acl_match_max(struct acl_test *test, struct acl_pattern *pattern)
return 0; return 0;
} }
int acl_match_ip(struct acl_test *test, struct acl_pattern *pattern)
{
struct in_addr *s;
if (test->i != AF_INET)
return 0;
s = (void *)test->ptr;
if (((s->s_addr ^ pattern->val.ipv4.addr.s_addr) & pattern->val.ipv4.mask.s_addr) == 0)
return 1;
return 0;
}
/* Parse a string. It is allocated and duplicated. */ /* Parse a string. It is allocated and duplicated. */
int acl_parse_str(const char *text, struct acl_pattern *pattern) int acl_parse_str(const char *text, struct acl_pattern *pattern)
{ {
@ -222,6 +235,16 @@ int acl_parse_range(const char *text, struct acl_pattern *pattern)
return 1; return 1;
} }
/* Parse an IP address and an optional mask in the form addr[/mask].
* The addr may either be an IPv4 address or a hostname. The mask
* may either be a dotted mask or a number of bits. Returns 1 if OK,
* otherwise 0.
*/
int acl_parse_ip(const char *text, struct acl_pattern *pattern)
{
return str2net(text, &pattern->val.ipv4.addr, &pattern->val.ipv4.mask);
}
/* /*
* Registers the ACL keyword list <kwl> as a list of valid keywords for next * Registers the ACL keyword list <kwl> as a list of valid keywords for next
* parsing sessions. * parsing sessions.

View File

@ -489,8 +489,8 @@ static int acl_fetch_dconn(struct proxy *px, struct session *l4, void *l7, void
/* Note: must not be declared <const> as its list will be overwritten */ /* Note: must not be declared <const> as its list will be overwritten */
static struct acl_kw_list acl_kws = {{ },{ static struct acl_kw_list acl_kws = {{ },{
{ "src_port", acl_parse_range, acl_fetch_sport, acl_match_range }, { "src_port", acl_parse_range, acl_fetch_sport, acl_match_range },
#if 0
{ "src", acl_parse_ip, acl_fetch_src, acl_match_ip }, { "src", acl_parse_ip, acl_fetch_src, acl_match_ip },
#if 0
{ "dst", acl_parse_ip, acl_fetch_dst, acl_match_ip }, { "dst", acl_parse_ip, acl_fetch_dst, acl_match_ip },
{ "dst_port", acl_parse_range, acl_fetch_dport, acl_match_range }, { "dst_port", acl_parse_range, acl_fetch_dport, acl_match_range },