Skip to content

Commit

Permalink
add custom 5-shield html
Browse files Browse the repository at this point in the history
  • Loading branch information
janusec2 committed Jul 12, 2023
1 parent a1f3703 commit c169845
Show file tree
Hide file tree
Showing 3 changed files with 68 additions and 57 deletions.
63 changes: 61 additions & 2 deletions data/setting.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,6 @@ var (
<html>
<head>
<title>403 Forbidden</title>
</head>
<style>
body {
font-family: Arial, Helvetica, sans-serif;
Expand All @@ -55,8 +54,8 @@ var (
width: 70%;
margin: auto;
}
</style>
</head>
<body>
<div class="block_div">
<h1 class="text-logo">JANUSEC</h1>
Expand All @@ -66,6 +65,58 @@ var (
</body>
</html>
`

shieldHTML string = `<!DOCTYPE html>
<html>
<head>
<title>Checking</title>
<style>
body {
font-family: Arial, Helvetica, sans-serif;
text-align: center;
}
.text-logo {
display: block;
width: 260px;
font-size: 48px;
background-color: #F9F9F9;
color: #f5f5f5;
text-decoration: none;
text-shadow: 2px 2px 4px #000000;
box-shadow: 2px 2px 3px #D5D5D5;
padding: 15px;
margin: auto;
}
.block_div {
padding: 10px;
width: 70%;
margin: auto;
}
</style>
</head>
<body>
<div class="block_div">
<h1 class="text-logo">JANUSEC</h1>
<hr>
<p>
Checking your browser, please wait <span id="countdown">5</span> seconds ...
</p>
</div>
<script>
var t=5;
var countdown=setInterval(function(){
t--;
document.getElementById("countdown").innerHTML=t;
if(t<=0) {
clearInterval(countdown);
window.location.href = "/.auth/shield?callback={{ .Callback }}";
}
}, 1000);
</script>
</body>
</html>`
)

// UpdateBackendLastModified ...
Expand Down Expand Up @@ -144,6 +195,10 @@ func InitDefaultSettings() {
if !DAL.ExistsSetting("block_html") {
_ = DAL.SaveStringSetting("block_html", blockHTML)
}
if !DAL.ExistsSetting("shield_html") {
// v1.4.1 added
_ = DAL.SaveStringSetting("shield_html", shieldHTML)
}

// SMTP shared with PrimarySetting
if !DAL.ExistsSetting("smtp_enabled") {
Expand Down Expand Up @@ -313,6 +368,7 @@ func LoadSettings() {
PrimarySetting.SearchEngines = DAL.SelectStringSetting("search_engines")
PrimarySetting.WebSSHEnabled = DAL.SelectBoolSetting("webssh_enabled")
PrimarySetting.BlockHTML = DAL.SelectStringSetting("block_html")
PrimarySetting.ShieldHTML = DAL.SelectStringSetting("shield_html") // v1.4.1 added
// v1.2.0 add SMTP
smtpSetting := &models.SMTPSetting{}
smtpSetting.SMTPEnabled = DAL.SelectBoolSetting("smtp_enabled")
Expand Down Expand Up @@ -340,6 +396,7 @@ func LoadSettings() {
NodeSetting.SkipSEEnabled = PrimarySetting.SkipSEEnabled
NodeSetting.SearchEnginesPattern = UpdateSecondShieldPattern(PrimarySetting.SearchEngines)
NodeSetting.BlockHTML = PrimarySetting.BlockHTML
NodeSetting.ShieldHTML = PrimarySetting.ShieldHTML
// NodeSetting.SMTP and PrimarySetting.SMTP point to the same SMTP setting
NodeSetting.SMTP = smtpSetting
// LoadAuthConfig
Expand Down Expand Up @@ -667,6 +724,8 @@ func UpdatePrimarySetting(r *http.Request, body []byte, clientIP string, authUse
NodeSetting.SearchEnginesPattern = UpdateSecondShieldPattern(PrimarySetting.SearchEngines)
DAL.SaveStringSetting("block_html", PrimarySetting.BlockHTML)
NodeSetting.BlockHTML = PrimarySetting.BlockHTML
DAL.SaveStringSetting("shield_html", PrimarySetting.ShieldHTML)
NodeSetting.ShieldHTML = PrimarySetting.ShieldHTML
DAL.SaveBoolSetting("smtp_enabled", PrimarySetting.SMTP.SMTPEnabled)
DAL.SaveStringSetting("smtp_server", PrimarySetting.SMTP.SMTPServer)
DAL.SaveStringSetting("smtp_port", PrimarySetting.SMTP.SMTPPort)
Expand Down
56 changes: 1 addition & 55 deletions gateway/shield.go
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ func SecondShieldAuthorization(w http.ResponseWriter, r *http.Request) {
// GenerateShieldPage for first access if 5-second shield enabled
func GenerateShieldPage(w http.ResponseWriter, r *http.Request, urlPath string) {
if tmplShieldReq == nil {
tmplShieldReq, _ = template.New("shieldReq").Parse(shieldHTML)
tmplShieldReq, _ = template.New("shieldReq").Parse(data.NodeSetting.ShieldHTML)
}
session, _ := store.Get(r, "janusec-token")
session.Values["timestamp"] = time.Now().Unix()
Expand All @@ -94,57 +94,3 @@ func GenerateShieldPage(w http.ResponseWriter, r *http.Request, urlPath string)
utils.DebugPrintln("GenerateShieldPage tmpl.Execute error", err)
}
}

const shieldHTML = `<!DOCTYPE html>
<html>
<head>
<title>Checking</title>
</head>
<style>
body {
font-family: Arial, Helvetica, sans-serif;
text-align: center;
}
.text-logo {
display: block;
width: 260px;
font-size: 48px;
background-color: #F9F9F9;
color: #f5f5f5;
text-decoration: none;
text-shadow: 2px 2px 4px #000000;
box-shadow: 2px 2px 3px #D5D5D5;
padding: 15px;
margin: auto;
}
.block_div {
padding: 10px;
width: 70%;
margin: auto;
}
</style>
<body>
<div class="block_div">
<h1 class="text-logo">JANUSEC</h1>
<hr>
<p>
Checking your browser, please wait <span id="countdown">5</span> seconds ...
</p>
</div>
<script>
var t=5;
var countdown=setInterval(function(){
t--;
document.getElementById("countdown").innerHTML=t;
if(t<=0) {
clearInterval(countdown);
window.location.href = "/.auth/shield?callback={{ .Callback }}";
}
}, 1000);
</script>
</body>
</html>
`
6 changes: 6 additions & 0 deletions models/gateway.go
Original file line number Diff line number Diff line change
Expand Up @@ -134,6 +134,9 @@ type PrimarySetting struct {
// BlockHTML, v1.4.0 added
BlockHTML string `json:"block_html"`

// ShieldHTML for 5-second shield, v1.4.1 added
ShieldHTML string `json:"shield_html"`

// WAFLogDays for WAF logs
WAFLogDays int64 `json:"waf_log_days"`

Expand Down Expand Up @@ -175,6 +178,9 @@ type NodeShareSetting struct {
// BlockHTML, v1.4.0 added
BlockHTML string `json:"block_html"`

// ShieldHTML for 5-second shield, v1.4.1 added
ShieldHTML string `json:"shield_html"`

// AuthConfig for authentication
AuthConfig *OAuthConfig `json:"auth_config"`

Expand Down

0 comments on commit c169845

Please sign in to comment.