Merge pull request #727 from openziti/external_interstitial

External Interstitial (#716)
This commit is contained in:
Michael Quigley 2024-08-06 12:31:31 -04:00 committed by GitHub
commit 6561a3b6bb
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 36 additions and 12 deletions

View File

@ -2,6 +2,8 @@
## v0.4.39
FEATURE: Support `html_path` directive in `interstitial` stanza of public frontend configuration to support using an external HTML file for the interstitial page (https://github.com/openziti/zrok/issues/716)
CHANGE: Update `github.com/openziti/sdk-golang` (and related dependencies) to version `v0.23.40`.
CHANGE: upgrade to ziti v1.1.7 CLI in zrok container image

View File

@ -23,6 +23,7 @@ type Config struct {
type InterstitialConfig struct {
Enabled bool
HtmlPath string
UserAgentPrefixes []string
}

View File

@ -180,7 +180,7 @@ func shareHandler(handler http.Handler, pcfg *Config, key []byte, ctx ziti.Conte
_, zrokOkErr := r.Cookie("zrok_interstitial")
if skip == "" && zrokOkErr != nil {
logrus.Debugf("forcing interstitial for '%v'", r.URL)
interstitialUi.WriteInterstitialAnnounce(w)
interstitialUi.WriteInterstitialAnnounce(w, pcfg.Interstitial.HtmlPath)
return
}
}

View File

@ -3,13 +3,30 @@ package interstitialUi
import (
"github.com/sirupsen/logrus"
"net/http"
"os"
)
func WriteInterstitialAnnounce(w http.ResponseWriter) {
var externalFile []byte
func WriteInterstitialAnnounce(w http.ResponseWriter, htmlPath string) {
if htmlPath != "" && externalFile == nil {
if data, err := os.ReadFile(htmlPath); err == nil {
externalFile = data
} else {
logrus.Errorf("error reading external interstitial file '%v': %v", htmlPath, err)
}
}
var htmlData = externalFile
if htmlData == nil {
if data, err := FS.ReadFile("index.html"); err == nil {
htmlData = data
} else {
logrus.Errorf("error reading embedded interstitial html 'index.html': %v", err)
}
}
w.WriteHeader(http.StatusOK)
n, err := w.Write(data)
if n != len(data) {
n, err := w.Write(htmlData)
if n != len(htmlData) {
logrus.Errorf("short write")
return
}
@ -17,5 +34,4 @@ func WriteInterstitialAnnounce(w http.ResponseWriter) {
logrus.Error(err)
return
}
}
}

View File

@ -18,6 +18,11 @@ v: 3
# #
# enabled: true
#
# # Specify a path to an external HTML file containing the interstitial page. Leaving out of configuration will fall back
# # to embedded interstitial HTML. See `endpoints/publicProxy/interstitialUi/index.html` for details on how the page works.
# #
# html_path: /some/path/to/interstitial.html
#
# # Specify a list of User-Agent prefixes that should receive the interstitial page. If interstitial pages are enabled
# # and this list is not set, all user agents will receive an interstitial page.
# #