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
}
|