115bd2a018afcc33fcefff0f5c1460ca60b166df
[project/mdnsd.git] / main.c
1 /*
2 * Copyright (C) 2014 John Crispin <blogic@openwrt.org>
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU Lesser General Public License version 2.1
6 * as published by the Free Software Foundation
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 */
13
14 #include <sys/stat.h>
15 #include <sys/types.h>
16
17 #include <time.h>
18 #include <stdio.h>
19 #include <fcntl.h>
20 #include <getopt.h>
21 #include <resolv.h>
22 #include <unistd.h>
23 #include <sys/types.h>
24 #include <arpa/inet.h>
25 #include <sys/socket.h>
26 #include <netinet/in.h>
27 #include <arpa/nameser.h>
28 #include <asm/byteorder.h>
29
30 #include <libubus.h>
31 #include <libubox/uloop.h>
32
33 #include "dns.h"
34 #include "ubus.h"
35 #include "util.h"
36 #include "cache.h"
37 #include "service.h"
38 #include "announce.h"
39 #include "interface.h"
40
41 static char *iface_name = "eth0";
42
43 int
44 main(int argc, char **argv)
45 {
46 int ch, ttl;
47
48 while ((ch = getopt(argc, argv, "t:i:d")) != -1) {
49 switch (ch) {
50 case 't':
51 ttl = atoi(optarg);
52 if (ttl > 0)
53 announce_ttl = ttl;
54 else
55 fprintf(stderr, "invalid ttl\n");
56 break;
57 case 'd':
58 debug++;
59 break;
60 case 'i':
61 iface_name = optarg;
62 break;
63 }
64 }
65
66 if (!iface_name)
67 return -1;
68
69 uloop_init();
70
71 if (interface_add(iface_name)) {
72 fprintf(stderr, "Failed to add interface %s\n", iface_name);
73 return -1;
74 }
75
76 signal_setup();
77
78 if (cache_init())
79 return -1;
80
81 service_init();
82
83 ubus_startup();
84 uloop_run();
85 uloop_done();
86
87 cache_cleanup();
88 service_cleanup();
89 vlist_flush(&interfaces);
90
91 return 0;
92 }