all repos

onasty @ eb4c60509f134e49485bff1ee0c6422ced9d5e03

a one-time notes service

onasty/internal/transport/http/apiv1/response.go (view raw)

Oleksandr Smirnov Oleksandr Smirnov
olexsmir@gmail.com
refactor!: rename "burn before expiration" to "keep before expiration" (#199)..., 9 months ago
1
package apiv1
2
3
import (
4
	"errors"
5
	"log/slog"
6
	"net/http"
7
8
	"github.com/gin-gonic/gin"
9
	"github.com/olexsmir/onasty/internal/jwtutil"
10
	"github.com/olexsmir/onasty/internal/models"
11
	"github.com/olexsmir/onasty/internal/service/authsrv"
12
	"github.com/olexsmir/onasty/internal/service/notesrv"
13
)
14
15
var ErrUnauthorized = errors.New("unauthorized")
16
17
type response struct {
18
	Message string `json:"message"`
19
}
20
21
func errorResponse(c *gin.Context, err error) {
22
	if errors.Is(err, authsrv.ErrProviderNotSupported) ||
23
		errors.Is(err, models.ErrResetPasswordTokenAlreadyUsed) ||
24
		errors.Is(err, models.ErrResetPasswordTokenExpired) ||
25
		errors.Is(err, models.ErrUserEmailIsAlreadyInUse) ||
26
		errors.Is(err, models.ErrUserIsAlreadyVerified) ||
27
		errors.Is(err, models.ErrUserIsNotActivated) ||
28
		errors.Is(err, models.ErrUserInvalidEmail) ||
29
		errors.Is(err, models.ErrUserInvalidPassword) ||
30
		errors.Is(err, models.ErrUserNotFound) ||
31
		errors.Is(err, models.ErrUserWrongCredentials) ||
32
		// notes
33
		errors.Is(err, notesrv.ErrNotePasswordNotProvided) ||
34
		errors.Is(err, models.ErrNoteContentIsEmpty) ||
35
		errors.Is(err, models.ErrNoteCannotBeKept) ||
36
		errors.Is(err, models.ErrNoteSlugIsAlreadyInUse) ||
37
		errors.Is(err, models.ErrNoteSlugIsInvalid) {
38
		newError(c, http.StatusBadRequest, err.Error())
39
		return
40
	}
41
42
	if errors.Is(err, models.ErrNoteExpired) {
43
		newError(c, http.StatusGone, err.Error())
44
		return
45
	}
46
47
	if errors.Is(err, models.ErrNoteNotFound) ||
48
		errors.Is(err, models.ErrVerificationTokenNotFound) {
49
		newErrorStatus(c, http.StatusNotFound, err.Error())
50
		return
51
	}
52
53
	if errors.Is(err, ErrUnauthorized) ||
54
		errors.Is(err, jwtutil.ErrTokenExpired) ||
55
		errors.Is(err, jwtutil.ErrTokenSignatureInvalid) {
56
		newErrorStatus(c, http.StatusUnauthorized, err.Error())
57
		return
58
	}
59
60
	newInternalError(c, err)
61
}
62
63
func newError(c *gin.Context, status int, msg string) {
64
	slog.ErrorContext(c.Request.Context(), msg, "status", status)
65
	c.AbortWithStatusJSON(status, response{msg})
66
}
67
68
func newErrorStatus(c *gin.Context, status int, msg string) {
69
	slog.ErrorContext(c.Request.Context(), msg, "status", status)
70
	c.AbortWithStatus(status)
71
}
72
73
func newInternalError(c *gin.Context, err error, msg ...string) {
74
	slog.ErrorContext(c.Request.Context(), err.Error(), "status", "internal error")
75
76
	if len(msg) != 0 {
77
		c.AbortWithStatusJSON(http.StatusInternalServerError, response{
78
			Message: msg[0],
79
		})
80
		return
81
	}
82
83
	c.AbortWithStatusJSON(http.StatusInternalServerError, response{
84
		Message: "internal error",
85
	})
86
}