Added forgot password form.

This commit is contained in:
mikestefanello 2021-12-14 21:59:56 -05:00
parent 6ec1b77684
commit 0546a1b089
5 changed files with 81 additions and 3 deletions

50
routes/forgot_password.go Normal file
View File

@ -0,0 +1,50 @@
package routes
import (
"goweb/controller"
"goweb/msg"
"github.com/labstack/echo/v4"
)
type (
ForgotPassword struct {
controller.Controller
form ForgotPasswordForm
}
ForgotPasswordForm struct {
Email string `form:"email" validate:"required,email" label:"Email address"`
}
)
func (f *ForgotPassword) Get(c echo.Context) error {
p := controller.NewPage(c)
p.Layout = "auth"
p.Name = "forgot-password"
p.Title = "Forgot password"
p.Data = f.form
return f.RenderPage(c, p)
}
func (f *ForgotPassword) Post(c echo.Context) error {
fail := func(message string, err error) error {
c.Logger().Errorf("%s: %v", message, err)
msg.Danger(c, "An error occurred. Please try again.")
return f.Get(c)
}
// Parse the form values
if err := c.Bind(&f.form); err != nil {
return fail("unable to parse forgot password form", err)
}
// Validate the form
if err := c.Validate(f.form); err != nil {
f.SetValidationErrorMessages(c, err, f.form)
return f.Get(c)
}
// TODO
return f.Redirect(c, "home")
}

View File

@ -18,7 +18,7 @@ type (
Name string `form:"name" validate:"required" label:"Name"`
Email string `form:"email" validate:"required,email" label:"Email address"`
Password string `form:"password" validate:"required" label:"Password"`
ConfirmPassword string `form:"password-confirm" validate:"required,eqfield=Password" label:"Confirm password"` // TODO validate same
ConfirmPassword string `form:"password-confirm" validate:"required,eqfield=Password" label:"Confirm password"`
}
)
@ -72,7 +72,9 @@ func (r *Register) Post(c echo.Context) error {
err = auth.Login(c, u.ID)
if err != nil {
// TODO
c.Logger().Errorf("unable to log in: %v", err)
msg.Info(c, "Your account has been created.")
return r.Redirect(c, "login")
}
msg.Info(c, "Your account has been created. You are now logged in.")

View File

@ -99,4 +99,8 @@ func userRoutes(g *echo.Group, ctr controller.Controller) {
register := Register{Controller: ctr}
noAuth.GET("/register", register.Get).Name = "register"
noAuth.POST("/register", register.Post).Name = "register.post"
forgot := ForgotPassword{Controller: ctr}
noAuth.GET("/password", forgot.Get).Name = "forgot_password"
noAuth.POST("/password", forgot.Post).Name = "forgot_password.post"
}

View File

@ -0,0 +1,22 @@
{{define "content"}}
<form method="post">
<div class="content">
<p>Enter your email address and we'll email you a link that allows you to reset your password.</p>
</div>
<div class="field">
<label for="email" class="label">Email address</label>
<div class="control">
<input id="email" type="email" name="email" class="input" value="{{.Data.Email}}" required>
</div>
</div>
<div class="field is-grouped">
<p class="control">
<button class="button is-primary">Reset password</button>
</p>
<p class="control">
<a href="{{call .Reverse "home"}}" class="button is-light">Cancel</a>
</p>
</div>
{{template "csrf" .}}
</form>
{{end}}

View File

@ -22,5 +22,5 @@
</div>
{{template "csrf" .}}
</form>
<div class="content is-small"><a href="{{call .Reverse "register"}}">Create an account</a></div>
<div class="content is-small"><a href="{{call .Reverse "register"}}">Create an account</a> - <a href="{{call .Reverse "forgot_password"}}">Forgot password?</a></div>
{{end}}