-
Notifications
You must be signed in to change notification settings - Fork 82
/
audit_trail.go
173 lines (135 loc) · 8.34 KB
/
audit_trail.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
// Copyright (c) 2016, 2018, 2024, 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.
// Data Safe API
//
// APIs for using Oracle Data Safe.
//
package datasafe
import (
"fmt"
"github.com/oracle/oci-go-sdk/v65/common"
"strings"
)
// AuditTrail An audit trail represents the source of audit records that provides documentary evidence of
// the sequence of activities in the target database. Configuring audit trails in Data Safe, and enabling
// audit data collection on the audit trails copies the audit records from the target database's audit trail
// into the Data Safe repository.
type AuditTrail struct {
// The OCID of the audit trail.
Id *string `mandatory:"true" json:"id"`
// The OCID of the parent audit.
AuditProfileId *string `mandatory:"true" json:"auditProfileId"`
// The OCID of the Data Safe target for which the audit trail is created.
TargetId *string `mandatory:"true" json:"targetId"`
// The display name of the audit trail.
DisplayName *string `mandatory:"true" json:"displayName"`
// The date and time the audit trail was created, in the format defined by RFC3339.
TimeCreated *common.SDKTime `mandatory:"true" json:"timeCreated"`
// The date and time the audit trail was updated, in the format defined by RFC3339.
TimeUpdated *common.SDKTime `mandatory:"true" json:"timeUpdated"`
// The current state of the audit trail.
LifecycleState AuditTrailLifecycleStateEnum `mandatory:"true" json:"lifecycleState"`
// The current sub-state of the audit trail.
Status AuditTrailStatusEnum `mandatory:"true" json:"status"`
// The OCID of the compartment that contains the audit trail and is the same as the compartment of the audit profile resource.
CompartmentId *string `mandatory:"true" json:"compartmentId"`
// Details about the current state of the audit trail in Data Safe.
LifecycleDetails *string `mandatory:"false" json:"lifecycleDetails"`
// An audit trail location represents the source of audit records that provides documentary
// evidence of the sequence of activities in the target database.
TrailLocation *string `mandatory:"false" json:"trailLocation"`
// The description of the audit trail.
Description *string `mandatory:"false" json:"description"`
// Indicates if auto purge is enabled on the target database, which helps delete audit data in the
// target database every seven days so that the database's audit trail does not become too large.
IsAutoPurgeEnabled *bool `mandatory:"false" json:"isAutoPurgeEnabled"`
// The date from which the audit trail must start collecting data, in the format defined by RFC3339.
AuditCollectionStartTime *common.SDKTime `mandatory:"false" json:"auditCollectionStartTime"`
// The OCID of the workrequest for audit trail which collects audit records.
WorkRequestId *string `mandatory:"false" json:"workRequestId"`
// The date and time until when the audit events were collected from the target database by the Data Safe audit trail
// collection process, in the format defined by RFC3339.
TimeLastCollected *common.SDKTime `mandatory:"false" json:"timeLastCollected"`
// The secondary id assigned for the peer database registered with Data Safe.
PeerTargetDatabaseKey *int `mandatory:"false" json:"peerTargetDatabaseKey"`
// The underlying source of unified audit trail.
TrailSource AuditTrailSourceEnum `mandatory:"false" json:"trailSource,omitempty"`
// The date and time of the last purge job. The purge job deletes audit data in the
// target database every seven days so that the database's audit trail does not become too large.
// In the format defined by RFC3339.
PurgeJobTime *common.SDKTime `mandatory:"false" json:"purgeJobTime"`
// The current status of the audit trail purge job.
PurgeJobStatus AuditTrailPurgeJobStatusEnum `mandatory:"false" json:"purgeJobStatus,omitempty"`
// The details of the audit trail purge job that ran at the time specified by purgeJobTime".
PurgeJobDetails *string `mandatory:"false" json:"purgeJobDetails"`
// Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm)
// Example: `{"Department": "Finance"}`
FreeformTags map[string]string `mandatory:"false" json:"freeformTags"`
// Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/resourcetags.htm)
// Example: `{"Operations": {"CostCenter": "42"}}`
DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"`
// System tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags.
// Example: `{"orcl-cloud": {"free-tier-retained": "true"}}`
SystemTags map[string]map[string]interface{} `mandatory:"false" json:"systemTags"`
}
func (m AuditTrail) 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 AuditTrail) ValidateEnumValue() (bool, error) {
errMessage := []string{}
if _, ok := GetMappingAuditTrailLifecycleStateEnum(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(GetAuditTrailLifecycleStateEnumStringValues(), ",")))
}
if _, ok := GetMappingAuditTrailStatusEnum(string(m.Status)); !ok && m.Status != "" {
errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for Status: %s. Supported values are: %s.", m.Status, strings.Join(GetAuditTrailStatusEnumStringValues(), ",")))
}
if _, ok := GetMappingAuditTrailSourceEnum(string(m.TrailSource)); !ok && m.TrailSource != "" {
errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for TrailSource: %s. Supported values are: %s.", m.TrailSource, strings.Join(GetAuditTrailSourceEnumStringValues(), ",")))
}
if _, ok := GetMappingAuditTrailPurgeJobStatusEnum(string(m.PurgeJobStatus)); !ok && m.PurgeJobStatus != "" {
errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for PurgeJobStatus: %s. Supported values are: %s.", m.PurgeJobStatus, strings.Join(GetAuditTrailPurgeJobStatusEnumStringValues(), ",")))
}
if len(errMessage) > 0 {
return true, fmt.Errorf(strings.Join(errMessage, "\n"))
}
return false, nil
}
// AuditTrailPurgeJobStatusEnum Enum with underlying type: string
type AuditTrailPurgeJobStatusEnum string
// Set of constants representing the allowable values for AuditTrailPurgeJobStatusEnum
const (
AuditTrailPurgeJobStatusSucceeded AuditTrailPurgeJobStatusEnum = "SUCCEEDED"
AuditTrailPurgeJobStatusFailed AuditTrailPurgeJobStatusEnum = "FAILED"
)
var mappingAuditTrailPurgeJobStatusEnum = map[string]AuditTrailPurgeJobStatusEnum{
"SUCCEEDED": AuditTrailPurgeJobStatusSucceeded,
"FAILED": AuditTrailPurgeJobStatusFailed,
}
var mappingAuditTrailPurgeJobStatusEnumLowerCase = map[string]AuditTrailPurgeJobStatusEnum{
"succeeded": AuditTrailPurgeJobStatusSucceeded,
"failed": AuditTrailPurgeJobStatusFailed,
}
// GetAuditTrailPurgeJobStatusEnumValues Enumerates the set of values for AuditTrailPurgeJobStatusEnum
func GetAuditTrailPurgeJobStatusEnumValues() []AuditTrailPurgeJobStatusEnum {
values := make([]AuditTrailPurgeJobStatusEnum, 0)
for _, v := range mappingAuditTrailPurgeJobStatusEnum {
values = append(values, v)
}
return values
}
// GetAuditTrailPurgeJobStatusEnumStringValues Enumerates the set of values in String for AuditTrailPurgeJobStatusEnum
func GetAuditTrailPurgeJobStatusEnumStringValues() []string {
return []string{
"SUCCEEDED",
"FAILED",
}
}
// GetMappingAuditTrailPurgeJobStatusEnum performs case Insensitive comparison on enum value and return the desired enum
func GetMappingAuditTrailPurgeJobStatusEnum(val string) (AuditTrailPurgeJobStatusEnum, bool) {
enum, ok := mappingAuditTrailPurgeJobStatusEnumLowerCase[strings.ToLower(val)]
return enum, ok
}