summaryrefslogtreecommitdiff
path: root/usr.sbin/tcpdrop/tcpdrop.c
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin/tcpdrop/tcpdrop.c')
-rw-r--r--usr.sbin/tcpdrop/tcpdrop.c70
1 files changed, 53 insertions, 17 deletions
diff --git a/usr.sbin/tcpdrop/tcpdrop.c b/usr.sbin/tcpdrop/tcpdrop.c
index 5857446f0bb..578b69ae94c 100644
--- a/usr.sbin/tcpdrop/tcpdrop.c
+++ b/usr.sbin/tcpdrop/tcpdrop.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: tcpdrop.c,v 1.5 2006/01/03 01:46:27 stevesk Exp $ */
+/* $OpenBSD: tcpdrop.c,v 1.6 2007/03/25 17:20:27 deraadt Exp $ */
/*
* Copyright (c) 2004 Markus Friedl <markus@openbsd.org>
@@ -44,26 +44,60 @@ main(int argc, char **argv)
struct addrinfo hints, *ail, *aif, *laddr, *faddr;
char fhbuf[NI_MAXHOST], fsbuf[NI_MAXSERV];
char lhbuf[NI_MAXHOST], lsbuf[NI_MAXSERV];
+ char *laddr1, *addr1, *port1, *laddr2, *addr2, *port2;
struct tcp_ident_mapping tir;
int gaierr, rval = 0;
- if (argc != 5) {
+ memset(&hints, 0, sizeof(hints));
+ hints.ai_family = AF_UNSPEC;
+ hints.ai_socktype = SOCK_STREAM;
+
+ if (argc == 3) {
+ laddr1 = addr1 = strdup(argv[1]);
+ port1 = strrchr(addr1, ':');
+ if (port1)
+ *port1++ = '\0';
+ else
+ goto fail;
+
+ laddr2 = addr2 = strdup(argv[2]);
+ port2 = strrchr(addr2, ':');
+ if (port2)
+ *port2++ = '\0';
+ else
+ goto fail;
+ } else if (argc == 5) {
+ laddr1 = addr1 = argv[1];
+ port1 = argv[2];
+ laddr2 = addr2 = argv[3];
+ port2 = argv[4];
+ } else {
+fail:
fprintf(stderr, "usage: %s laddr lport faddr fport\n",
__progname);
+ fprintf(stderr, " %s laddr:lport faddr:fport\n",
+ __progname);
exit(1);
}
- memset(&hints, 0, sizeof(hints));
- hints.ai_family = AF_UNSPEC;
- hints.ai_socktype = SOCK_STREAM;
+ if (addr1[0] == '[' && addr1[strlen(addr1) - 1] == ']') {
+ laddr1 = strdup(addr1);
+ laddr1[strlen(laddr1) - 1] = '\0';
+ laddr1++;
+ }
+ if (addr2[0] == '[' && addr2[strlen(addr2) - 1] == ']') {
+ laddr2 = strdup(addr2);
+ laddr2[strlen(laddr2) - 1] = '\0';
+ laddr2++;
+ }
- if ((gaierr = getaddrinfo(argv[1], argv[2], &hints, &laddr)) != 0)
- errx(1, "%s port %s: %s", argv[1], argv[2],
+ if ((gaierr = getaddrinfo(laddr1, port1, &hints, &laddr)) != 0)
+ errx(1, "%s port %s: %s", addr1, port1,
gai_strerror(gaierr));
- if ((gaierr = getaddrinfo(argv[3], argv[4], &hints, &faddr)) != 0) {
+ if ((gaierr = getaddrinfo(laddr2, port2, &hints, &faddr)) != 0) {
freeaddrinfo(laddr);
- errx(1, "%s port %s: %s", argv[3], argv[4],
+ errx(1, "%s port %s: %s", addr2, port2,
gai_strerror(gaierr));
}
@@ -75,13 +109,11 @@ main(int argc, char **argv)
memcpy(&tir.laddr, ail->ai_addr, ail->ai_addrlen);
if ((gaierr = getnameinfo(aif->ai_addr, aif->ai_addrlen,
- fhbuf, sizeof(fhbuf),
- fsbuf, sizeof(fsbuf),
+ fhbuf, sizeof(fhbuf), fsbuf, sizeof(fsbuf),
NI_NUMERICHOST | NI_NUMERICSERV)) != 0)
errx(1, "getnameinfo: %s", gai_strerror(gaierr));
if ((gaierr = getnameinfo(ail->ai_addr, ail->ai_addrlen,
- lhbuf, sizeof(lhbuf),
- lsbuf, sizeof(lsbuf),
+ lhbuf, sizeof(lhbuf), lsbuf, sizeof(lsbuf),
NI_NUMERICHOST | NI_NUMERICSERV)) != 0)
errx(1, "getnameinfo: %s", gai_strerror(gaierr));
@@ -89,10 +121,14 @@ main(int argc, char **argv)
NULL, &tir, sizeof(tir)) == -1) {
rval = 1;
warn("%s %s %s %s", lhbuf, lsbuf, fhbuf, fsbuf);
- } else
- printf("%s %s %s %s: dropped\n",
- lhbuf, lsbuf, fhbuf, fsbuf);
-
+ } else {
+ if (aif->ai_family == PF_INET6)
+ printf("[%s]:%s [%s]:%s dropped\n",
+ lhbuf, lsbuf, fhbuf, fsbuf);
+ else
+ printf("%s:%s %s:%s dropped\n",
+ lhbuf, lsbuf, fhbuf, fsbuf);
+ }
}
}
freeaddrinfo(laddr);