|
Packit Service |
b25606 |
/*
|
|
Packit Service |
b25606 |
*
|
|
Packit Service |
b25606 |
* libnet 1.1
|
|
Packit Service |
b25606 |
* Build a DNSv4 packet
|
|
Packit Service |
b25606 |
* To view: /usr/sbin/tcpdump -vvvvven -s 0 port 53
|
|
Packit Service |
b25606 |
*
|
|
Packit Service |
b25606 |
* Copyright (c) 2003 Frédéric Raynal <pappy@security-labs.org>
|
|
Packit Service |
b25606 |
* All rights reserved.
|
|
Packit Service |
b25606 |
*
|
|
Packit Service |
b25606 |
* Redistribution and use in source and binary forms, with or without
|
|
Packit Service |
b25606 |
* modification, are permitted provided that the following conditions
|
|
Packit Service |
b25606 |
* are met:
|
|
Packit Service |
b25606 |
* 1. Redistributions of source code must retain the above copyright
|
|
Packit Service |
b25606 |
* notice, this list of conditions and the following disclaimer.
|
|
Packit Service |
b25606 |
* 2. Redistributions in binary form must reproduce the above copyright
|
|
Packit Service |
b25606 |
* notice, this list of conditions and the following disclaimer in the
|
|
Packit Service |
b25606 |
* documentation and/or other materials provided with the distribution.
|
|
Packit Service |
b25606 |
*
|
|
Packit Service |
b25606 |
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
Packit Service |
b25606 |
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
Packit Service |
b25606 |
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
Packit Service |
b25606 |
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
Packit Service |
b25606 |
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
Packit Service |
b25606 |
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
Packit Service |
b25606 |
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
Packit Service |
b25606 |
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
Packit Service |
b25606 |
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
Packit Service |
b25606 |
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
Packit Service |
b25606 |
* SUCH DAMAGE.
|
|
Packit Service |
b25606 |
*
|
|
Packit Service |
b25606 |
*/
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
#if (HAVE_CONFIG_H)
|
|
Packit Service |
b25606 |
#include "../include/config.h"
|
|
Packit Service |
b25606 |
#endif
|
|
Packit Service |
b25606 |
#include "./libnet_test.h"
|
|
Packit Service |
b25606 |
#ifdef __WIN32__
|
|
Packit Service |
b25606 |
#include "../include/win32/getopt.h"
|
|
Packit Service |
b25606 |
#endif
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
void
|
|
Packit Service |
b25606 |
usage(char *prog)
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
fprintf(stderr, "Usage: %s -d dst_ip -q query_host [-s src_ip] [-t]\n", prog);
|
|
Packit Service |
b25606 |
exit(1);
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
int
|
|
Packit Service |
b25606 |
main(int argc, char *argv[])
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
char c;
|
|
Packit Service |
b25606 |
u_long src_ip = 0, dst_ip = 0;
|
|
Packit Service |
b25606 |
u_short type = LIBNET_UDP_DNSV4_H;
|
|
Packit Service |
b25606 |
libnet_t *l;
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
libnet_ptag_t ip;
|
|
Packit Service |
b25606 |
libnet_ptag_t ptag4; /* TCP or UDP ptag */
|
|
Packit Service |
b25606 |
libnet_ptag_t dns;
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
char errbuf[LIBNET_ERRBUF_SIZE];
|
|
Packit Service |
b25606 |
char *query = NULL;
|
|
Packit Service |
b25606 |
char payload[1024];
|
|
Packit Service |
b25606 |
u_short payload_s;
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
printf("libnet 1.1 packet shaping: DNSv4[raw]\n");
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
/*
|
|
Packit Service |
b25606 |
* Initialize the library. Root priviledges are required.
|
|
Packit Service |
b25606 |
*/
|
|
Packit Service |
b25606 |
l = libnet_init(
|
|
Packit Service |
b25606 |
LIBNET_RAW4, /* injection type */
|
|
Packit Service |
b25606 |
NULL, /* network interface */
|
|
Packit Service |
b25606 |
errbuf); /* error buffer */
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
if (!l)
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
fprintf(stderr, "libnet_init: %s", errbuf);
|
|
Packit Service |
b25606 |
exit(EXIT_FAILURE);
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
/*
|
|
Packit Service |
b25606 |
* parse options
|
|
Packit Service |
b25606 |
*/
|
|
Packit Service |
b25606 |
while ((c = getopt(argc, argv, "d:s:q:t")) != EOF)
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
switch (c)
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
case 'd':
|
|
Packit Service |
b25606 |
if ((dst_ip = libnet_name2addr4(l, optarg, LIBNET_RESOLVE)) == -1)
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
fprintf(stderr, "Bad destination IP address: %s\n", optarg);
|
|
Packit Service |
b25606 |
exit(EXIT_FAILURE);
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
break;
|
|
Packit Service |
b25606 |
case 's':
|
|
Packit Service |
b25606 |
if ((src_ip = libnet_name2addr4(l, optarg, LIBNET_RESOLVE)) == -1)
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
fprintf(stderr, "Bad source IP address: %s\n", optarg);
|
|
Packit Service |
b25606 |
exit(EXIT_FAILURE);
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
break;
|
|
Packit Service |
b25606 |
case 'q':
|
|
Packit Service |
b25606 |
query = optarg;
|
|
Packit Service |
b25606 |
break;
|
|
Packit Service |
b25606 |
case 't':
|
|
Packit Service |
b25606 |
type = LIBNET_TCP_DNSV4_H;
|
|
Packit Service |
b25606 |
break;
|
|
Packit Service |
b25606 |
default:
|
|
Packit Service |
b25606 |
exit(EXIT_FAILURE);
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
if (!src_ip)
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
src_ip = libnet_get_ipaddr4(l);
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
if (!dst_ip || !query)
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
usage(argv[0]);
|
|
Packit Service |
b25606 |
exit(EXIT_FAILURE);
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
/*
|
|
Packit Service |
b25606 |
* build dns payload
|
|
Packit Service |
b25606 |
*/
|
|
Packit Service |
b25606 |
payload_s = snprintf(payload, sizeof payload, "%c%s%c%c%c%c%c",
|
|
Packit Service |
b25606 |
(char)(strlen(query)&0xff), query, 0x00, 0x00, 0x01, 0x00, 0x01);
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
/*
|
|
Packit Service |
b25606 |
* build packet
|
|
Packit Service |
b25606 |
*/
|
|
Packit Service |
b25606 |
dns = libnet_build_dnsv4(
|
|
Packit Service |
b25606 |
type, /* TCP or UDP */
|
|
Packit Service |
b25606 |
0x7777, /* id */
|
|
Packit Service |
b25606 |
0x0100, /* request */
|
|
Packit Service |
b25606 |
1, /* num_q */
|
|
Packit Service |
b25606 |
0, /* num_anws_rr */
|
|
Packit Service |
b25606 |
0, /* num_auth_rr */
|
|
Packit Service |
b25606 |
0, /* num_addi_rr */
|
|
Packit Service |
b25606 |
payload,
|
|
Packit Service |
b25606 |
payload_s,
|
|
Packit Service |
b25606 |
l,
|
|
Packit Service |
b25606 |
0
|
|
Packit Service |
b25606 |
);
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
if (dns == -1)
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
fprintf(stderr, "Can't build DNS packet: %s\n", libnet_geterror(l));
|
|
Packit Service |
b25606 |
goto bad;
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
if (type == LIBNET_TCP_DNSV4_H) /* TCP DNS */
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
ptag4 = libnet_build_tcp(
|
|
Packit Service |
b25606 |
0x6666, /* source port */
|
|
Packit Service |
b25606 |
53, /* destination port */
|
|
Packit Service |
b25606 |
0x01010101, /* sequence number */
|
|
Packit Service |
b25606 |
0x02020202, /* acknowledgement num */
|
|
Packit Service |
b25606 |
TH_PUSH|TH_ACK, /* control flags */
|
|
Packit Service |
b25606 |
32767, /* window size */
|
|
Packit Service |
b25606 |
0, /* checksum */
|
|
Packit Service |
b25606 |
0, /* urgent pointer */
|
|
Packit Service |
b25606 |
LIBNET_TCP_H + LIBNET_TCP_DNSV4_H + payload_s, /* TCP packet size */
|
|
Packit Service |
b25606 |
NULL, /* payload */
|
|
Packit Service |
b25606 |
0, /* payload size */
|
|
Packit Service |
b25606 |
l, /* libnet handle */
|
|
Packit Service |
b25606 |
0); /* libnet id */
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
if (ptag4 == -1)
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
fprintf(stderr, "Can't build UDP header: %s\n", libnet_geterror(l));
|
|
Packit Service |
b25606 |
goto bad;
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
ip = libnet_build_ipv4(
|
|
Packit Service |
b25606 |
LIBNET_IPV4_H + LIBNET_TCP_H + type + payload_s,/* length */
|
|
Packit Service |
b25606 |
0, /* TOS */
|
|
Packit Service |
b25606 |
242, /* IP ID */
|
|
Packit Service |
b25606 |
0, /* IP Frag */
|
|
Packit Service |
b25606 |
64, /* TTL */
|
|
Packit Service |
b25606 |
IPPROTO_TCP, /* protocol */
|
|
Packit Service |
b25606 |
0, /* checksum */
|
|
Packit Service |
b25606 |
src_ip, /* source IP */
|
|
Packit Service |
b25606 |
dst_ip, /* destination IP */
|
|
Packit Service |
b25606 |
NULL, /* payload */
|
|
Packit Service |
b25606 |
0, /* payload size */
|
|
Packit Service |
b25606 |
l, /* libnet handle */
|
|
Packit Service |
b25606 |
0); /* libnet id */
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
if (ip == -1)
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
fprintf(stderr, "Can't build IP header: %s\n", libnet_geterror(l));
|
|
Packit Service |
b25606 |
exit(EXIT_FAILURE);
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
else /* UDP DNS */
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
ptag4 = libnet_build_udp(
|
|
Packit Service |
b25606 |
0x6666, /* source port */
|
|
Packit Service |
b25606 |
53, /* destination port */
|
|
Packit Service |
b25606 |
LIBNET_UDP_H + LIBNET_UDP_DNSV4_H + payload_s, /* packet length */
|
|
Packit Service |
b25606 |
0, /* checksum */
|
|
Packit Service |
b25606 |
NULL, /* payload */
|
|
Packit Service |
b25606 |
0, /* payload size */
|
|
Packit Service |
b25606 |
l, /* libnet handle */
|
|
Packit Service |
b25606 |
0); /* libnet id */
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
if (ptag4 == -1)
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
fprintf(stderr, "Can't build UDP header: %s\n", libnet_geterror(l));
|
|
Packit Service |
b25606 |
goto bad;
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
ip = libnet_build_ipv4(
|
|
Packit Service |
b25606 |
LIBNET_IPV4_H + LIBNET_UDP_H + type + payload_s,/* length */
|
|
Packit Service |
b25606 |
0, /* TOS */
|
|
Packit Service |
b25606 |
242, /* IP ID */
|
|
Packit Service |
b25606 |
0, /* IP Frag */
|
|
Packit Service |
b25606 |
64, /* TTL */
|
|
Packit Service |
b25606 |
IPPROTO_UDP, /* protocol */
|
|
Packit Service |
b25606 |
0, /* checksum */
|
|
Packit Service |
b25606 |
src_ip, /* source IP */
|
|
Packit Service |
b25606 |
dst_ip, /* destination IP */
|
|
Packit Service |
b25606 |
NULL, /* payload */
|
|
Packit Service |
b25606 |
0, /* payload size */
|
|
Packit Service |
b25606 |
l, /* libnet handle */
|
|
Packit Service |
b25606 |
0); /* libnet id */
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
if (ip == -1)
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
fprintf(stderr, "Can't build IP header: %s\n", libnet_geterror(l));
|
|
Packit Service |
b25606 |
exit(EXIT_FAILURE);
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
|
|
Packit Service |
b25606 |
/*
|
|
Packit Service |
b25606 |
* write to the wire
|
|
Packit Service |
b25606 |
*/
|
|
Packit Service |
b25606 |
c = libnet_write(l);
|
|
Packit Service |
b25606 |
if (c == -1)
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
fprintf(stderr, "Write error: %s\n", libnet_geterror(l));
|
|
Packit Service |
b25606 |
goto bad;
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
else
|
|
Packit Service |
b25606 |
{
|
|
Packit Service |
b25606 |
fprintf(stderr, "Wrote %d byte DNS packet; check the wire.\n", c);
|
|
Packit Service |
b25606 |
}
|
|
Packit Service |
b25606 |
libnet_destroy(l);
|
|
Packit Service |
b25606 |
return (EXIT_SUCCESS);
|
|
Packit Service |
b25606 |
bad:
|
|
Packit Service |
b25606 |
libnet_destroy(l);
|
|
Packit Service |
b25606 |
return (EXIT_FAILURE);
|
|
Packit Service |
b25606 |
}
|