-
Notifications
You must be signed in to change notification settings - Fork 82
/
repository.go
250 lines (198 loc) · 11 KB
/
repository.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
// 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.
// DevOps API
//
// Use the DevOps API to create DevOps projects, configure code repositories, add artifacts to deploy, build and test software applications, configure target deployment environments, and deploy software applications. For more information, see DevOps (https://docs.cloud.oracle.com/Content/devops/using/home.htm).
//
package devops
import (
"fmt"
"github.com/oracle/oci-go-sdk/v65/common"
"strings"
)
// Repository Repositories containing the source code to build and deploy.
type Repository struct {
// The OCID of the repository. This value is unique and immutable.
Id *string `mandatory:"true" json:"id"`
// The OCID of the repository's compartment.
CompartmentId *string `mandatory:"true" json:"compartmentId"`
// The OCID of the DevOps project containing the repository.
ProjectId *string `mandatory:"true" json:"projectId"`
// Unique name of a repository. This value is mutable.
Name *string `mandatory:"false" json:"name"`
// Tenancy unique namespace.
Namespace *string `mandatory:"false" json:"namespace"`
// Unique project name in a namespace.
ProjectName *string `mandatory:"false" json:"projectName"`
// SSH URL that you use to git clone, pull and push.
SshUrl *string `mandatory:"false" json:"sshUrl"`
// HTTP URL that you use to git clone, pull and push.
HttpUrl *string `mandatory:"false" json:"httpUrl"`
// Details of the repository. Avoid entering confidential information.
Description *string `mandatory:"false" json:"description"`
// The default branch of the repository.
DefaultBranch *string `mandatory:"false" json:"defaultBranch"`
// Type of repository:
// MIRRORED - Repository created by mirroring an existing repository.
// HOSTED - Repository created and hosted using OCI DevOps code repository.
RepositoryType RepositoryRepositoryTypeEnum `mandatory:"false" json:"repositoryType,omitempty"`
MirrorRepositoryConfig *MirrorRepositoryConfig `mandatory:"false" json:"mirrorRepositoryConfig"`
// The time the repository was created. Format defined by RFC3339 (https://datatracker.ietf.org/doc/html/rfc3339).
TimeCreated *common.SDKTime `mandatory:"false" json:"timeCreated"`
// The time the repository was updated. Format defined by RFC3339 (https://datatracker.ietf.org/doc/html/rfc3339).
TimeUpdated *common.SDKTime `mandatory:"false" json:"timeUpdated"`
// The current state of the repository.
LifecycleState RepositoryLifecycleStateEnum `mandatory:"false" json:"lifecycleState,omitempty"`
// A message describing the current state in more detail. For example, can be used to provide actionable information for a resource in Failed state.
LifecyleDetails *string `mandatory:"false" json:"lifecyleDetails"`
// The count of the branches present in the repository.
BranchCount *int `mandatory:"false" json:"branchCount"`
// The count of the commits present in the repository.
CommitCount *int `mandatory:"false" json:"commitCount"`
// The size of the repository in bytes.
SizeInBytes *int64 `mandatory:"false" json:"sizeInBytes"`
// Trigger build events supported for this repository:
// PUSH - Build is triggered when a push event occurs.
// COMMIT_UPDATES - Build is triggered when new commits are mirrored into a repository.
TriggerBuildEvents []RepositoryTriggerBuildEventsEnum `mandatory:"false" json:"triggerBuildEvents,omitempty"`
// Simple key-value pair that is applied without any predefined name, type or scope. Exists for cross-compatibility only. See Resource Tags (https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm). Example: `{"bar-key": "value"}`
FreeformTags map[string]string `mandatory:"false" json:"freeformTags"`
// Defined tags for this resource. Each key is predefined and scoped to a namespace. See Resource Tags (https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm). Example: `{"foo-namespace": {"bar-key": "value"}}`
DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"`
// Usage of system tag keys. These predefined keys are scoped to namespaces. See Resource Tags (https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm). Example: `{"orcl-cloud": {"free-tier-retained": "true"}}`
SystemTags map[string]map[string]interface{} `mandatory:"false" json:"systemTags"`
}
func (m Repository) 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 Repository) ValidateEnumValue() (bool, error) {
errMessage := []string{}
if _, ok := GetMappingRepositoryRepositoryTypeEnum(string(m.RepositoryType)); !ok && m.RepositoryType != "" {
errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for RepositoryType: %s. Supported values are: %s.", m.RepositoryType, strings.Join(GetRepositoryRepositoryTypeEnumStringValues(), ",")))
}
if _, ok := GetMappingRepositoryLifecycleStateEnum(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(GetRepositoryLifecycleStateEnumStringValues(), ",")))
}
for _, val := range m.TriggerBuildEvents {
if _, ok := GetMappingRepositoryTriggerBuildEventsEnum(string(val)); !ok && val != "" {
errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for TriggerBuildEvents: %s. Supported values are: %s.", val, strings.Join(GetRepositoryTriggerBuildEventsEnumStringValues(), ",")))
}
}
if len(errMessage) > 0 {
return true, fmt.Errorf(strings.Join(errMessage, "\n"))
}
return false, nil
}
// RepositoryRepositoryTypeEnum Enum with underlying type: string
type RepositoryRepositoryTypeEnum string
// Set of constants representing the allowable values for RepositoryRepositoryTypeEnum
const (
RepositoryRepositoryTypeMirrored RepositoryRepositoryTypeEnum = "MIRRORED"
RepositoryRepositoryTypeHosted RepositoryRepositoryTypeEnum = "HOSTED"
)
var mappingRepositoryRepositoryTypeEnum = map[string]RepositoryRepositoryTypeEnum{
"MIRRORED": RepositoryRepositoryTypeMirrored,
"HOSTED": RepositoryRepositoryTypeHosted,
}
var mappingRepositoryRepositoryTypeEnumLowerCase = map[string]RepositoryRepositoryTypeEnum{
"mirrored": RepositoryRepositoryTypeMirrored,
"hosted": RepositoryRepositoryTypeHosted,
}
// GetRepositoryRepositoryTypeEnumValues Enumerates the set of values for RepositoryRepositoryTypeEnum
func GetRepositoryRepositoryTypeEnumValues() []RepositoryRepositoryTypeEnum {
values := make([]RepositoryRepositoryTypeEnum, 0)
for _, v := range mappingRepositoryRepositoryTypeEnum {
values = append(values, v)
}
return values
}
// GetRepositoryRepositoryTypeEnumStringValues Enumerates the set of values in String for RepositoryRepositoryTypeEnum
func GetRepositoryRepositoryTypeEnumStringValues() []string {
return []string{
"MIRRORED",
"HOSTED",
}
}
// GetMappingRepositoryRepositoryTypeEnum performs case Insensitive comparison on enum value and return the desired enum
func GetMappingRepositoryRepositoryTypeEnum(val string) (RepositoryRepositoryTypeEnum, bool) {
enum, ok := mappingRepositoryRepositoryTypeEnumLowerCase[strings.ToLower(val)]
return enum, ok
}
// RepositoryLifecycleStateEnum Enum with underlying type: string
type RepositoryLifecycleStateEnum string
// Set of constants representing the allowable values for RepositoryLifecycleStateEnum
const (
RepositoryLifecycleStateActive RepositoryLifecycleStateEnum = "ACTIVE"
RepositoryLifecycleStateCreating RepositoryLifecycleStateEnum = "CREATING"
RepositoryLifecycleStateDeleted RepositoryLifecycleStateEnum = "DELETED"
)
var mappingRepositoryLifecycleStateEnum = map[string]RepositoryLifecycleStateEnum{
"ACTIVE": RepositoryLifecycleStateActive,
"CREATING": RepositoryLifecycleStateCreating,
"DELETED": RepositoryLifecycleStateDeleted,
}
var mappingRepositoryLifecycleStateEnumLowerCase = map[string]RepositoryLifecycleStateEnum{
"active": RepositoryLifecycleStateActive,
"creating": RepositoryLifecycleStateCreating,
"deleted": RepositoryLifecycleStateDeleted,
}
// GetRepositoryLifecycleStateEnumValues Enumerates the set of values for RepositoryLifecycleStateEnum
func GetRepositoryLifecycleStateEnumValues() []RepositoryLifecycleStateEnum {
values := make([]RepositoryLifecycleStateEnum, 0)
for _, v := range mappingRepositoryLifecycleStateEnum {
values = append(values, v)
}
return values
}
// GetRepositoryLifecycleStateEnumStringValues Enumerates the set of values in String for RepositoryLifecycleStateEnum
func GetRepositoryLifecycleStateEnumStringValues() []string {
return []string{
"ACTIVE",
"CREATING",
"DELETED",
}
}
// GetMappingRepositoryLifecycleStateEnum performs case Insensitive comparison on enum value and return the desired enum
func GetMappingRepositoryLifecycleStateEnum(val string) (RepositoryLifecycleStateEnum, bool) {
enum, ok := mappingRepositoryLifecycleStateEnumLowerCase[strings.ToLower(val)]
return enum, ok
}
// RepositoryTriggerBuildEventsEnum Enum with underlying type: string
type RepositoryTriggerBuildEventsEnum string
// Set of constants representing the allowable values for RepositoryTriggerBuildEventsEnum
const (
RepositoryTriggerBuildEventsPush RepositoryTriggerBuildEventsEnum = "PUSH"
RepositoryTriggerBuildEventsCommitUpdates RepositoryTriggerBuildEventsEnum = "COMMIT_UPDATES"
)
var mappingRepositoryTriggerBuildEventsEnum = map[string]RepositoryTriggerBuildEventsEnum{
"PUSH": RepositoryTriggerBuildEventsPush,
"COMMIT_UPDATES": RepositoryTriggerBuildEventsCommitUpdates,
}
var mappingRepositoryTriggerBuildEventsEnumLowerCase = map[string]RepositoryTriggerBuildEventsEnum{
"push": RepositoryTriggerBuildEventsPush,
"commit_updates": RepositoryTriggerBuildEventsCommitUpdates,
}
// GetRepositoryTriggerBuildEventsEnumValues Enumerates the set of values for RepositoryTriggerBuildEventsEnum
func GetRepositoryTriggerBuildEventsEnumValues() []RepositoryTriggerBuildEventsEnum {
values := make([]RepositoryTriggerBuildEventsEnum, 0)
for _, v := range mappingRepositoryTriggerBuildEventsEnum {
values = append(values, v)
}
return values
}
// GetRepositoryTriggerBuildEventsEnumStringValues Enumerates the set of values in String for RepositoryTriggerBuildEventsEnum
func GetRepositoryTriggerBuildEventsEnumStringValues() []string {
return []string{
"PUSH",
"COMMIT_UPDATES",
}
}
// GetMappingRepositoryTriggerBuildEventsEnum performs case Insensitive comparison on enum value and return the desired enum
func GetMappingRepositoryTriggerBuildEventsEnum(val string) (RepositoryTriggerBuildEventsEnum, bool) {
enum, ok := mappingRepositoryTriggerBuildEventsEnumLowerCase[strings.ToLower(val)]
return enum, ok
}