Initial commit
Some checks failed
Build Kernel / Build all affected Kernels (push) Has been cancelled
Build all core packages / Build all core packages for selected target (push) Has been cancelled
Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
Build Toolchains / Build Toolchains for each target (push) Has been cancelled
Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
Coverity scan build / Coverity x86/64 build (push) Has been cancelled
Some checks failed
Build Kernel / Build all affected Kernels (push) Has been cancelled
Build all core packages / Build all core packages for selected target (push) Has been cancelled
Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
Build Toolchains / Build Toolchains for each target (push) Has been cancelled
Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
Coverity scan build / Coverity x86/64 build (push) Has been cancelled
This commit is contained in:
59
package/network/services/ipset-dns/Makefile
Normal file
59
package/network/services/ipset-dns/Makefile
Normal file
@@ -0,0 +1,59 @@
|
||||
#
|
||||
# Copyright (C) 2013 OpenWrt.org
|
||||
#
|
||||
# This is free software, licensed under the GNU General Public License v2.
|
||||
# See /LICENSE for more information.
|
||||
#
|
||||
|
||||
include $(TOPDIR)/rules.mk
|
||||
|
||||
PKG_NAME:=ipset-dns
|
||||
PKG_RELEASE:=1
|
||||
|
||||
PKG_SOURCE_PROTO:=git
|
||||
PKG_SOURCE_URL:=https://git.zx2c4.com/ipset-dns
|
||||
PKG_SOURCE_DATE:=2017-10-08
|
||||
PKG_SOURCE_VERSION:=ade2cf88e933f4f90451e0a6171f0aa4a523f989
|
||||
PKG_MIRROR_HASH:=94478078566bb8ddd76063607780f899646eacd2414e60d799231ff9391ce540
|
||||
PKG_MAINTAINER:=Jo-Philipp Wich <jo@mein.io>
|
||||
|
||||
PKG_LICENSE:=GPL-2.0
|
||||
PKG_LICENSE_FILES:=COPYING
|
||||
|
||||
include $(INCLUDE_DIR)/package.mk
|
||||
|
||||
define Package/ipset-dns/Default
|
||||
endef
|
||||
|
||||
define Package/ipset-dns
|
||||
SECTION:=net
|
||||
CATEGORY:=Network
|
||||
TITLE:=A lightweight DNS forwarder to populate ipsets
|
||||
URL:=http://git.zx2c4.com/ipset-dns/about/
|
||||
DEPENDS:=+libmnl
|
||||
endef
|
||||
|
||||
define Package/ipset-dns/description
|
||||
The ipset-dns daemon is a lightweight DNS forwarding server that adds all
|
||||
resolved IPs to a given netfilter ipset. It is designed to be used in
|
||||
conjunction with dnsmasq's upstream server directive.
|
||||
|
||||
Practical use cases include routing over a given gateway traffic for
|
||||
particular web services or webpages that do not have a priori predictable
|
||||
IP addresses and instead rely on dizzying arrays of DNS resolutions.
|
||||
endef
|
||||
|
||||
define Package/ipset-dns/conffiles
|
||||
/etc/config/ipset-dns
|
||||
endef
|
||||
|
||||
define Package/ipset-dns/install
|
||||
$(INSTALL_DIR) $(1)/usr/sbin
|
||||
$(INSTALL_BIN) $(PKG_BUILD_DIR)/ipset-dns $(1)/usr/sbin/ipset-dns
|
||||
$(INSTALL_DIR) $(1)/etc/init.d
|
||||
$(INSTALL_BIN) ./files/ipset-dns.init $(1)/etc/init.d/ipset-dns
|
||||
$(INSTALL_DIR) $(1)/etc/config
|
||||
$(INSTALL_CONF) ./files/ipset-dns.config $(1)/etc/config/ipset-dns
|
||||
endef
|
||||
|
||||
$(eval $(call BuildPackage,ipset-dns))
|
||||
16
package/network/services/ipset-dns/files/ipset-dns.config
Normal file
16
package/network/services/ipset-dns/files/ipset-dns.config
Normal file
@@ -0,0 +1,16 @@
|
||||
# declare an ipset-dns listener instance, multiple allowed
|
||||
config ipset-dns
|
||||
# use given ipset for type A (IPv4) responses
|
||||
option ipset 'domain-filter-ipv4'
|
||||
|
||||
# use given ipset for type AAAA (IPv6) responses
|
||||
option ipset6 'domain-filter-ipv6'
|
||||
|
||||
# use given listening port
|
||||
# defaults to 53000 + instance number
|
||||
#option port '53001'
|
||||
|
||||
# use given upstream DNS server,
|
||||
# defaults to first entry in /tmp/resolv.conf.d/resolv.conf.auto
|
||||
#option dns '8.8.8.8'
|
||||
|
||||
57
package/network/services/ipset-dns/files/ipset-dns.init
Executable file
57
package/network/services/ipset-dns/files/ipset-dns.init
Executable file
@@ -0,0 +1,57 @@
|
||||
#!/bin/sh /etc/rc.common
|
||||
# Copyright (C) 2013 OpenWrt.org
|
||||
|
||||
START=61
|
||||
|
||||
USE_PROCD=1
|
||||
|
||||
find_nameserver() {
|
||||
. /lib/functions/network.sh
|
||||
|
||||
local tmp
|
||||
if network_find_wan tmp && network_get_dnsserver tmp "$tmp"; then
|
||||
echo "${tmp%% *}"
|
||||
return 0
|
||||
fi
|
||||
|
||||
return 1
|
||||
}
|
||||
|
||||
start_instance() {
|
||||
local cfg="$1"
|
||||
local ipset ipset6 port dns
|
||||
|
||||
config_get ipset "$cfg" ipset
|
||||
config_get ipset6 "$cfg" ipset6
|
||||
[ -n "$ipset$ipset6" ] || {
|
||||
echo "No ipset specified for instance $cfg" >&2
|
||||
return 1
|
||||
}
|
||||
|
||||
config_get dns "$cfg" dns "$DEFNS"
|
||||
[ -n "$dns" ] || {
|
||||
echo "No DNS server specified for instance $cfg" >&2
|
||||
return 1
|
||||
}
|
||||
|
||||
config_get port "$cfg" port $((PORT++))
|
||||
|
||||
procd_open_instance
|
||||
procd_set_param command /usr/sbin/ipset-dns "$ipset" "$ipset6" "$port" "$dns"
|
||||
procd_set_param env NO_DAEMONIZE=1
|
||||
procd_set_param respawn
|
||||
procd_close_instance
|
||||
}
|
||||
|
||||
service_triggers()
|
||||
{
|
||||
procd_add_reload_trigger "ipset-dns"
|
||||
}
|
||||
|
||||
start_service() {
|
||||
PORT=53001
|
||||
DEFNS="$(find_nameserver)"
|
||||
|
||||
config_load ipset-dns
|
||||
config_foreach start_instance ipset-dns
|
||||
}
|
||||
Reference in New Issue
Block a user