File: ipcheck.c

package info (click to toggle)
libreswan 5.2-2.3
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 81,644 kB
  • sloc: ansic: 129,988; sh: 32,018; xml: 20,646; python: 10,303; makefile: 3,022; javascript: 1,506; sed: 574; yacc: 511; perl: 264; awk: 52
file content (87 lines) | stat: -rw-r--r-- 2,139 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
/* test IP code, for libreswan
 *
 * Copyright (C) 2000  Henry Spencer.
 * Copyright (C) 2012 Paul Wouters <paul@libreswan.org>
 * Copyright (C) 2018 Andrew Cagney
 *
 * This library is free software; you can redistribute it and/or modify it
 * under the terms of the GNU Library General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or (at your
 * option) any later version.  See <https://www.gnu.org/licenses/lgpl-2.1.txt>.
 *
 * This library is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
 * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Library General Public
 * License for more details.
 *
 */

#include <stdio.h>

#include "constants.h"
#include "ip_address.h"
#include "stdlib.h"
#include "ipcheck.h"
#include "lswtool.h"
#include "lswalloc.h"		/* for leak_detective; */

unsigned fails;
enum have_dns have_dns = DNS_NO;

int main(int argc, char *argv[])
{
	leak_detective = true;
	log_ip = false; /* force sensitive */
	struct logger *logger = tool_logger(argc, argv);

	if (argc != 2) {
		fprintf(stderr, "usage: %s --dns={no,hosts-file,yes}\n", argv[0]);
		return 1;
	}

	/* only one option for now */
	const char *dns = argv[1];
	if (!eat(dns, "--dns")) {
		fprintf(stderr, "%s: unknown option '%s'\n",
			argv[0], argv[1]);
		return 1;
	}

	if (streq(dns, "=no")) {
		have_dns = DNS_NO;
	} else if (streq(dns, "=hosts-file") || streq(dns, "")) {
		have_dns = HAVE_HOSTS_FILE;
	} else if (streq(dns, "=yes")) {
		have_dns = DNS_YES;
	} else {
		fprintf(stderr, "%s: unknown --dns param '%s'\n",
			argv[0], dns);
		return 1;
	}

	ip_address_check();
	ip_endpoint_check();
	ip_range_check(logger);
	ip_subnet_check(logger);
	ip_said_check();
	ip_info_check();
	ip_protoport_check();
	ip_selector_check(logger);
	ip_sockaddr_check();
	ip_port_check();
	ip_port_range_check();
	ip_cidr_check();
	ip_protocol_check();
	ip_packet_check();

	if (report_leaks(logger)) {
		fails++;
	}

	if (fails > 0) {
		fprintf(stderr, "TOTAL FAILURES: %d\n", fails);
		return 1;
	} else {
		return 0;
	}
}