-
Notifications
You must be signed in to change notification settings - Fork 82
/
problem.go
124 lines (92 loc) · 5.51 KB
/
problem.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
// Copyright (c) 2016, 2018, 2022, Oracle and/or its affiliates. All rights reserved.
// This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license.
// Code generated. DO NOT EDIT.
// Cloud Guard and Security Zones API
//
// Use the Cloud Guard and Security Zones API to automate processes that you would otherwise perform through the Cloud Guard Console or the Security Zones Console. For more information on these services, see the Cloud Guard (https://docs.cloud.oracle.com/iaas/cloud-guard/home.htm) and Security Zones (https://docs.cloud.oracle.com/iaas/security-zone/home.htm) documentation.
// **Note:** For Cloud Guard, you can perform Create, Update, and Delete operations only from the reporting region of your Cloud Guard tenancy. You can perform Read operations in Cloud Guard from any region.
//
package cloudguard
import (
"fmt"
"github.com/oracle/oci-go-sdk/v65/common"
"strings"
)
// Problem Problem Definition.
type Problem struct {
// Unique identifier that is immutable on creation
Id *string `mandatory:"true" json:"id"`
// Compartment Identifier where the resource is created
CompartmentId *string `mandatory:"true" json:"compartmentId"`
// Identifier of the rule
DetectorRuleId *string `mandatory:"false" json:"detectorRuleId"`
// DEPRECATED
Region *string `mandatory:"false" json:"region"`
// Regions where the problem is found
Regions []string `mandatory:"false" json:"regions"`
// The Risk Level
RiskLevel RiskLevelEnum `mandatory:"false" json:"riskLevel,omitempty"`
// Risk Score for the problem
RiskScore *float64 `mandatory:"false" json:"riskScore"`
// The date and time for the peak risk score that is observed. Format defined by RFC3339.
PeakRiskScoreDate *string `mandatory:"false" json:"peakRiskScoreDate"`
// Peak risk score for the problem
PeakRiskScore *float64 `mandatory:"false" json:"peakRiskScore"`
// The date and time when the problem will be auto resolved. Format defined by RFC3339.
AutoResolveDate *string `mandatory:"false" json:"autoResolveDate"`
// Number of days for which peak score is calculated for the problem
PeakRiskScoreLookupPeriodInDays *int `mandatory:"false" json:"peakRiskScoreLookupPeriodInDays"`
// Identifier of the Resource
ResourceId *string `mandatory:"false" json:"resourceId"`
// DisplayName of the Resource
ResourceName *string `mandatory:"false" json:"resourceName"`
// Type of the Resource
ResourceType *string `mandatory:"false" json:"resourceType"`
// user defined labels on the problem
Labels []string `mandatory:"false" json:"labels"`
// The date and time the problem was last detected. Format defined by RFC3339.
TimeLastDetected *common.SDKTime `mandatory:"false" json:"timeLastDetected"`
// The date and time the problem was first detected. Format defined by RFC3339.
TimeFirstDetected *common.SDKTime `mandatory:"false" json:"timeFirstDetected"`
// The current state of the Problem.
LifecycleState ProblemLifecycleStateEnum `mandatory:"false" json:"lifecycleState,omitempty"`
// The lifecycleDetail will give more detail on the substate of the lifecycleState.
LifecycleDetail ProblemLifecycleDetailEnum `mandatory:"false" json:"lifecycleDetail,omitempty"`
// Id of the detector associated with the Problem.
DetectorId DetectorEnumEnum `mandatory:"false" json:"detectorId,omitempty"`
// targetId of the problem
TargetId *string `mandatory:"false" json:"targetId"`
// The additional details of the Problem
AdditionalDetails map[string]string `mandatory:"false" json:"additionalDetails"`
// Description of the problem
Description *string `mandatory:"false" json:"description"`
// Recommendation for the problem
Recommendation *string `mandatory:"false" json:"recommendation"`
// User Comments
Comment *string `mandatory:"false" json:"comment"`
}
func (m Problem) String() string {
return common.PointerString(m)
}
// ValidateEnumValue returns an error when providing an unsupported enum value
// This function is being called during constructing API request process
// Not recommended for calling this function directly
func (m Problem) ValidateEnumValue() (bool, error) {
errMessage := []string{}
if _, ok := GetMappingRiskLevelEnum(string(m.RiskLevel)); !ok && m.RiskLevel != "" {
errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for RiskLevel: %s. Supported values are: %s.", m.RiskLevel, strings.Join(GetRiskLevelEnumStringValues(), ",")))
}
if _, ok := GetMappingProblemLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" {
errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetProblemLifecycleStateEnumStringValues(), ",")))
}
if _, ok := GetMappingProblemLifecycleDetailEnum(string(m.LifecycleDetail)); !ok && m.LifecycleDetail != "" {
errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleDetail: %s. Supported values are: %s.", m.LifecycleDetail, strings.Join(GetProblemLifecycleDetailEnumStringValues(), ",")))
}
if _, ok := GetMappingDetectorEnumEnum(string(m.DetectorId)); !ok && m.DetectorId != "" {
errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for DetectorId: %s. Supported values are: %s.", m.DetectorId, strings.Join(GetDetectorEnumEnumStringValues(), ",")))
}
if len(errMessage) > 0 {
return true, fmt.Errorf(strings.Join(errMessage, "\n"))
}
return false, nil
}