summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sbin/pfctl/parse.y33
1 files changed, 29 insertions, 4 deletions
diff --git a/sbin/pfctl/parse.y b/sbin/pfctl/parse.y
index 75db2d1eb42..873e30b62d5 100644
--- a/sbin/pfctl/parse.y
+++ b/sbin/pfctl/parse.y
@@ -1,4 +1,4 @@
-/* $OpenBSD: parse.y,v 1.78 2002/06/07 23:30:39 dhartmei Exp $ */
+/* $OpenBSD: parse.y,v 1.79 2002/06/08 00:23:41 henning Exp $ */
/*
* Copyright (c) 2001 Markus Friedl. All rights reserved.
@@ -113,8 +113,9 @@ int yyparse(void);
void ipmask(struct pf_addr *, u_int8_t);
void expand_label_addr(const char *, char *, u_int8_t, struct node_host *);
void expand_label_port(const char *, char *, u_int8_t, struct node_port *);
+void expand_label_proto(const char *, char *, u_int8_t);
void expand_label(char *, u_int8_t, struct node_host *, struct node_port *,
- struct node_host *, struct node_port *);
+ struct node_host *, struct node_port *, u_int8_t);
void expand_rule(struct pf_rule *, struct node_if *, struct node_proto *,
struct node_host *, struct node_port *, struct node_host *,
struct node_port *, struct node_uid *, struct node_gid *,
@@ -1708,14 +1709,38 @@ expand_label_port(const char *name, char *label, u_int8_t af,
}
void
+expand_label_proto(const char *name, char *label, u_int8_t proto)
+{
+ char tmp[PF_RULE_LABEL_SIZE];
+ char *p;
+ struct protoent *pe;
+
+ while ((p = strstr(label, name)) != NULL) {
+ tmp[0] = 0;
+ strlcat(tmp, label, p-label+1);
+ pe = getprotobynumber(proto);
+ if (pe != NULL)
+ strlcat(tmp, pe->p_name, PF_RULE_LABEL_SIZE);
+ else
+ snprintf(tmp+strlen(tmp), PF_RULE_LABEL_SIZE-strlen(tmp),
+ "%u", proto);
+ strlcat(tmp, p+strlen(name), PF_RULE_LABEL_SIZE);
+ strncpy(label, tmp, PF_RULE_LABEL_SIZE);
+ }
+}
+
+
+void
expand_label(char *label, u_int8_t af,
struct node_host *src_host, struct node_port *src_port,
- struct node_host *dst_host, struct node_port *dst_port)
+ struct node_host *dst_host, struct node_port *dst_port,
+ u_int8_t proto)
{
expand_label_addr("$srcaddr", label, af, src_host);
expand_label_addr("$dstaddr", label, af, dst_host);
expand_label_port("$srcport", label, af, src_port);
expand_label_port("$dstport", label, af, dst_port);
+ expand_label_proto("$proto", label, proto);
}
void
@@ -1778,7 +1803,7 @@ expand_rule(struct pf_rule *r,
strlcpy(r->label, label, PF_RULE_LABEL_SIZE);
expand_label(r->label, r->af, src_host, src_port,
- dst_host, dst_port);
+ dst_host, dst_port, proto->proto);
r->proto = proto->proto;
r->src.addr = src_host->addr;
r->src.mask = src_host->mask;