diff options
Diffstat (limited to 'sys')
-rw-r--r-- | sys/net/pf.c | 65 | ||||
-rw-r--r-- | sys/net/pfvar.h | 14 |
2 files changed, 48 insertions, 31 deletions
diff --git a/sys/net/pf.c b/sys/net/pf.c index 50400f337e5..910798a6cd6 100644 --- a/sys/net/pf.c +++ b/sys/net/pf.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pf.c,v 1.206 2002/05/09 19:58:42 dhartmei Exp $ */ +/* $OpenBSD: pf.c,v 1.207 2002/05/12 00:54:56 dhartmei Exp $ */ /* * Copyright (c) 2001 Daniel Hartmeier @@ -276,7 +276,7 @@ int pf_normalize_tcp(int, struct ifnet *, struct mbuf *, int, int, void *, struct pf_pdesc *); void pf_route(struct mbuf **, struct pf_rule *, int); void pf_route6(struct mbuf **, struct pf_rule *, int); -int pf_user_lookup(uid_t *, uid_t *, int, int, int, +int pf_socket_lookup(uid_t *, gid_t *, int, int, int, struct pf_pdesc *); @@ -2972,7 +2972,7 @@ pf_match_port(u_int8_t op, u_int16_t a1, u_int16_t a2, u_int16_t p) } int -pf_match_uid(u_int8_t op, u_int16_t a1, u_int16_t a2, u_int16_t u) +pf_match_uid(u_int8_t op, uid_t a1, uid_t a2, uid_t u) { if (u == UID_MAX && op != PF_OP_EQ && op != PF_OP_NE) return (0); @@ -2980,6 +2980,14 @@ pf_match_uid(u_int8_t op, u_int16_t a1, u_int16_t a2, u_int16_t u) } int +pf_match_gid(u_int8_t op, gid_t a1, gid_t a2, gid_t g) +{ + if (g == GID_MAX && op != PF_OP_EQ && op != PF_OP_NE) + return (0); + return (pf_match(op, a1, a2, g)); +} + +int pf_chk_sport(struct pf_port_list *plist, u_int16_t port) { struct pf_port_node *pnode; @@ -3195,7 +3203,7 @@ pf_map_port_range(struct pf_rdr *rdr, u_int16_t port) } int -pf_user_lookup(uid_t *ruid, uid_t *euid, int direction, int af, int proto, +pf_socket_lookup(uid_t *uid, gid_t *gid, int direction, int af, int proto, struct pf_pdesc *pd) { struct pf_addr *saddr, *daddr; @@ -3203,7 +3211,8 @@ pf_user_lookup(uid_t *ruid, uid_t *euid, int direction, int af, int proto, struct inpcbtable *tb; struct inpcb *inp; - *ruid = *euid = UID_MAX; + *uid = UID_MAX; + *gid = GID_MAX; if (af != AF_INET) return (0); switch (proto) { @@ -3239,8 +3248,8 @@ pf_user_lookup(uid_t *ruid, uid_t *euid, int direction, int af, int proto, if (inp == NULL) return (0); } - *ruid = inp->inp_socket->so_ruid; - *euid = inp->inp_socket->so_euid; + *uid = inp->inp_socket->so_euid; + *gid = inp->inp_socket->so_egid; return (1); } @@ -3254,8 +3263,9 @@ pf_test_tcp(struct pf_rule **rm, int direction, struct ifnet *ifp, struct pf_addr *saddr = pd->src, *daddr = pd->dst, baddr; struct tcphdr *th = pd->hdr.tcp; u_int16_t bport, nport = 0, af = pd->af; - int xuid = -1; - uid_t ruid, euid; + int lookup = -1; + uid_t uid; + gid_t gid; struct pf_rule *r; u_short reason; int rewrite = 0, error; @@ -3348,15 +3358,15 @@ pf_test_tcp(struct pf_rule **rm, int direction, struct ifnet *ifp, r = TAILQ_NEXT(r, entries); else if ((r->flagset & th->th_flags) != r->flags) r = TAILQ_NEXT(r, entries); - else if (r->ruid.op && (xuid != -1 || (xuid = - pf_user_lookup(&ruid, &euid, direction, af, IPPROTO_TCP, pd), - 1)) && !pf_match_uid(r->ruid.op, r->ruid.uid[0], - r->ruid.uid[1], ruid)) + else if (r->uid.op && (lookup != -1 || (lookup = + pf_socket_lookup(&uid, &gid, direction, af, IPPROTO_TCP, pd), + 1)) && !pf_match_uid(r->uid.op, r->uid.uid[0], + r->uid.uid[1], uid)) r = TAILQ_NEXT(r, entries); - else if (r->euid.op && (xuid != -1 || (xuid = - pf_user_lookup(&ruid, &euid, direction, af, IPPROTO_TCP, pd), - 1)) && !pf_match_uid(r->euid.op, r->euid.uid[0], - r->euid.uid[1], euid)) + else if (r->gid.op && (lookup != -1 || (lookup = + pf_socket_lookup(&uid, &gid, direction, af, IPPROTO_TCP, pd), + 1)) && !pf_match_gid(r->gid.op, r->gid.gid[0], + r->gid.gid[1], gid)) r = TAILQ_NEXT(r, entries); else { *rm = r; @@ -3500,8 +3510,9 @@ pf_test_udp(struct pf_rule **rm, int direction, struct ifnet *ifp, struct pf_addr *saddr = pd->src, *daddr = pd->dst, baddr; struct udphdr *uh = pd->hdr.udp; u_int16_t bport, nport = 0, af = pd->af; - int xuid = -1; - uid_t ruid, euid; + int lookup = -1; + uid_t uid; + gid_t gid; struct pf_rule *r; u_short reason; int rewrite = 0, error; @@ -3595,15 +3606,15 @@ pf_test_udp(struct pf_rule **rm, int direction, struct ifnet *ifp, r = r->skip[PF_SKIP_DST_PORT]; else if (r->rule_flag & PFRULE_FRAGMENT) r = TAILQ_NEXT(r, entries); - else if (r->ruid.op && (xuid != -1 || (xuid = - pf_user_lookup(&ruid, &euid, direction, af, IPPROTO_UDP, pd), - 1)) && !pf_match_uid(r->ruid.op, r->ruid.uid[0], - r->ruid.uid[1], ruid)) + else if (r->uid.op && (lookup != -1 || (lookup = + pf_socket_lookup(&uid, &gid, direction, af, IPPROTO_UDP, pd), + 1)) && !pf_match_uid(r->uid.op, r->uid.uid[0], + r->uid.uid[1], uid)) r = TAILQ_NEXT(r, entries); - else if (r->euid.op && (xuid != -1 || (xuid = - pf_user_lookup(&ruid, &euid, direction, af, IPPROTO_UDP, pd), - 1)) && !pf_match_uid(r->euid.op, r->euid.uid[0], - r->euid.uid[1], euid)) + else if (r->gid.op && (lookup != -1 || (lookup = + pf_socket_lookup(&uid, &gid, direction, af, IPPROTO_UDP, pd), + 1)) && !pf_match_gid(r->gid.op, r->gid.gid[0], + r->gid.gid[1], gid)) r = TAILQ_NEXT(r, entries); else { *rm = r; diff --git a/sys/net/pfvar.h b/sys/net/pfvar.h index d6a7726144f..40ed54aefcb 100644 --- a/sys/net/pfvar.h +++ b/sys/net/pfvar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: pfvar.h,v 1.71 2002/05/09 21:58:12 jasoni Exp $ */ +/* $OpenBSD: pfvar.h,v 1.72 2002/05/12 00:54:56 dhartmei Exp $ */ /* * Copyright (c) 2001 Daniel Hartmeier @@ -201,6 +201,11 @@ struct pf_rule_uid { u_int8_t op; }; +struct pf_rule_gid { + uid_t gid[2]; + u_int8_t op; +}; + struct pf_rule_addr { struct pf_addr_wrap addr; struct pf_addr mask; @@ -242,8 +247,8 @@ struct pf_rule { u_int16_t return_icmp; u_int16_t max_mss; - struct pf_rule_uid ruid; - struct pf_rule_uid euid; + struct pf_rule_uid uid; + struct pf_rule_gid gid; u_int8_t action; u_int8_t direction; @@ -626,7 +631,8 @@ int pf_match_addr(u_int8_t, struct pf_addr *, struct pf_addr *, struct pf_addr *, int); int pf_match(u_int8_t, u_int16_t, u_int16_t, u_int16_t); int pf_match_port(u_int8_t, u_int16_t, u_int16_t, u_int16_t); -int pf_match_uid(u_int8_t, u_int16_t, u_int16_t, u_int16_t); +int pf_match_uid(u_int8_t, uid_t, uid_t, uid_t); +int pf_match_gid(u_int8_t, gid_t, gid_t, gid_t); void pf_normalize_init(void); int pf_normalize_ip(struct mbuf **, int, struct ifnet *, u_short *); |