Blame __dist_sample/sample/dns.c

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
}