1
0
mirror of https://github.com/raseels-repos/golang-saas-starter-kit.git synced 2025-06-08 23:56:37 +02:00

123 lines
3.4 KiB
Go
Raw Normal View History

package handlers
import (
"context"
"net/http"
"time"
"geeks-accelerator/oss/saas-starter-kit/internal/account"
2019-08-01 16:17:47 -08:00
"geeks-accelerator/oss/saas-starter-kit/internal/geonames"
"geeks-accelerator/oss/saas-starter-kit/internal/platform/auth"
"geeks-accelerator/oss/saas-starter-kit/internal/platform/web"
"geeks-accelerator/oss/saas-starter-kit/internal/platform/web/webcontext"
"geeks-accelerator/oss/saas-starter-kit/internal/platform/web/weberror"
"geeks-accelerator/oss/saas-starter-kit/internal/signup"
"geeks-accelerator/oss/saas-starter-kit/internal/user_auth"
"github.com/gorilla/schema"
"github.com/jmoiron/sqlx"
"github.com/pkg/errors"
)
// Signup represents the Signup API method handler set.
type Signup struct {
MasterDB *sqlx.DB
Renderer web.Renderer
Authenticator *auth.Authenticator
}
// Step1 handles collecting the first detailed needed to create a new account.
func (h *Signup) Step1(ctx context.Context, w http.ResponseWriter, r *http.Request, params map[string]string) error {
ctxValues, err := webcontext.ContextValues(ctx)
if err != nil {
return err
}
//
req := new(signup.SignupRequest)
data := make(map[string]interface{})
2019-08-04 23:24:30 -08:00
f := func() (bool, error) {
claims, _ := auth.ClaimsFromContext(ctx)
if r.Method == http.MethodPost {
err := r.ParseForm()
if err != nil {
2019-08-04 23:24:30 -08:00
return false, err
}
decoder := schema.NewDecoder()
if err := decoder.Decode(req, r.PostForm); err != nil {
2019-08-04 23:24:30 -08:00
return false, err
}
// Execute the account / user signup.
_, err = signup.Signup(ctx, claims, h.MasterDB, *req, ctxValues.Now)
if err != nil {
switch errors.Cause(err) {
case account.ErrForbidden:
2019-08-04 23:24:30 -08:00
return false, web.RespondError(ctx, w, weberror.NewError(ctx, err, http.StatusForbidden))
default:
if verr, ok := weberror.NewValidationError(ctx, err); ok {
data["validationErrors"] = verr.(*weberror.Error)
2019-08-04 23:24:30 -08:00
return false, nil
} else {
2019-08-04 23:24:30 -08:00
return false, err
}
}
}
// Authenticated the new user.
2019-08-05 17:23:56 -08:00
token, err := user_auth.Authenticate(ctx, h.MasterDB, h.Authenticator, user_auth.AuthenticateRequest{
Email: req.User.Email,
Password: req.User.Password,
}, time.Hour, ctxValues.Now)
if err != nil {
2019-08-04 23:24:30 -08:00
return false, err
}
// Add the token to the users session.
2019-08-03 16:35:57 -08:00
err = handleSessionToken(ctx, h.MasterDB, w, r, token)
if err != nil {
2019-08-04 23:24:30 -08:00
return false, err
}
2019-08-03 15:01:17 -08:00
// Display a welcome message to the user.
webcontext.SessionFlashSuccess(ctx,
"Thank you for Joining",
"You workflow will be a breeze starting today.")
// Redirect the user to the dashboard.
return true, web.Redirect(ctx, w, r, "/", http.StatusFound)
2019-08-01 11:34:03 -08:00
}
2019-08-04 23:24:30 -08:00
return false, nil
}
2019-08-04 23:24:30 -08:00
end, err := f()
if err != nil {
return web.RenderError(ctx, w, r, err, h.Renderer, TmplLayoutBase, TmplContentErrorGeneric, web.MIMETextHTMLCharsetUTF8)
2019-08-04 23:24:30 -08:00
} else if end {
err = webcontext.ContextSession(ctx).Save(r, w)
if err != nil {
return err
}
2019-08-04 23:24:30 -08:00
return nil
}
data["geonameCountries"] = geonames.ValidGeonameCountries
data["countries"], err = geonames.FindCountries(ctx, h.MasterDB, "name", "")
if err != nil {
return err
}
data["form"] = req
2019-08-04 23:27:02 -08:00
if verr, ok := weberror.NewValidationError(ctx, signup.Validator().Struct(signup.SignupRequest{})); ok {
data["validationDefaults"] = verr.(*weberror.Error)
}
return h.Renderer.Render(ctx, w, r, TmplLayoutBase, "signup-step1.gohtml", web.MIMETextHTMLCharsetUTF8, http.StatusOK, data)
}