Added forgot password form.
This commit is contained in:
parent
6ec1b77684
commit
0546a1b089
5 changed files with 81 additions and 3 deletions
50
routes/forgot_password.go
Normal file
50
routes/forgot_password.go
Normal 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")
|
||||
}
|
||||
|
|
@ -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.")
|
||||
|
|
|
|||
|
|
@ -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"
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue