summaryrefslogtreecommitdiff
path: root/shrine/services/warning.go
blob: 553c7fb4cae31bd2ffa10c7ae101c1adaf2ac33d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
package services

import (
	"fmt"
	"shrine/enums"
	"shrine/messages"
	"shrine/models"
	"shrine/repositories"
	"shrine/types/audit"
	"shrine/types/hypertext"
	"shrine/types/warning"
	"shrine/utils/auth"
	"shrine/utils/logger"
	"shrine/utils/meta"
	"shrine/utils/sanitize"
	"strings"
)

func WarnUser(admin *models.User, target *models.User, request warning.WarnRequest) (*warning.WarningResponse, *hypertext.ServiceError) {
	if hierarchyErr := auth.ValidateHierarchy(admin, target, "warn"); hierarchyErr != nil {
		return nil, fail(enums.Forbidden, hierarchyErr.Error())
	}

	title := strings.TrimSpace(request.Title)
	if title == "" {
		return nil, fail(enums.BadRequest, messages.WarningTitleRequired)
	}

	sanitizedMessage := sanitize.HTML(request.Message)
	if sanitizedMessage == "" {
		return nil, fail(enums.BadRequest, messages.WarningMessageRequired)
	}

	record, err := repositories.CreateWarning(admin.ID, target.ID, title, sanitizedMessage)
	if err != nil {
		logger.Errorf("Warnings", messages.FailedCreateWarningDetailed, target.Username, err)
		return nil, fail(enums.Internal, messages.FailedCreateWarning)
	}

	repositories.LogAction(admin.ID, "user.warn", "user", target.Username, fmt.Sprintf(messages.AuditWarnedUser, target.Username), audit.WarningDetails{
		WarningRef: record.SystemRef,
		Title:      title,
		Message:    sanitizedMessage,
	})

	response := record.ToResponse()
	return &response, nil
}

func DeactivateWarning(admin *models.User, ref string) (*warning.WarningResponse, *hypertext.ServiceError) {
	record, err := repositories.FindWarningByRef(ref)
	if err != nil {
		return nil, fail(enums.NotFound, messages.WarningNotFound)
	}

	if !record.Active {
		return nil, fail(enums.BadRequest, messages.WarningAlreadyInactive)
	}

	if err := repositories.DeactivateWarning(record); err != nil {
		return nil, fail(enums.Internal, messages.FailedDeactivateWarn)
	}

	repositories.LogAction(admin.ID, "user.unwarn", "user", "", fmt.Sprintf(messages.AuditDeactivatedWarn, record.SystemRef), audit.DeactivateWarningDetails{
		WarningRef: record.SystemRef,
	})

	response := record.ToResponse()
	return &response, nil
}

func ListWarnings(username string, pagination meta.Pagination) ([]warning.WarningResponse, int64, *hypertext.ServiceError) {
	citizen, serviceErr := ResolveUser(username)
	if serviceErr != nil {
		return nil, 0, serviceErr
	}

	warnings, total := repositories.ListWarningsForUser(citizen.ID, pagination)

	items := make([]warning.WarningResponse, len(warnings))
	for index, record := range warnings {
		items[index] = record.ToResponse()
	}

	return items, total, nil
}