2024-07-13 13:58:36 +02:00
|
|
|
package frontend
|
2024-03-11 21:08:27 +01:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"html/template"
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
"strconv"
|
|
|
|
|
2024-07-13 14:09:11 +02:00
|
|
|
b "streifling.com/jason/cpolis/cmd/backend"
|
2024-03-11 21:08:27 +01:00
|
|
|
)
|
|
|
|
|
2024-07-13 14:09:11 +02:00
|
|
|
func checkUserStrings(user *b.User) (string, int, bool) {
|
2024-03-11 21:08:27 +01:00
|
|
|
userLen := 15
|
|
|
|
nameLen := 50
|
|
|
|
|
|
|
|
if len(user.UserName) > userLen {
|
|
|
|
return "Benutzername", userLen, false
|
|
|
|
} else if len(user.FirstName) > nameLen {
|
|
|
|
return "Vorname", nameLen, false
|
|
|
|
} else if len(user.LastName) > nameLen {
|
|
|
|
return "Nachname", nameLen, false
|
|
|
|
} else {
|
|
|
|
return "", 0, true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-08-18 11:20:06 +02:00
|
|
|
func CreateUser(c *b.Config, s *b.CookieStore) http.HandlerFunc {
|
2024-03-29 09:07:17 +01:00
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
2024-08-18 11:20:06 +02:00
|
|
|
if _, err := getSession(w, r, c, s); err != nil {
|
2024-10-04 10:35:32 +02:00
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
2024-08-18 11:20:06 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-03-29 09:07:17 +01:00
|
|
|
tmpl, err := template.ParseFiles(c.WebDir + "/templates/add-user.html")
|
2024-10-04 10:21:56 +02:00
|
|
|
if err = template.Must(tmpl, err).ExecuteTemplate(w, "page-content", nil); err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
2024-03-29 09:07:17 +01:00
|
|
|
}
|
2024-03-11 21:08:27 +01:00
|
|
|
}
|
|
|
|
|
2024-07-13 14:09:11 +02:00
|
|
|
func AddUser(c *b.Config, db *b.DB, s *b.CookieStore) http.HandlerFunc {
|
2024-03-11 21:08:27 +01:00
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
2024-08-18 11:20:06 +02:00
|
|
|
session, err := getSession(w, r, c, s)
|
|
|
|
if err != nil {
|
2024-10-04 10:35:32 +02:00
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
2024-08-18 11:20:06 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-10-04 16:06:33 +02:00
|
|
|
user := &b.User{
|
|
|
|
UserName: r.PostFormValue("username"),
|
|
|
|
FirstName: r.PostFormValue("first-name"),
|
|
|
|
LastName: r.PostFormValue("last-name"),
|
2024-03-11 21:08:27 +01:00
|
|
|
}
|
|
|
|
pass := r.PostFormValue("password")
|
|
|
|
pass2 := r.PostFormValue("password2")
|
|
|
|
|
2024-10-04 16:06:33 +02:00
|
|
|
if len(user.UserName) == 0 || len(user.FirstName) == 0 ||
|
|
|
|
len(user.LastName) == 0 || len(pass) == 0 || len(pass2) == 0 {
|
|
|
|
http.Error(w, "Bitte alle Felder ausfüllen.", http.StatusBadRequest)
|
2024-03-11 21:08:27 +01:00
|
|
|
return
|
|
|
|
}
|
2024-10-04 16:06:33 +02:00
|
|
|
|
|
|
|
userString, stringLen, ok := checkUserStrings(user)
|
2024-03-11 21:08:27 +01:00
|
|
|
if !ok {
|
2024-10-04 16:06:33 +02:00
|
|
|
http.Error(w, fmt.Sprint(userString, " ist zu lang. Maximal ", stringLen, " Zeichen erlaubt."), http.StatusBadRequest)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if id := db.GetID(user.UserName); id != 0 {
|
|
|
|
http.Error(w, user.UserName+" ist bereits vergeben. Bitte anderen Benutzernamen wählen.", http.StatusBadRequest)
|
2024-03-11 21:08:27 +01:00
|
|
|
return
|
|
|
|
}
|
2024-10-04 16:06:33 +02:00
|
|
|
|
2024-03-11 21:08:27 +01:00
|
|
|
if pass != pass2 {
|
2024-10-04 16:06:33 +02:00
|
|
|
http.Error(w, "Die Passwörter stimmen nicht überein.", http.StatusBadRequest)
|
2024-03-11 21:08:27 +01:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-10-04 16:06:33 +02:00
|
|
|
roleString := r.PostFormValue("role")
|
|
|
|
if len(roleString) == 0 {
|
|
|
|
http.Error(w, "Bitte eine Aufgabe vergeben.", http.StatusBadRequest)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
user.Role, err = strconv.Atoi(roleString)
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
_, err = db.AddUser(user, pass)
|
2024-03-11 21:08:27 +01:00
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
2024-03-28 07:00:37 +01:00
|
|
|
|
2024-03-29 09:07:17 +01:00
|
|
|
tmpl, err := template.ParseFiles(c.WebDir + "/templates/hub.html")
|
2024-04-12 08:46:34 +02:00
|
|
|
tmpl = template.Must(tmpl, err)
|
2024-10-04 10:21:56 +02:00
|
|
|
if err = tmpl.ExecuteTemplate(w, "page-content", session.Values["role"].(int)); err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
2024-03-11 21:08:27 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-07-13 14:09:11 +02:00
|
|
|
func EditSelf(c *b.Config, db *b.DB, s *b.CookieStore) http.HandlerFunc {
|
2024-03-12 19:56:22 +01:00
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
2024-08-18 11:20:06 +02:00
|
|
|
session, err := getSession(w, r, c, s)
|
2024-03-12 19:56:22 +01:00
|
|
|
if err != nil {
|
2024-10-04 10:35:32 +02:00
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
2024-08-18 11:20:06 +02:00
|
|
|
return
|
2024-03-12 19:56:22 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
user, err := db.GetUser(session.Values["id"].(int64))
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-04-09 19:06:29 +02:00
|
|
|
tmpl, err := template.ParseFiles(c.WebDir + "/templates/edit-self.html")
|
2024-10-04 10:21:56 +02:00
|
|
|
if err = template.Must(tmpl, err).ExecuteTemplate(w, "page-content", user); err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
2024-03-12 19:56:22 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-07-13 14:09:11 +02:00
|
|
|
func UpdateSelf(c *b.Config, db *b.DB, s *b.CookieStore) http.HandlerFunc {
|
2024-03-11 21:08:27 +01:00
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
2024-08-18 11:20:06 +02:00
|
|
|
session, err := getSession(w, r, c, s)
|
2024-03-11 21:08:27 +01:00
|
|
|
if err != nil {
|
2024-10-04 10:35:32 +02:00
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
2024-08-18 11:20:06 +02:00
|
|
|
return
|
2024-03-11 21:08:27 +01:00
|
|
|
}
|
|
|
|
|
2024-10-04 16:06:33 +02:00
|
|
|
user := &b.User{
|
|
|
|
ID: session.Values["id"].(int64),
|
|
|
|
UserName: r.PostFormValue("username"),
|
|
|
|
FirstName: r.PostFormValue("first-name"),
|
|
|
|
LastName: r.PostFormValue("last-name"),
|
2024-03-11 21:08:27 +01:00
|
|
|
}
|
2024-10-04 16:06:33 +02:00
|
|
|
|
2024-03-11 21:08:27 +01:00
|
|
|
oldPass := r.PostFormValue("old-password")
|
|
|
|
newPass := r.PostFormValue("password")
|
|
|
|
newPass2 := r.PostFormValue("password2")
|
|
|
|
|
2024-10-04 16:06:33 +02:00
|
|
|
if len(user.UserName) == 0 {
|
|
|
|
http.Error(w, "Bitte den Benutzernamen ausfüllen.", http.StatusBadRequest)
|
2024-03-11 21:08:27 +01:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-10-04 16:06:33 +02:00
|
|
|
if len(user.FirstName) == 0 || len(user.LastName) == 0 {
|
|
|
|
http.Error(w, "Bitte den vollständigen Namen ausfüllen.", http.StatusBadRequest)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
userString, stringLen, ok := checkUserStrings(user)
|
2024-03-11 21:08:27 +01:00
|
|
|
if !ok {
|
2024-10-04 16:06:33 +02:00
|
|
|
http.Error(w, fmt.Sprint(userString, " ist zu lang. Maximal ", stringLen, " Zeichen erlaubt."), http.StatusBadRequest)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if id := db.GetID(user.UserName); id != 0 && id != user.ID {
|
|
|
|
http.Error(w, user.UserName+" ist bereits vergeben. Bitte anderen Benutzernamen wählen.", http.StatusBadRequest)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = db.UpdateOwnUserAttributes(user.ID, user.UserName, user.FirstName, user.LastName, oldPass, newPass, newPass2); err != nil {
|
|
|
|
log.Println("error: user:", user.ID, err)
|
|
|
|
http.Error(w, "Benutzerdaten konnten nicht aktualisiert werden.", http.StatusInternalServerError)
|
|
|
|
return
|
2024-03-11 21:08:27 +01:00
|
|
|
}
|
|
|
|
|
2024-03-29 09:07:17 +01:00
|
|
|
tmpl, err := template.ParseFiles(c.WebDir + "/templates/hub.html")
|
2024-03-11 21:08:27 +01:00
|
|
|
tmpl = template.Must(tmpl, err)
|
2024-10-04 10:21:56 +02:00
|
|
|
if err = tmpl.ExecuteTemplate(w, "page-content", session.Values["role"].(int)); err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
2024-03-11 21:08:27 +01:00
|
|
|
}
|
|
|
|
}
|
2024-04-01 19:26:18 +02:00
|
|
|
|
2024-07-13 14:09:11 +02:00
|
|
|
func AddFirstUser(c *b.Config, db *b.DB, s *b.CookieStore) http.HandlerFunc {
|
2024-04-01 19:26:18 +02:00
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
2024-08-18 11:20:06 +02:00
|
|
|
var err error
|
2024-10-04 16:06:33 +02:00
|
|
|
user := &b.User{
|
|
|
|
UserName: r.PostFormValue("username"),
|
|
|
|
FirstName: r.PostFormValue("first-name"),
|
|
|
|
LastName: r.PostFormValue("last-name"),
|
|
|
|
Role: b.Admin,
|
2024-04-01 19:26:18 +02:00
|
|
|
}
|
|
|
|
pass := r.PostFormValue("password")
|
|
|
|
pass2 := r.PostFormValue("password2")
|
|
|
|
|
2024-10-04 16:06:33 +02:00
|
|
|
if len(user.UserName) == 0 || len(user.FirstName) == 0 ||
|
|
|
|
len(user.LastName) == 0 || len(pass) == 0 || len(pass2) == 0 {
|
|
|
|
http.Error(w, "Bitte alle Felder ausfüllen.", http.StatusBadRequest)
|
2024-04-01 19:26:18 +02:00
|
|
|
return
|
|
|
|
}
|
2024-10-04 16:06:33 +02:00
|
|
|
|
|
|
|
userString, stringLen, ok := checkUserStrings(user)
|
2024-04-01 19:26:18 +02:00
|
|
|
if !ok {
|
2024-10-04 16:06:33 +02:00
|
|
|
http.Error(w, fmt.Sprint(userString, " ist zu lang. Maximal ", stringLen, " Zeichen erlaubt."), http.StatusBadRequest)
|
2024-04-01 19:26:18 +02:00
|
|
|
return
|
|
|
|
}
|
2024-10-04 16:06:33 +02:00
|
|
|
|
2024-04-01 19:26:18 +02:00
|
|
|
if pass != pass2 {
|
2024-10-04 16:06:33 +02:00
|
|
|
http.Error(w, "Die Passwörter stimmen nicht überein.", http.StatusBadRequest)
|
2024-04-01 19:26:18 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-10-04 16:06:33 +02:00
|
|
|
user.ID, err = db.AddFirstUser(user, pass)
|
2024-04-01 19:26:18 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
2024-10-04 16:06:33 +02:00
|
|
|
if user.ID == -1 {
|
|
|
|
http.Error(w, "Bitte ein Benutzerkonto von einem Administrator anlegen lassen.", http.StatusInternalServerError)
|
2024-04-02 19:37:53 +02:00
|
|
|
return
|
|
|
|
}
|
2024-04-01 19:26:18 +02:00
|
|
|
|
2024-10-04 16:06:33 +02:00
|
|
|
if err := saveSession(w, r, s, user); err != nil {
|
2024-04-01 19:26:18 +02:00
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := db.AddIssue(); err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpl, err := template.ParseFiles(c.WebDir + "/templates/hub.html")
|
2024-10-04 10:21:56 +02:00
|
|
|
if err = template.Must(tmpl, err).ExecuteTemplate(w, "page-content", 0); err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
2024-04-01 19:26:18 +02:00
|
|
|
}
|
|
|
|
}
|
2024-04-09 19:06:29 +02:00
|
|
|
|
2024-07-13 14:09:11 +02:00
|
|
|
func ShowAllUsers(c *b.Config, db *b.DB, s *b.CookieStore, action string) http.HandlerFunc {
|
2024-04-09 19:06:29 +02:00
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
2024-08-18 11:20:06 +02:00
|
|
|
session, err := getSession(w, r, c, s)
|
|
|
|
if err != nil {
|
2024-10-04 10:35:32 +02:00
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
2024-08-18 11:20:06 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-09-10 19:59:56 +02:00
|
|
|
data := new(struct {
|
2024-07-13 14:09:11 +02:00
|
|
|
Users map[int64]*b.User
|
2024-04-12 08:46:34 +02:00
|
|
|
Action string
|
2024-09-10 19:59:56 +02:00
|
|
|
})
|
2024-04-12 08:46:34 +02:00
|
|
|
|
2024-09-10 19:59:56 +02:00
|
|
|
data.Action = action
|
2024-04-12 08:46:34 +02:00
|
|
|
data.Users, err = db.GetAllUsers()
|
2024-04-09 19:06:29 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-04-12 08:46:34 +02:00
|
|
|
delete(data.Users, session.Values["id"].(int64))
|
2024-04-09 19:06:29 +02:00
|
|
|
tmpl, err := template.ParseFiles(c.WebDir + "/templates/show-all-users.html")
|
2024-10-04 10:21:56 +02:00
|
|
|
if err = template.Must(tmpl, err).ExecuteTemplate(w, "page-content", data); err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
2024-04-09 19:06:29 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-08-18 11:20:06 +02:00
|
|
|
func EditUser(c *b.Config, db *b.DB, s *b.CookieStore) http.HandlerFunc {
|
2024-04-09 19:06:29 +02:00
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
2024-08-18 11:20:06 +02:00
|
|
|
if _, err := getSession(w, r, c, s); err != nil {
|
2024-10-04 10:35:32 +02:00
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
2024-08-18 11:20:06 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-04-09 19:06:29 +02:00
|
|
|
id, err := strconv.ParseInt(r.PathValue("id"), 10, 64)
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
user, err := db.GetUser(id)
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpl, err := template.ParseFiles(c.WebDir + "/templates/edit-user.html")
|
2024-10-04 10:21:56 +02:00
|
|
|
if err = template.Must(tmpl, err).ExecuteTemplate(w, "page-content", user); err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
2024-04-09 19:06:29 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-07-13 14:09:11 +02:00
|
|
|
func UpdateUser(c *b.Config, db *b.DB, s *b.CookieStore) http.HandlerFunc {
|
2024-04-09 19:06:29 +02:00
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
2024-08-18 11:20:06 +02:00
|
|
|
session, err := getSession(w, r, c, s)
|
|
|
|
if err != nil {
|
2024-10-04 10:35:32 +02:00
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
2024-08-18 11:20:06 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-10-04 16:06:33 +02:00
|
|
|
user := new(b.User)
|
|
|
|
user.ID, err = strconv.ParseInt(r.PathValue("id"), 10, 64)
|
2024-04-09 19:06:29 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-10-04 16:06:33 +02:00
|
|
|
user.Role, err = strconv.Atoi(r.PostFormValue("role"))
|
2024-04-09 19:06:29 +02:00
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-10-04 16:06:33 +02:00
|
|
|
user.UserName = r.PostFormValue("username")
|
|
|
|
if len(user.UserName) == 0 {
|
|
|
|
http.Error(w, "Bitte den Benutzernamen ausfüllen.", http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
user.FirstName = r.PostFormValue("first-name")
|
|
|
|
user.LastName = r.PostFormValue("last-name")
|
|
|
|
if len(user.FirstName) == 0 || len(user.LastName) == 0 {
|
|
|
|
http.Error(w, "Bitte den vollständigen Namen ausfüllen.", http.StatusInternalServerError)
|
|
|
|
return
|
2024-04-09 19:06:29 +02:00
|
|
|
}
|
2024-10-04 16:06:33 +02:00
|
|
|
|
2024-04-09 19:06:29 +02:00
|
|
|
newPass := r.PostFormValue("password")
|
|
|
|
newPass2 := r.PostFormValue("password2")
|
|
|
|
|
2024-10-04 16:06:33 +02:00
|
|
|
userString, stringLen, ok := checkUserStrings(user)
|
|
|
|
if !ok {
|
|
|
|
http.Error(w, fmt.Sprint(userString, " ist zu lang. Maximal ", stringLen, " Zeichen erlaubt."), http.StatusBadRequest)
|
2024-04-09 19:06:29 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-10-04 16:06:33 +02:00
|
|
|
if id := db.GetID(user.UserName); id != 0 && id != user.ID {
|
|
|
|
http.Error(w, user.UserName+" ist bereits vergeben. Bitte anderen Benutzernamen wählen.", http.StatusBadRequest)
|
|
|
|
return
|
2024-04-09 19:06:29 +02:00
|
|
|
}
|
|
|
|
|
2024-10-04 16:06:33 +02:00
|
|
|
if err = db.UpdateUserAttributes(user.ID, user.UserName, user.FirstName, user.LastName, newPass, newPass2, user.Role); err != nil {
|
|
|
|
log.Println("error: user:", user.ID, err)
|
|
|
|
http.Error(w, "Benutzerdaten konnten nicht aktualisiert werden.", http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpl := template.Must(template.ParseFiles(c.WebDir + "/templates/hub.html"))
|
2024-10-04 10:21:56 +02:00
|
|
|
if err = tmpl.ExecuteTemplate(w, "page-content", session.Values["role"].(int)); err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
2024-04-12 08:46:34 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-07-13 14:09:11 +02:00
|
|
|
func DeleteUser(c *b.Config, db *b.DB, s *b.CookieStore) http.HandlerFunc {
|
2024-04-12 08:46:34 +02:00
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
2024-08-18 11:20:06 +02:00
|
|
|
session, err := getSession(w, r, c, s)
|
|
|
|
if err != nil {
|
2024-10-04 10:35:32 +02:00
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
2024-08-18 11:20:06 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-04-12 08:46:34 +02:00
|
|
|
id, err := strconv.ParseInt(r.PathValue("id"), 10, 64)
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = db.DeleteUser(id); err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
tmpl, err := template.ParseFiles(c.WebDir + "/templates/hub.html")
|
|
|
|
tmpl = template.Must(tmpl, err)
|
2024-10-04 10:21:56 +02:00
|
|
|
if err = tmpl.ExecuteTemplate(w, "page-content", session.Values["role"].(int)); err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
|
|
|
return
|
|
|
|
}
|
2024-04-09 19:06:29 +02:00
|
|
|
}
|
|
|
|
}
|