nidus-sync/endpoint.go

110 lines
2.8 KiB
Go
Raw Normal View History

package main
import (
"errors"
"log/slog"
"net/http"
"strings"
)
func getFavicon(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Content-type", "image/x-icon")
http.ServeFile(w, r, "static/favicon.ico")
}
2025-11-05 21:05:10 +00:00
func getReport(w http.ResponseWriter, r *http.Request) {
//org := r.URL.Query().Get("org")
err := htmlReport(w)
if err != nil {
respondError(w, "Failed to generate report page", err, http.StatusInternalServerError)
}
}
func getRoot(w http.ResponseWriter, r *http.Request) {
user, err := getAuthenticatedUser(r)
if err != nil && !errors.Is(err, &NoCredentialsError{}) {
respondError(w, "Failed to get root", err, http.StatusInternalServerError)
return
}
if user == nil {
errorCode := r.URL.Query().Get("error")
err = htmlSignin(w, errorCode)
} else {
err = htmlDashboard(w, user)
}
if err != nil {
respondError(w, "Failed to render root", err, http.StatusInternalServerError)
}
}
2025-11-04 00:02:51 +00:00
func getSignup(w http.ResponseWriter, r *http.Request) {
err := htmlSignup(w, r.URL.Path)
if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
}
}
func respondError(w http.ResponseWriter, m string, e error, s int) {
slog.Error(m, slog.Int("status", s), slog.String("err", e.Error()))
http.Error(w, m, http.StatusBadRequest)
}
func postSignin(w http.ResponseWriter, r *http.Request) {
if err := r.ParseForm(); err != nil {
respondError(w, "Could not parse form", err, http.StatusBadRequest)
return
}
username := r.FormValue("username")
password := r.FormValue("password")
slog.Info("Signin",
slog.String("username", username),
slog.String("password", strings.Repeat("*", len(password))))
_, err := signinUser(r, username, password)
if err != nil {
if errors.Is(err, InvalidCredentials{}) {
http.Redirect(w, r, "/?error=invalid-credentials", http.StatusFound)
return
}
respondError(w, "Failed to signin user", err, http.StatusInternalServerError)
return
}
http.Redirect(w, r, "/", http.StatusFound)
}
func postSignup(w http.ResponseWriter, r *http.Request) {
if err := r.ParseForm(); err != nil {
respondError(w, "Could not parse form", err, http.StatusBadRequest)
return
}
username := r.FormValue("username")
name := r.FormValue("name")
password := r.FormValue("password")
terms := r.FormValue("terms")
slog.Info("Signup",
slog.String("username", username),
slog.String("name", name),
slog.String("password", strings.Repeat("*", len(password))))
if terms != "on" {
slog.Error("Terms not agreed", slog.String("terms", terms))
http.Error(w, "You must agree to the terms to register", http.StatusBadRequest)
return
}
user, err := signupUser(username, name, password)
if err != nil {
respondError(w, "Failed to signup user", err, http.StatusInternalServerError)
return
}
addUserSession(r, user)
2025-11-05 14:20:56 +00:00
http.Redirect(w, r, "/", http.StatusFound)
}