forked from Tufin/oasdiff
-
Notifications
You must be signed in to change notification settings - Fork 0
/
check-response-header-removed.go
65 lines (61 loc) · 1.84 KB
/
check-response-header-removed.go
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
package checker
import (
"github.com/tufin/oasdiff/diff"
)
const (
RequiredResponseHeaderRemovedId = "required-response-header-removed"
OptionalResponseHeaderRemovedId = "optional-response-header-removed"
)
func ResponseHeaderRemovedCheck(diffReport *diff.Diff, operationsSources *diff.OperationsSourcesMap, config *Config) Changes {
result := make(Changes, 0)
if diffReport.PathsDiff == nil {
return result
}
for path, pathItem := range diffReport.PathsDiff.Modified {
if pathItem.OperationsDiff == nil {
continue
}
for operation, operationItem := range pathItem.OperationsDiff.Modified {
if operationItem.ResponsesDiff == nil {
continue
}
if operationItem.ResponsesDiff.Modified == nil {
continue
}
source := (*operationsSources)[operationItem.Revision]
for responseStatus, responseDiff := range operationItem.ResponsesDiff.Modified {
if responseDiff.HeadersDiff == nil {
continue
}
for _, headerName := range responseDiff.HeadersDiff.Deleted {
if responseDiff.Base.Headers[headerName] == nil {
continue
}
required := responseDiff.Base.Headers[headerName].Value.Required
if required {
result = append(result, ApiChange{
Id: RequiredResponseHeaderRemovedId,
Level: ERR,
Args: []any{headerName, responseStatus},
Operation: operation,
OperationId: operationItem.Revision.OperationID,
Path: path,
Source: source,
})
} else {
result = append(result, ApiChange{
Id: OptionalResponseHeaderRemovedId,
Level: WARN,
Args: []any{headerName, responseStatus},
Operation: operation,
OperationId: operationItem.Revision.OperationID,
Path: path,
Source: source,
})
}
}
}
}
}
return result
}