NetBSD/dist/ipf/lib/getport.c

82 lines
1.7 KiB
C
Raw Normal View History

2010-04-18 01:00:08 +04:00
/* $NetBSD: getport.c,v 1.7 2010/04/17 21:00:09 darrenr Exp $ */
2007-04-15 00:34:18 +04:00
/*
* Copyright (C) 2002-2005 by Darren Reed.
2010-04-18 01:00:08 +04:00
*
* See the IPFILTER.LICENCE file for details on licencing.
*
* Id: getport.c,v 1.1.4.7 2009/12/27 06:58:06 darrenr Exp
*/
2007-04-15 00:34:18 +04:00
2004-03-28 12:55:20 +04:00
#include "ipf.h"
2005-04-03 19:05:30 +04:00
int getport(fr, name, port)
frentry_t *fr;
2004-03-28 12:55:20 +04:00
char *name;
2005-04-03 19:05:30 +04:00
u_short *port;
2004-03-28 12:55:20 +04:00
{
struct protoent *p;
2004-03-28 12:55:20 +04:00
struct servent *s;
u_short p1;
if (fr == NULL || fr->fr_type != FR_T_IPF) {
s = getservbyname(name, NULL);
2005-04-03 19:05:30 +04:00
if (s != NULL) {
*port = s->s_port;
return 0;
}
2004-07-23 09:39:03 +04:00
return -1;
}
2004-03-28 12:55:20 +04:00
2006-04-04 20:17:18 +04:00
/*
* Some people will use port names in rules without specifying
* either TCP or UDP because it is implied by the group head.
* If we don't know the protocol, then the best we can do here is
* to take either only the TCP or UDP mapping (if one or the other
* is missing) or make sure both of them agree.
*/
if (fr->fr_proto == 0) {
s = getservbyname(name, "tcp");
if (s != NULL)
p1 = s->s_port;
else
p1 = 0;
s = getservbyname(name, "udp");
if (s != NULL) {
if (p1 != s->s_port)
return -1;
}
if ((p1 == 0) && (s == NULL))
return -1;
if (p1)
*port = p1;
else
*port = s->s_port;
return 0;
}
if ((fr->fr_flx & FI_TCPUDP) != 0) {
/*
* If a rule is "tcp/udp" then check that both TCP and UDP
* mappings for this protocol name match ports.
*/
s = getservbyname(name, "tcp");
if (s == NULL)
2004-07-23 09:39:03 +04:00
return -1;
p1 = s->s_port;
s = getservbyname(name, "udp");
if (s == NULL || s->s_port != p1)
2004-07-23 09:39:03 +04:00
return -1;
2005-04-03 19:05:30 +04:00
*port = p1;
return 0;
}
p = getprotobynumber(fr->fr_proto);
s = getservbyname(name, p ? p->p_name : NULL);
2005-04-03 19:05:30 +04:00
if (s != NULL) {
*port = s->s_port;
return 0;
}
2004-07-23 09:39:03 +04:00
return -1;
2004-03-28 12:55:20 +04:00
}