42-archive/nmap/srcs/parser.c
2017-09-26 18:59:18 +02:00

137 lines
3.2 KiB
C

#include "nmap.h"
static t_cliopts g_opts[] =
{
{'h', "host", 0, 0, nmap_get_host, 0},
/* {'f', "file", 0, 0, nmap_get_file, 0}, */
/* {'p', "ports", 0, 0, nmap_get_ports, 0}, */
{'t', "threads", 0, 0, nmap_get_threads, 0},
{'s', "scan", 0, 0, nmap_get_scan, 0},
{0, 0, 0, 0, 0, 0},
};
static int nmap_get_host(char *node, t_data *data)
{
t_host host;
struct addrinfo *servinfo, hints;
memset (&hints, 0, sizeof (hints));
hints.ai_family = PF_UNSPEC;
hints.ai_socktype = SOCK_RAW;
hints.ai_flags = AI_CANONNAME;
if (getaddrinfo(node, NULL, &hints, &servinfo))
{
fprintf(stderr, "Failed to resolve \"%s\"\n", node);
return (1);
}
host.addr = servinfo->ai_addr;
host.addrlen = servinfo->ai_addrlen;
host.node = node;
host.dn = servinfo->ai_canonname;
void *addr;
if (servinfo->ai_family == AF_INET) { // IPv4
struct sockaddr_in *ipv4 = (struct sockaddr_in *)servinfo->ai_addr;
addr = &(ipv4->sin_addr);
} else { // IPv6
struct sockaddr_in6 *ipv6 = (struct sockaddr_in6 *)servinfo->ai_addr;
addr = &(ipv6->sin6_addr);
}
// convert the IP to a string and print it:
inet_ntop(servinfo->ai_family, addr, host.ip, sizeof(host.ip));
printf("dn=%s, ip=%s\n", host.dn, host.ip);
/* MUST DO rDNS search here */
/* printf("rDNS record for %s: %s\n", addrstr, DOMAIN NAME WITH RDNS); */
ft_lsteadd(&data->host, ft_lstnew(&host, sizeof(host)));
return (0);
}
/* int nmap_get_file(char *opt_arg, t_data *data) */
/* { */
/* } */
/* int nmap_get_ports(char *opt_arg, t_data *data) */
/* { */
/* } */
static int nmap_get_threads(char *opt_arg, t_data *data)
{
data->threads = ft_atoi(opt_arg);
return (0);
}
static int nmap_get_scan(char *opt_arg, t_data *data)
{
while (*opt_arg)
{
if (*opt_arg == 'T')
data->scan |= SCAN_TCP;
else if (*opt_arg == 'S')
data->scan |= SCAN_SYN;
else if (*opt_arg == 'N')
data->scan |= SCAN_NULL;
else if (*opt_arg == 'A')
data->scan |= SCAN_ACK;
else if (*opt_arg == 'F')
data->scan |= SCAN_FIN;
else if (*opt_arg == 'X')
data->scan |= SCAN_XMAS;
else if (*opt_arg == 'U')
data->scan |= SCAN_UDP;
else
return (1);
opt_arg++;
}
return (0);
}
int nmap_parse(int ac, char **av, t_data *data)
{
struct ifaddrs *ifaddrs, *ifa_first;
(void)ac;
data->host = NULL;
bzero(data->ports, USHRT_MAX + 1);
data->threads = 0;
data->scan = 0;
if (cliopts_get(av, g_opts, data))
return (ft_perror("nmap"));
if (!data->host && data->av_data && data->av_data)
nmap_get_host(*data->av_data, data);
if (!data->scan)
data->scan = SCAN_TCP;
getifaddrs(&ifa_first);
for (ifaddrs = ifa_first; ifaddrs && ifaddrs->ifa_flags & IFF_LOOPBACK; ifaddrs = ifaddrs->ifa_next)
;
if (ifaddrs)
{
ifaddrs=ifaddrs->ifa_next;
printf("if=%s\n", ifaddrs->ifa_name);
data->source_addr = *ifaddrs->ifa_addr;
}
else
{
fprintf(stderr, "couldn't find an internet interface\n");
exit(1);
}
freeifaddrs(ifa_first);
for (t_list *list = data->host; list != NULL; list = list->next)
{
t_host *host = list->content;
printf("scanning %s...\n", host->dn);
for (port = 1; port < USHRT_MAX; port++;)
{
if (data.ports[port])
host->channels[port] = chmake(sizeof(t_tcp_packet));
}
}
return (0);
}