When running a LAN Cache and overriding DNS entries, there are some services (including the Origin launcher) which will try and use HTTPS to talk to one of the hostnames that are being overridden. This breaks updates to the Origin client.
The solution is to run SNI Proxy on all IP addresses on the LAN Cache server. This accepts the HTTPS requests, looks at the host being requested and sends the request on to the correct server.
Why do I need an SNI Proxy
SNI Proxy allows hostnames that serve BOTH http and https content to be overridden and pointed to your cache server. Traffic going to that hostname on port 80 (http) will hit the cache container and be cached, whilst traffic on port 443 (https) is passed straight through to the internet by the SNI Proxy container.
Can SNI Proxy cache encrypted traffic
It does NOT allow https / encrypted content to be inspected or cached - merely ensure that it is passed straight through to the internet to avoid breaking anything whilst allow us to cache the HTTP traffic from that same hostname.
Run the proxy container using the following to allow TCP port 443 (HTTPS) through the host machine:
docker run --name sniproxy -p 443:443 lancachenet/sniproxy:latest
Changing Upstream DNS
If you need to change the upstream DNS server the cache uses, these are defined by the
UPSTREAM_DNS environment variable. The defaults are Google DNS (188.8.131.52 and 184.108.40.206).
UPSTREAM_DNS 220.127.116.11 18.104.22.168
You can override these using the
-e argument to docker run and specifying your upstream DNS servers. Multiple upstream dns servers are allowed, separated by whitespace.
-e UPSTREAM_DNS="22.214.171.124 126.96.36.199"
Running on Startup
Follow the instructions in the Docker documentation to run the container at startup. Documentation
The SNI Proxy config and Dockerfile are from the OpenSourceLAN origin-docker project on GitHub.