dnsmasq: load instance-specific conf-file if exists
[openwrt/openwrt.git] / package / network / services / dnsmasq / Makefile
1 #
2 # Copyright (C) 2006-2016 OpenWrt.org
3 #
4 # This is free software, licensed under the GNU General Public License v2.
5 # See /LICENSE for more information.
6 #
7
8 include $(TOPDIR)/rules.mk
9
10 PKG_NAME:=dnsmasq
11 PKG_VERSION:=2.78
12 PKG_RELEASE:=3
13
14 PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.xz
15 PKG_SOURCE_URL:=http://thekelleys.org.uk/dnsmasq/
16 PKG_HASH:=89949f438c74b0c7543f06689c319484bd126cc4b1f8c745c742ab397681252b
17
18 PKG_LICENSE:=GPL-2.0
19 PKG_LICENSE_FILES:=COPYING
20 PKG_CPE_ID:=cpe:/a:thekelleys:dnsmasq
21
22 PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)-$(BUILD_VARIANT)/$(PKG_NAME)-$(PKG_VERSION)
23
24 PKG_INSTALL:=1
25 PKG_BUILD_PARALLEL:=1
26 PKG_CONFIG_DEPENDS:=CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dhcpv6 \
27 CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dnssec \
28 CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_auth \
29 CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_ipset \
30 CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_conntrack \
31 CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_noid \
32 CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_broken_rtc
33
34 include $(INCLUDE_DIR)/package.mk
35
36 define Package/dnsmasq/Default
37 SECTION:=net
38 CATEGORY:=Base system
39 TITLE:=DNS and DHCP server
40 URL:=http://www.thekelleys.org.uk/dnsmasq/
41 DEPENDS:=+libubus
42 USERID:=dnsmasq=453:dnsmasq=453
43 endef
44
45 define Package/dnsmasq
46 $(call Package/dnsmasq/Default)
47 VARIANT:=nodhcpv6
48 endef
49
50 define Package/dnsmasq-dhcpv6
51 $(call Package/dnsmasq/Default)
52 TITLE += (with DHCPv6 support)
53 DEPENDS+=@IPV6
54 VARIANT:=dhcpv6
55 endef
56
57 define Package/dnsmasq-full
58 $(call Package/dnsmasq/Default)
59 TITLE += (with DNSSEC, DHCPv6, Auth DNS, IPset, Conntrack, NO_ID enabled by default)
60 DEPENDS+=+PACKAGE_dnsmasq_full_dnssec:libnettle \
61 +PACKAGE_dnsmasq_full_ipset:kmod-ipt-ipset \
62 +PACKAGE_dnsmasq_full_conntrack:libnetfilter-conntrack
63 VARIANT:=full
64 endef
65
66 define Package/dnsmasq/description
67 It is intended to provide coupled DNS and DHCP service to a LAN.
68 endef
69
70 define Package/dnsmasq-dhcpv6/description
71 $(call Package/dnsmasq/description)
72
73 This is a variant with DHCPv6 support
74 endef
75
76 define Package/dnsmasq-full/description
77 $(call Package/dnsmasq/description)
78
79 This is a fully configurable variant with DHCPv6, DNSSEC, Authoritative DNS and
80 IPset, Conntrack support & NO_ID enabled by default.
81 endef
82
83 define Package/dnsmasq/conffiles
84 /etc/config/dhcp
85 /etc/dnsmasq.conf
86 endef
87
88 define Package/dnsmasq-full/config
89 if PACKAGE_dnsmasq-full
90 config PACKAGE_dnsmasq_full_dhcpv6
91 bool "Build with DHCPv6 support."
92 depends on IPV6
93 default y
94 config PACKAGE_dnsmasq_full_dnssec
95 bool "Build with DNSSEC support."
96 default y
97 config PACKAGE_dnsmasq_full_auth
98 bool "Build with the facility to act as an authoritative DNS server."
99 default y
100 config PACKAGE_dnsmasq_full_ipset
101 bool "Build with IPset support."
102 default y
103 config PACKAGE_dnsmasq_full_conntrack
104 bool "Build with Conntrack support."
105 default y
106 config PACKAGE_dnsmasq_full_noid
107 bool "Build with NO_ID. (hide *.bind pseudo domain)"
108 default y
109 config PACKAGE_dnsmasq_full_broken_rtc
110 bool "Build with HAVE_BROKEN_RTC."
111 default n
112 endif
113 endef
114
115 Package/dnsmasq-dhcpv6/conffiles = $(Package/dnsmasq/conffiles)
116 Package/dnsmasq-full/conffiles = $(Package/dnsmasq/conffiles)
117
118 TARGET_CFLAGS += -ffunction-sections -fdata-sections
119 TARGET_LDFLAGS += -Wl,--gc-sections
120
121 COPTS = $(if $(CONFIG_IPV6),,-DNO_IPV6)
122
123 ifeq ($(BUILD_VARIANT),nodhcpv6)
124 COPTS += -DNO_DHCP6
125 endif
126
127 ifeq ($(BUILD_VARIANT),full)
128 COPTS += $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dhcpv6),,-DNO_DHCP6) \
129 $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_dnssec),-DHAVE_DNSSEC) \
130 $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_auth),,-DNO_AUTH) \
131 $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_ipset),,-DNO_IPSET) \
132 $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_conntrack),-DHAVE_CONNTRACK,) \
133 $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_noid),-DNO_ID,) \
134 $(if $(CONFIG_PACKAGE_dnsmasq_$(BUILD_VARIANT)_broken_rtc),-DHAVE_BROKEN_RTC)
135 COPTS += $(if $(CONFIG_LIBNETTLE_MINI),-DNO_GMP,)
136 else
137 COPTS += -DNO_AUTH -DNO_IPSET -DNO_ID
138 endif
139
140 MAKE_FLAGS := \
141 $(TARGET_CONFIGURE_OPTS) \
142 CFLAGS="$(TARGET_CFLAGS) $(TARGET_CPPFLAGS)" \
143 LDFLAGS="$(TARGET_LDFLAGS)" \
144 COPTS="$(COPTS)" \
145 PREFIX="/usr"
146
147 define Package/dnsmasq/install
148 $(INSTALL_DIR) $(1)/usr/sbin
149 $(CP) $(PKG_INSTALL_DIR)/usr/sbin/dnsmasq $(1)/usr/sbin/
150 $(INSTALL_DIR) $(1)/etc/config
151 $(INSTALL_DATA) ./files/dhcp.conf $(1)/etc/config/dhcp
152 $(INSTALL_DATA) ./files/dnsmasq.conf $(1)/etc/dnsmasq.conf
153 $(INSTALL_DIR) $(1)/etc/init.d
154 $(INSTALL_BIN) ./files/dnsmasq.init $(1)/etc/init.d/dnsmasq
155 $(INSTALL_DIR) $(1)/etc/hotplug.d/dhcp
156 $(INSTALL_DIR) $(1)/etc/hotplug.d/neigh
157 $(INSTALL_DIR) $(1)/etc/hotplug.d/ntp
158 $(INSTALL_DIR) $(1)/etc/hotplug.d/tftp
159 $(INSTALL_DATA) ./files/dnsmasqsec.hotplug $(1)/etc/hotplug.d/ntp/25-dnsmasqsec
160 $(INSTALL_DIR) $(1)/usr/share/dnsmasq
161 $(INSTALL_DATA) ./files/rfc6761.conf $(1)/usr/share/dnsmasq/
162 $(INSTALL_DIR) $(1)/usr/lib/dnsmasq
163 $(INSTALL_BIN) ./files/dhcp-script.sh $(1)/usr/lib/dnsmasq/dhcp-script.sh
164 $(INSTALL_DIR) $(1)/usr/share/acl.d
165 $(INSTALL_DATA) ./files/dnsmasq_acl.json $(1)/usr/share/acl.d/
166 endef
167
168 Package/dnsmasq-dhcpv6/install = $(Package/dnsmasq/install)
169
170 define Package/dnsmasq-full/install
171 $(call Package/dnsmasq/install,$(1))
172 ifneq ($(CONFIG_PACKAGE_dnsmasq_full_dnssec),)
173 $(INSTALL_DIR) $(1)/usr/share/dnsmasq
174 $(INSTALL_DATA) $(PKG_BUILD_DIR)/trust-anchors.conf $(1)/usr/share/dnsmasq
175 endif
176 endef
177
178 $(eval $(call BuildPackage,dnsmasq))
179 $(eval $(call BuildPackage,dnsmasq-dhcpv6))
180 $(eval $(call BuildPackage,dnsmasq-full))