diff options
Diffstat (limited to 'src/user/routes.go')
| -rw-r--r-- | src/user/routes.go | 56 |
1 files changed, 48 insertions, 8 deletions
diff --git a/src/user/routes.go b/src/user/routes.go index f826822..64018d0 100644 --- a/src/user/routes.go +++ b/src/user/routes.go @@ -1,9 +1,10 @@ package user import ( - "fmt" + "log" "net/http" + "github.com/go-playground/validator/v10" "gitlab.com/alexkavon/newsstand/src/server" ) @@ -11,7 +12,7 @@ var Routes = server.Routes{ server.Route{ Name: "Create", Method: "GET", - Path: "/user/create", + Path: "/u/create", HandlerFunc: Create, }, server.Route{ @@ -23,19 +24,19 @@ var Routes = server.Routes{ server.Route{ Name: "LoginForm", Method: "GET", - Path: "/user/auth", + Path: "/u/auth", HandlerFunc: LoginForm, }, server.Route{ Name: "Authenticate", Method: "POST", - Path: "/user/auth", + Path: "/u/auth", HandlerFunc: Authenticate, }, server.Route{ Name: "Me", Method: "GET", - Path: "/user/me", + Path: "/u/me", AuthRequired: true, HandlerFunc: Show, }, @@ -50,8 +51,36 @@ func Create(s *server.Server) http.HandlerFunc { func Store(s *server.Server) http.HandlerFunc { return func(w http.ResponseWriter, r *http.Request) { r.ParseForm() - fmt.Println(r.PostForm) - s.Ui.RenderTemplate(w, "core", "messages", &struct{ Message string }{Message: "Congrats"}) + + user := &User{ + Db: s.Db, + Username: r.PostFormValue("username"), + Secret: r.PostFormValue("secret"), + Email: r.PostFormValue("email"), + } + // Validate User Input + v := validator.New() + err := v.Struct(user) + if err != nil { + log.Println("Validator failed", err.(validator.ValidationErrors)) + } + + // Hash secret + err = user.HashSecret() + if err != nil { + log.Println("Hash failure", err) + } + + // Store user + err = user.Insert() + if err != nil { + log.Println("Insert Error", err) + } + // Send email validation + // Create cookie session + s.NewSession(w, user.Username) + // Redirect to user profile + http.Redirect(w, r, "/u/me", http.StatusSeeOther) } } @@ -66,5 +95,16 @@ func Authenticate(s *server.Server) http.HandlerFunc { } func Show(s *server.Server) http.HandlerFunc { - return func(w http.ResponseWriter, r *http.Request) {} + return func(w http.ResponseWriter, r *http.Request) { + token, err := r.Cookie("session_token") + if err != nil { + s.Ui.Render(w, "user/login", &struct{ Message string }{"You are not logged in! Missing Cookie"}) + } + session, ok := s.Sessions[token.Value] + if !ok { + s.Ui.Render(w, "user/login", &struct{ Message string }{"You are not logged in! With Session."}) + } + + s.Ui.Render(w, "user/me", &struct{ Message, Username string }{"Congrats on getting this far!", session.Username()}) + } } |
