Parameters for password validation
This commit is contained in:
2
Makefile
2
Makefile
@ -1,5 +1,5 @@
|
|||||||
REPO=npenkov/docker-ldap-passwd-webui
|
REPO=npenkov/docker-ldap-passwd-webui
|
||||||
VER=1.1
|
VER=1.2
|
||||||
|
|
||||||
.PHONY: all build push
|
.PHONY: all build push
|
||||||
|
|
||||||
|
@ -38,6 +38,8 @@ docker run -d -p 8080:8080 --name ldap-passwd-webui \
|
|||||||
-e LPW_SSL_SKIP_VERIFY="true" \
|
-e LPW_SSL_SKIP_VERIFY="true" \
|
||||||
-e LPW_USER_DN="uid=%s,ou=people,dc=example,dc=org" \
|
-e LPW_USER_DN="uid=%s,ou=people,dc=example,dc=org" \
|
||||||
-e LPW_USER_BASE="ou=people,dc=example,dc=org" \
|
-e LPW_USER_BASE="ou=people,dc=example,dc=org" \
|
||||||
|
-e LPW_PATTERN='.{8,}' \
|
||||||
|
-e LPW_PATTERN_INFO="Password must be at least 8 characters long." \
|
||||||
npenkov/docker-ldap-passwd-webui:latest
|
npenkov/docker-ldap-passwd-webui:latest
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -9,6 +9,14 @@ func getTitle() string {
|
|||||||
return envStr("LPW_TITLE", "Change your password on example.org")
|
return envStr("LPW_TITLE", "Change your password on example.org")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func getPattern() string {
|
||||||
|
return envStr("LPW_PATTERN", ".{8,}")
|
||||||
|
}
|
||||||
|
|
||||||
|
func getPatternInfo() string {
|
||||||
|
return envStr("LPW_PATTERN_INFO", "Password must be at least 8 characters long.")
|
||||||
|
}
|
||||||
|
|
||||||
func envStr(key, defaultValue string) string {
|
func envStr(key, defaultValue string) string {
|
||||||
val := os.Getenv(key)
|
val := os.Getenv(key)
|
||||||
if val != "" {
|
if val != "" {
|
||||||
|
16
app/web.go
16
app/web.go
@ -48,10 +48,12 @@ func (h *RegexpHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type pageData struct {
|
type pageData struct {
|
||||||
Title string
|
Title string
|
||||||
Username string
|
Pattern string
|
||||||
Alerts map[string]string
|
PatternInfo string
|
||||||
CaptchaId string
|
Username string
|
||||||
|
Alerts map[string]string
|
||||||
|
CaptchaId string
|
||||||
}
|
}
|
||||||
|
|
||||||
// ServeAssets : Serves the static assets
|
// ServeAssets : Serves the static assets
|
||||||
@ -61,7 +63,7 @@ func ServeAssets(w http.ResponseWriter, req *http.Request) {
|
|||||||
|
|
||||||
// ServeIndex : Serves index page on GET request
|
// ServeIndex : Serves index page on GET request
|
||||||
func ServeIndex(w http.ResponseWriter, req *http.Request) {
|
func ServeIndex(w http.ResponseWriter, req *http.Request) {
|
||||||
p := &pageData{Title: getTitle(), CaptchaId: captcha.New()}
|
p := &pageData{Title: getTitle(), CaptchaId: captcha.New(), Pattern: getPattern(), PatternInfo: getPatternInfo()}
|
||||||
t, e := template.ParseFiles(path.Join("templates", "index.html"))
|
t, e := template.ParseFiles(path.Join("templates", "index.html"))
|
||||||
if e != nil {
|
if e != nil {
|
||||||
log.Printf("Error parsing file %v\n", e)
|
log.Printf("Error parsing file %v\n", e)
|
||||||
@ -102,6 +104,10 @@ func ChangePassword(w http.ResponseWriter, req *http.Request) {
|
|||||||
alerts["error"] = "New and confirmation passwords does not match. "
|
alerts["error"] = "New and confirmation passwords does not match. "
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if m, _ := regexp.MatchString(getPattern(), newPassword[0]); !m {
|
||||||
|
alerts["error"] = alerts["error"] + fmt.Sprintf("%s", getPatternInfo())
|
||||||
|
}
|
||||||
|
|
||||||
if len(captchaID) < 1 || captchaID[0] == "" ||
|
if len(captchaID) < 1 || captchaID[0] == "" ||
|
||||||
len(captchaSolution) < 1 || captchaSolution[0] == "" ||
|
len(captchaSolution) < 1 || captchaSolution[0] == "" ||
|
||||||
!captcha.VerifyString(captchaID[0], captchaSolution[0]) {
|
!captcha.VerifyString(captchaID[0], captchaSolution[0]) {
|
||||||
|
@ -54,12 +54,12 @@
|
|||||||
|
|
||||||
<label for="new-password">New password</label>
|
<label for="new-password">New password</label>
|
||||||
<input id="new-password" name="new-password" type="password"
|
<input id="new-password" name="new-password" type="password"
|
||||||
pattern=".{8,}" x-moz-errormessage="Password must be at least 8 characters long." required>
|
pattern="{{.Pattern}}" x-moz-errormessage="{{.PatternInfo}}" required>
|
||||||
|
|
||||||
<label for="confirm-password">Confirm new password</label>
|
<label for="confirm-password">Confirm new password</label>
|
||||||
<input id="confirm-password" name="confirm-password" type="password"
|
<input id="confirm-password" name="confirm-password" type="password"
|
||||||
pattern=".{8,}" x-moz-errormessage="Password must be at least 8 characters long." required>
|
pattern="{{.Pattern}}" x-moz-errormessage="{{.PatternInfo}}" required>
|
||||||
|
<p>{{.PatternInfo}}</p>
|
||||||
<p>Type the numbers you see in the picture below:</p>
|
<p>Type the numbers you see in the picture below:</p>
|
||||||
<p>
|
<p>
|
||||||
<img id=image src="/captcha/{{.CaptchaId}}.png" alt="Captcha image">
|
<img id=image src="/captcha/{{.CaptchaId}}.png" alt="Captcha image">
|
||||||
|
Reference in New Issue
Block a user