forked from open-networks/go-msgraph
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSecurity.go
297 lines (272 loc) · 13.8 KB
/
Security.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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
package msgraph
import (
"net"
"time"
)
// Alert represents a security alert.
type Alert struct {
ActivityGroupName string `json:"activityGroupName"`
AssignedTo string `json:"assignedTo"`
AzureSubscriptionID string `json:"azureSubscriptionId"`
AzureTenantID string `json:"azureTenantId"`
Category string `json:"category"`
ClosedDateTime time.Time `json:"closedDateTime"`
CloudAppStates []CloudAppSecurityState `json:"cloudAppStates"`
Comments []string `json:"comments"`
Confidence int32 `json:"confidence"`
CreatedDateTime time.Time `json:"createdDateTime"`
Description string `json:"description"`
DetectionIDs []string `json:"detectionIds"`
EventDateTime time.Time `json:"eventDateTime"`
Feedback string `json:"feedback"`
FileStates []FileSecurityState `json:"fileStates"`
HostStates []HostSecurityState `json:"hostStates"`
ID string `json:"id"`
IncidentIDs []string `json:"incidentIds"`
LastModifiedDateTime time.Time `json:"lastModifiedDateTime"`
MalwareStates []MalwareState `json:"malwareStates"`
NetworkConnections []NetworkConnection `json:"networkConnections"`
Processes []Process `json:"processes"`
RecommendedActions []string `json:"recommendedActions"`
RegistryKeyStates []RegistryKeyState `json:"registryKeyStates"`
SecurityResources []SecurityResource `json:"securityResources"`
Severity string `json:"severity"`
SourceMaterials []string `json:"sourceMaterials"`
Status string `json:"status"`
Tags []string `json:"tags"`
Title string `json:"title"`
Triggers []AlertTrigger `json:"triggers"`
UserStates []UserSecurityState `json:"userStates"`
VendorInformation SecurityVendorInformation `json:"vendorInformation"`
VulnerabilityStates []VulnerabilityState `json:"vulnerabilityStates"`
}
// CloudAppSecurityState contains stateful information about a cloud application related to an alert.
type CloudAppSecurityState struct {
DestinationServiceIP net.IP `json:"destinationServiceIp"`
DestinationServiceName string `json:"destinationServiceName"`
RiskScore string `json:"riskScore"`
}
// FileSecurityState contains information about a file (not process) related to an alert.
type FileSecurityState struct {
FileHash FileHash `json:"fileHash"`
Name string `json:"name"`
Path string `json:"path"`
RiskScore string `json:"riskScore"`
}
// FileHash contains hash information related to a file.
type FileHash struct {
HashType string `json:"hashType"`
HashValue string `json:"hashValue"`
}
// HostSecurityState contains information about a host (computer, device, etc.) related to an alert.
type HostSecurityState struct {
FQDN string `json:"fqdn"`
IsAzureAADJoined bool `json:"isAzureAadJoined"`
IsAzurAADRegistered bool `json:"isAzureAadRegistered"`
IsHybridAzureDomainJoined bool `json:"isHybridAzureDomainJoined"`
NetBiosName string `json:"netBiosName"`
OS string `json:"os"`
PrivateIPAddress net.IP `json:"privateIpAddress"`
PublicIPAddress net.IP `json:"publicIpAddress"`
RiskScore string `json:"riskScore"`
}
// MalwareState contains information about a malware entity.
type MalwareState struct {
Category string `json:"category"`
Family string `json:"family"`
Name string `json:"name"`
Severity string `json:"severity"`
WasRunning bool `json:"wasRunning"`
}
// NetworkConnection contains stateful information describing a network connection related to an alert.
type NetworkConnection struct {
ApplicationName string `json:"applicationName"`
DestinationAddress net.IP `json:"destinationAddress"`
DestinationLocation string `json:"destinationLocation"`
DestinationDomain string `json:"destinationDomain"`
DestinationPort string `json:"destinationPort"` // spec calls it a string, not a number
DestinationURL string `json:"destinationUrl"`
Direction string `json:"direction"`
DomainRegisteredDateTime time.Time `json:"domainRegisteredDateTime"`
LocalDNSName string `json:"localDnsName"`
NATDestinationAddress net.IP `json:"natDestinationAddress"`
NATDestinationPort string `json:"natDestinationPort"`
NATSourceAddress net.IP `json:"natSourceAddress"`
NATSourcePort string `json:"natSourcePort"`
Protocol string `json:"protocol"`
RiskScore string `json:"riskScore"`
SourceAddress net.IP `json:"sourceAddress"`
SourceLocation string `json:"sourceLocation"`
SourcePort string `json:"sourcePort"`
Status string `json:"status"`
URLParameters string `json:"urlParameters"`
}
// Process describes a process related to an alert.
type Process struct {
AccountName string `json:"accountName"`
CommandLine string `json:"commandLine"`
CreatedDateTime time.Time `json:"createdDateTime"` // translated
FileHash FileHash `json:"fileHash"`
IntegrityLevel string `json:"integrityLevel"`
IsElevated bool `json:"isElevated"`
Name string `json:"name"`
ParentProcessCreatedDateTime time.Time `json:"parentProcessCreatedDateTime"` // translated
ParentProcessID int32 `json:"parentProcessId"`
ParentProcessName string `json:"parentProcessName"`
Path string `json:"path"`
ProcessID int32 `json:"processId"`
}
// RegistryKeyState contains information about registry key changes related to an alert, and about the process which changed the keys.
type RegistryKeyState struct {
Hive string `json:"hive"`
Key string `json:"key"`
OldKey string `json:"oldKey"`
OldValueData string `json:"oldValueData"`
OldValueName string `json:"oldValueName"`
Operation string `json:"operation"`
ProcessID int32 `json:"processId"`
ValueData string `json:"valueData"`
ValueName string `json:"valueName"`
ValueType string `json:"valueType"`
}
// SecurityResource represents resources related to an alert.
type SecurityResource struct {
Resource string `json:"resource"`
ResourceType string `json:"resourceType"`
}
// AlertTrigger contains information about a property which triggered an alert detection.
type AlertTrigger struct {
Name string `json:"name"`
Type string `json:"type"`
Value string `json:"value"`
}
// UserSecurityState contains stateful information about a user account related to an alert.
type UserSecurityState struct {
AADUserID string `json:"aadUserId"`
AccountName string `json:"accountName"`
DomainName string `json:"domainName"`
EmailRole string `json:"emailRole"`
IsVPN bool `json:"isVpn"`
LogonDateTime time.Time `json:"logonDateTime"`
LogonID string `json:"logonId"`
LogonIP net.IP `json:"logonIp"`
LogonLocation string `json:"logonLocation"`
LogonType string `json:"logonType"`
OnPremisesSecurityIdentifier string `json:"onPremisesSecurityIdentifier"`
RiskScore string `json:"riskScore"`
UserAccountType string `json:"userAccountType"`
UserPrincipalName string `json:"userPrincipalName"`
}
// SecurityVendorInformation contains details about the vendor of a particular security product.
type SecurityVendorInformation struct {
Provider string `json:"provider"`
ProviderVersion string `json:"providerVersion"`
SubProvider string `json:"subProvider"`
Vendor string `json:"vendor"`
}
// VulnerabilityState contains information about a particular vulnerability.
type VulnerabilityState struct {
CVE string `json:"cve"`
Severity string `json:"severity"`
WasRunning bool `json:"wasRunning"`
}
// ListAlerts returns a slice of Alert objects from MS Graph's security API. Each Alert represents a security event reported by some component.
func (g *GraphClient) ListAlerts() ([]Alert, error) {
resource := "/security/alerts"
var marsh struct {
Alerts []Alert `json:"value"`
}
err := g.makeGETAPICall(resource, nil, &marsh)
return marsh.Alerts, err
}
// SecureScore represents the security score of a tenant for a particular day.
type SecureScore struct {
ID string `json:"id"`
AzureTenantID string `json:"azureTenantId"`
ActiveUserCount int32 `json:"activeUserCount"`
CreatedDateTime time.Time `json:"createdDateTime"`
CurrentScore float64 `json:"currentScore"`
EnabledServices []string `json:"enabledServices"`
LicensedUserCount int32 `json:"licensedUserCount"`
MaxScore float64 `json:"maxScore"`
AverageComparativeScores []AverageComparativeScore `json:"averageComparativeScores"`
ControlScores []ControlScore `json:"controlScores"`
VendorInformation SecurityVendorInformation `json:"vendorInformation"`
}
// AverageComparativeScore describes average scores across a variety of different scopes.
// The Basis field may contain the strings "AllTenants", "TotalSeats", or "IndustryTypes".
type AverageComparativeScore struct {
Basis string `json:"basis"`
AverageScore float64 `json:"averageScore"`
}
// ControlScore contains a score for a single security control.
type ControlScore struct {
ControlName string `json:"controlName"`
Score float64 `json:"score"`
ControlCategory string `json:"controlCategory"`
Description string `json:"description"`
}
// ListSecureScores returns a slice of SecureScore objects. Each SecureScore represents
// a tenant's security score for a particular day.
func (g *GraphClient) ListSecureScores() ([]SecureScore, error) {
resource := "/security/secureScores"
var marsh struct {
Scores []SecureScore `json:"value"`
}
err := g.makeGETAPICall(resource, nil, &marsh)
return marsh.Scores, err
}
// SecureScoreControlProfile describes in greater detail the parameters of a given security
// score control.
type SecureScoreControlProfile struct {
ID string `json:"id"`
AzureTenantID string `json:"azureTenantId"`
ActionType string `json:"actionType"`
ActionURL string `json:"actionUrl"`
ControlCategory string `json:"controlCategory"`
Title string `json:"title"`
Deprecated bool `json:"deprecated"`
ImplementationCost string `json:"implementationCost"`
LastModifiedDateTime time.Time `json:"lastModifiedDateTime"`
MaxScore float64 `json:"maxScore"`
Rank int32 `json:"rank"`
Remediation string `json:"remediation"`
RemediationImpact string `json:"remediationImpact"`
Service string `json:"service"`
Threats []string `json:"threats"`
Tier string `json:"tier"`
UserImpact string `json:"userImpact"`
ComplianceInformation []ComplianceInformation `json:"complianceInformation"`
ControlStateUpdates []SecureScoreControlStateUpdate `json:"controlStateUpdates"`
VendorInformation SecurityVendorInformation `json:"vendorInformation"`
}
// ComplianceInformation contains compliance data associated with a secure score control.
type ComplianceInformation struct {
CertificationName string `json:"certificationName"`
CertificationControls []CertificationControl `json:"certificationControls"`
}
// CertificationControl contains compliance certification data associated with a secure score control.
type CertificationControl struct {
Name string `json:"name"`
URL string `json:"url"`
}
// SecureScoreControlStateUpdate records a particular historical state of the control state
// as updated by the user.
type SecureScoreControlStateUpdate struct {
AssignedTo string `json:"assignedTo"`
Comment string `json:"comment"`
State string `json:"state"`
UpdatedBy string `json:"updatedBy"`
UpdatedDateTime time.Time `json:"updatedDateTime"`
}
// ListSecureScoreControlProfiles returns a slice of SecureScoreControlProfile objects.
// Each object represents a secure score control profile, which is used when calculating
// a tenant's secure score.
func (g *GraphClient) ListSecureScoreControlProfiles() ([]SecureScoreControlProfile, error) {
resource := "/security/secureScoreControlProfiles"
var marsh struct {
Profiles []SecureScoreControlProfile `json:"value"`
}
err := g.makeGETAPICall(resource, nil, &marsh)
return marsh.Profiles, err
}