ultisuite-backend/internal/api/mail/handlers_signatures.go
2026-05-24 00:03:36 +02:00

126 lines
3.5 KiB
Go

package mail
import (
"errors"
"net/http"
"github.com/go-chi/chi/v5"
"github.com/ultisuite/ulti-backend/internal/api/apiresponse"
"github.com/ultisuite/ulti-backend/internal/api/apivalidate"
"github.com/ultisuite/ulti-backend/internal/api/middleware"
"github.com/ultisuite/ulti-backend/internal/api/query"
)
func (h *Handler) ListSignatures(w http.ResponseWriter, r *http.Request) {
claims := middleware.ClaimsFromContext(r.Context())
params, err := query.ParseListRequest(r)
if err != nil {
apivalidate.WriteQueryError(w, r, err)
return
}
result, err := h.svc.ListSignatures(r.Context(), claims.Sub, params)
if err != nil {
h.logger.Error("list signatures", "error", err)
apivalidate.WriteInternal(w, r)
return
}
apiresponse.WriteJSON(w, http.StatusOK, result)
}
func (h *Handler) GetSignature(w http.ResponseWriter, r *http.Request) {
claims := middleware.ClaimsFromContext(r.Context())
signatureID := chi.URLParam(r, "signatureID")
if d := validateSignatureUUID(signatureID); d != nil {
apivalidate.WriteNotFound(w, r, "not found")
return
}
signature, err := h.svc.GetSignature(r.Context(), claims.Sub, signatureID)
if err != nil {
if errors.Is(err, ErrNotFound) {
apivalidate.WriteNotFound(w, r, "not found")
return
}
h.logger.Error("get signature", "error", err)
apivalidate.WriteInternal(w, r)
return
}
apiresponse.WriteJSON(w, http.StatusOK, signature)
}
func (h *Handler) CreateSignature(w http.ResponseWriter, r *http.Request) {
claims := middleware.ClaimsFromContext(r.Context())
var req createSignatureRequest
if err := apivalidate.DecodeJSON(w, r, maxSignatureRequestBody, &req); err != nil {
return
}
if verr := validateCreateSignature(&req); verr != nil {
apivalidate.WriteValidationError(w, r, verr)
return
}
id, err := h.svc.CreateSignature(r.Context(), claims.Sub, &req)
if err != nil {
h.logger.Error("create signature", "error", err)
apivalidate.WriteInternal(w, r)
return
}
apiresponse.WriteJSON(w, http.StatusCreated, map[string]string{"id": id})
}
func (h *Handler) UpdateSignature(w http.ResponseWriter, r *http.Request) {
claims := middleware.ClaimsFromContext(r.Context())
signatureID := chi.URLParam(r, "signatureID")
if d := validateSignatureUUID(signatureID); d != nil {
apivalidate.WriteNotFound(w, r, "not found")
return
}
var req updateSignatureRequest
if err := apivalidate.DecodeJSON(w, r, maxSignatureRequestBody, &req); err != nil {
return
}
if verr := validateUpdateSignature(&req); verr != nil {
apivalidate.WriteValidationError(w, r, verr)
return
}
if err := h.svc.UpdateSignature(r.Context(), claims.Sub, signatureID, &req); err != nil {
if errors.Is(err, ErrNotFound) {
apivalidate.WriteNotFound(w, r, "not found")
return
}
h.logger.Error("update signature", "error", err)
apivalidate.WriteInternal(w, r)
return
}
w.WriteHeader(http.StatusNoContent)
}
func (h *Handler) DeleteSignature(w http.ResponseWriter, r *http.Request) {
claims := middleware.ClaimsFromContext(r.Context())
signatureID := chi.URLParam(r, "signatureID")
if d := validateSignatureUUID(signatureID); d != nil {
apivalidate.WriteNotFound(w, r, "not found")
return
}
if err := h.svc.DeleteSignature(r.Context(), claims.Sub, signatureID); err != nil {
if errors.Is(err, ErrNotFound) {
apivalidate.WriteNotFound(w, r, "not found")
return
}
h.logger.Error("delete signature", "error", err)
apivalidate.WriteInternal(w, r)
return
}
w.WriteHeader(http.StatusNoContent)
}
func validateSignatureUUID(id string) *apivalidate.FieldDetail {
return validateAccountUUID(id)
}