84 lines
2.3 KiB
Go
84 lines
2.3 KiB
Go
package endpoints
|
|
|
|
import (
|
|
"arbeitszeitmessung/helper"
|
|
"arbeitszeitmessung/models"
|
|
"arbeitszeitmessung/templates"
|
|
"context"
|
|
"log"
|
|
"net/http"
|
|
"strconv"
|
|
"time"
|
|
|
|
"github.com/alexedwards/scs/v2"
|
|
)
|
|
|
|
var Session *scs.SessionManager
|
|
|
|
func CreateSessionManager(lifetime time.Duration) *scs.SessionManager {
|
|
Session = scs.New()
|
|
Session.Lifetime = lifetime
|
|
log.Println("Created Session")
|
|
return Session
|
|
}
|
|
|
|
func showLoginPage(w http.ResponseWriter, r *http.Request, failed bool) {
|
|
r = r.WithContext(context.WithValue(r.Context(), "session", Session))
|
|
if helper.GetEnv("GO_ENV", "production") == "debug" {
|
|
// http.Redirect(w, r, "/time", http.StatusSeeOther)
|
|
templates.LoginPage(failed).Render(r.Context(), w)
|
|
}
|
|
if Session.Exists(r.Context(), "user") {
|
|
http.Redirect(w, r, "/time", http.StatusSeeOther)
|
|
}
|
|
templates.LoginPage(failed).Render(r.Context(), w)
|
|
}
|
|
|
|
func loginUser(w http.ResponseWriter, r *http.Request) {
|
|
err := r.ParseForm()
|
|
if err != nil {
|
|
log.Println("Error parsing form!", err)
|
|
http.Error(w, "Internal error", http.StatusBadRequest)
|
|
return
|
|
}
|
|
_personal_nummer := r.FormValue("personal_nummer")
|
|
if _personal_nummer == "" {
|
|
log.Println("No personal_nummer provided!")
|
|
http.Error(w, "No personal_nummer provided", http.StatusBadRequest)
|
|
return
|
|
}
|
|
personal_nummer, err := strconv.Atoi(_personal_nummer)
|
|
if err != nil {
|
|
log.Println("Cannot parse personal nubmer!")
|
|
http.Error(w, "Cannot parse number", http.StatusBadRequest)
|
|
return
|
|
}
|
|
|
|
user, err := models.GetUserByPersonalNr(personal_nummer)
|
|
if err != nil {
|
|
log.Println("No user found under this personal number!", err)
|
|
http.Error(w, "No user found!", http.StatusNotFound)
|
|
}
|
|
|
|
password := r.FormValue("password")
|
|
if user.Login(password) {
|
|
log.Printf("New succesfull user login from %s %s (%d)!\n", user.Vorname, user.Name, user.PersonalNummer)
|
|
Session.Put(r.Context(), "user", user.PersonalNummer)
|
|
Session.Commit(r.Context())
|
|
http.Redirect(w, r, "/time", http.StatusSeeOther) //with this browser always uses GET
|
|
} else {
|
|
showLoginPage(w, r, true)
|
|
return
|
|
}
|
|
showLoginPage(w, r, false)
|
|
}
|
|
|
|
func logoutUser(w http.ResponseWriter, r *http.Request) {
|
|
log.Println("Loggin out user!")
|
|
err := Session.Destroy(r.Context())
|
|
if err != nil {
|
|
log.Println("Error destroying session!", err)
|
|
}
|
|
http.Redirect(w, r, "/user/login", http.StatusSeeOther)
|
|
}
|