Signed-off-by: Gerard Ryan <G.M0N3Y.2503@gmail.com>lilik-openwrt-22.03
@ -0,0 +1,52 @@ | |||
include $(TOPDIR)/rules.mk | |||
PKG_NAME:=cache-domains | |||
PKG_VERSION:=1.0.0 | |||
PKG_RELEASE:=1 | |||
PKG_MAINTAINER:=Gerard Ryan <G.M0N3Y.2503@gmail.com> | |||
include $(INCLUDE_DIR)/package.mk | |||
define Package/cache-domains/default | |||
SECTION:=utils | |||
CATEGORY:=Utilities | |||
TITLE:=Game content cache DNS | |||
URL:=https://github.com/uklans/cache-domains | |||
DEPENDS:=+jq +bash +dnsmasq +ca-bundle | |||
endef | |||
define Package/cache-domains/description/default | |||
Service to dynamically configure the local DNS (dnsmasq) to redirect game content servers to a LAN cache. | |||
Definitive list dynamically obtained from https://github.com/uklans/cache-domains. | |||
endef | |||
define Package/cache-domains/install/default | |||
$(INSTALL_DIR) $(1)/etc/init.d | |||
$(INSTALL_BIN) ./files/cache-domains.init $(1)/etc/init.d/cache-domains | |||
endef | |||
Build/Compile=# Nothing to compile, just install the scripts | |||
define Package/cache-domains-openssl | |||
$(Package/cache-domains/default) | |||
TITLE += (openssl) | |||
DEPENDS += +libustream-openssl | |||
VARIANT:=openssl | |||
endef | |||
Package/cache-domains-openssl/description = $(Package/cache-domains/description/default) | |||
Package/cache-domains-openssl/install = $(Package/cache-domains/install/default) | |||
define Package/cache-domains-mbedtls | |||
$(Package/cache-domains/default) | |||
TITLE += (mbedtls) | |||
DEPENDS += +libustream-mbedtls | |||
VARIANT:=mbedtls | |||
DEFAULT_VARIANT:=1 | |||
endef | |||
Package/cache-domains-mbedtls/description = $(Package/cache-domains/description/default) | |||
Package/cache-domains-mbedtls/install = $(Package/cache-domains/install/default) | |||
$(eval $(call BuildPackage,cache-domains-openssl)) | |||
$(eval $(call BuildPackage,cache-domains-mbedtls)) |
@ -0,0 +1,30 @@ | |||
# cache-domains | |||
Service to dynamically configure the local DNS (dnsmasq) to redirect game content servers to a LAN cache. Definitive list dynamically obtained from https://github.com/uklans/cache-domains. | |||
## Configuration | |||
Configuration file follows the same [syntax as the upsteam file](https://github.com/uklans/cache-domains/blob/master/scripts/config.example.json). The key for each `cache_domain` member matches the name of one of the `.txt` files in the [upstream root directory](https://github.com/uklans/cache-domains/blob/master/), except for the `default` key which matches the all the unreferenced `.txt` files. The value of each `cache_domain` member maps to one of the keys of the `ips` members, Thus mapping a cached domain to a list of IP addresses/LAN cache server. | |||
```json | |||
{ | |||
"ips": { | |||
"server1": ["10.10.3.10", "10.10.3.11"], | |||
"server2": "10.10.3.12", | |||
"server3": "10.10.3.13" | |||
}, | |||
"cache_domains": { | |||
"default": "server2", | |||
"blizzard": "server1", | |||
"origin": "server1", | |||
"steam": "server1", | |||
"wsus": "server3", | |||
"xboxlive": "server3" | |||
} | |||
} | |||
``` | |||
## Startup/Shutdown | |||
On start the local DNS (dnsmasq) will be configured to redirect the configured cache domains and on stop the redirection will be removed. | |||
## Testing | |||
With the above configuration set and the service running `nslookup swcdn.apple.com` would return `10.10.3.12` |
@ -0,0 +1,42 @@ | |||
#!/bin/sh /etc/rc.common | |||
START=24 | |||
SERVICE_NAME=cache-domains | |||
CACHE_DOMAINS_DIR="/var/${SERVICE_NAME}" | |||
CACHE_DOMAINS_SRC="https://api.github.com/repos/uklans/cache-domains/tarball/master" | |||
CONFIG_FILE="/etc/${SERVICE_NAME}.json" | |||
start() { | |||
mkdir -p ${CACHE_DOMAINS_DIR} | |||
rm -fr ${CACHE_DOMAINS_DIR}/* | |||
if ! wget -qO - ${CACHE_DOMAINS_SRC} | tar -xzC ${CACHE_DOMAINS_DIR}; then | |||
echo "ERROR: Could not retrieve ${CACHE_DOMAINS_SRC}" | |||
return 1 | |||
fi | |||
INITIAL_DIR="$(pwd)" | |||
cd ${CACHE_DOMAINS_DIR}/*/scripts/ | |||
if [ ! -f ${CONFIG_FILE} ]; then | |||
cp config.example.json ${CONFIG_FILE} | |||
echo "Using example config file ${CONFIG_FILE}" | |||
fi | |||
cp ${CONFIG_FILE} config.json | |||
./create-dnsmasq.sh | |||
cp ./output/dnsmasq/* /tmp/dnsmasq.d/ | |||
cd ${INITIAL_DIR} | |||
/etc/init.d/dnsmasq restart | |||
} | |||
stop() { | |||
# leave dnsmasq in a clean state | |||
for FILE in ${CACHE_DOMAINS_DIR}/*/scripts/output/dnsmasq/*; do | |||
rm -f /tmp/dnsmasq.d/$(basename ${FILE}) | |||
done | |||
/etc/init.d/dnsmasq restart | |||
} |