-
Notifications
You must be signed in to change notification settings - Fork 64
/
zz_accesspolicy_types.go
executable file
·134 lines (106 loc) · 5.86 KB
/
zz_accesspolicy_types.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
// SPDX-FileCopyrightText: 2024 The Crossplane Authors <https://crossplane.io>
//
// SPDX-License-Identifier: Apache-2.0
// Code generated by upjet. DO NOT EDIT.
package v1beta1
import (
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/runtime/schema"
v1 "github.com/crossplane/crossplane-runtime/apis/common/v1"
)
type AccessPolicyInitParameters struct {
// The parent of this AccessPolicy in the Cloud Resource Hierarchy.
// Format: organizations/{organization_id}
Parent *string `json:"parent,omitempty" tf:"parent,omitempty"`
// Folder or project on which this policy is applicable.
// Format: folders/{{folder_id}} or projects/{{project_id}}
Scopes []*string `json:"scopes,omitempty" tf:"scopes,omitempty"`
// Human readable title. Does not affect behavior.
Title *string `json:"title,omitempty" tf:"title,omitempty"`
}
type AccessPolicyObservation struct {
// Time the AccessPolicy was created in UTC.
CreateTime *string `json:"createTime,omitempty" tf:"create_time,omitempty"`
// an identifier for the resource with format {{name}}
ID *string `json:"id,omitempty" tf:"id,omitempty"`
// Resource name of the AccessPolicy. Format: {policy_id}
Name *string `json:"name,omitempty" tf:"name,omitempty"`
// The parent of this AccessPolicy in the Cloud Resource Hierarchy.
// Format: organizations/{organization_id}
Parent *string `json:"parent,omitempty" tf:"parent,omitempty"`
// Folder or project on which this policy is applicable.
// Format: folders/{{folder_id}} or projects/{{project_id}}
Scopes []*string `json:"scopes,omitempty" tf:"scopes,omitempty"`
// Human readable title. Does not affect behavior.
Title *string `json:"title,omitempty" tf:"title,omitempty"`
// Time the AccessPolicy was updated in UTC.
UpdateTime *string `json:"updateTime,omitempty" tf:"update_time,omitempty"`
}
type AccessPolicyParameters struct {
// The parent of this AccessPolicy in the Cloud Resource Hierarchy.
// Format: organizations/{organization_id}
// +kubebuilder:validation:Optional
Parent *string `json:"parent,omitempty" tf:"parent,omitempty"`
// Folder or project on which this policy is applicable.
// Format: folders/{{folder_id}} or projects/{{project_id}}
// +kubebuilder:validation:Optional
Scopes []*string `json:"scopes,omitempty" tf:"scopes,omitempty"`
// Human readable title. Does not affect behavior.
// +kubebuilder:validation:Optional
Title *string `json:"title,omitempty" tf:"title,omitempty"`
}
// AccessPolicySpec defines the desired state of AccessPolicy
type AccessPolicySpec struct {
v1.ResourceSpec `json:",inline"`
ForProvider AccessPolicyParameters `json:"forProvider"`
// THIS IS A BETA FIELD. It will be honored
// unless the Management Policies feature flag is disabled.
// InitProvider holds the same fields as ForProvider, with the exception
// of Identifier and other resource reference fields. The fields that are
// in InitProvider are merged into ForProvider when the resource is created.
// The same fields are also added to the terraform ignore_changes hook, to
// avoid updating them after creation. This is useful for fields that are
// required on creation, but we do not desire to update them after creation,
// for example because of an external controller is managing them, like an
// autoscaler.
InitProvider AccessPolicyInitParameters `json:"initProvider,omitempty"`
}
// AccessPolicyStatus defines the observed state of AccessPolicy.
type AccessPolicyStatus struct {
v1.ResourceStatus `json:",inline"`
AtProvider AccessPolicyObservation `json:"atProvider,omitempty"`
}
// +kubebuilder:object:root=true
// +kubebuilder:subresource:status
// +kubebuilder:storageversion
// AccessPolicy is the Schema for the AccessPolicys API. AccessPolicy is a container for AccessLevels (which define the necessary attributes to use GCP services) and ServicePerimeters (which define regions of services able to freely pass data within a perimeter).
// +kubebuilder:printcolumn:name="SYNCED",type="string",JSONPath=".status.conditions[?(@.type=='Synced')].status"
// +kubebuilder:printcolumn:name="READY",type="string",JSONPath=".status.conditions[?(@.type=='Ready')].status"
// +kubebuilder:printcolumn:name="EXTERNAL-NAME",type="string",JSONPath=".metadata.annotations.crossplane\\.io/external-name"
// +kubebuilder:printcolumn:name="AGE",type="date",JSONPath=".metadata.creationTimestamp"
// +kubebuilder:resource:scope=Cluster,categories={crossplane,managed,gcp}
type AccessPolicy struct {
metav1.TypeMeta `json:",inline"`
metav1.ObjectMeta `json:"metadata,omitempty"`
// +kubebuilder:validation:XValidation:rule="!('*' in self.managementPolicies || 'Create' in self.managementPolicies || 'Update' in self.managementPolicies) || has(self.forProvider.parent) || (has(self.initProvider) && has(self.initProvider.parent))",message="spec.forProvider.parent is a required parameter"
// +kubebuilder:validation:XValidation:rule="!('*' in self.managementPolicies || 'Create' in self.managementPolicies || 'Update' in self.managementPolicies) || has(self.forProvider.title) || (has(self.initProvider) && has(self.initProvider.title))",message="spec.forProvider.title is a required parameter"
Spec AccessPolicySpec `json:"spec"`
Status AccessPolicyStatus `json:"status,omitempty"`
}
// +kubebuilder:object:root=true
// AccessPolicyList contains a list of AccessPolicys
type AccessPolicyList struct {
metav1.TypeMeta `json:",inline"`
metav1.ListMeta `json:"metadata,omitempty"`
Items []AccessPolicy `json:"items"`
}
// Repository type metadata.
var (
AccessPolicy_Kind = "AccessPolicy"
AccessPolicy_GroupKind = schema.GroupKind{Group: CRDGroup, Kind: AccessPolicy_Kind}.String()
AccessPolicy_KindAPIVersion = AccessPolicy_Kind + "." + CRDGroupVersion.String()
AccessPolicy_GroupVersionKind = CRDGroupVersion.WithKind(AccessPolicy_Kind)
)
func init() {
SchemeBuilder.Register(&AccessPolicy{}, &AccessPolicyList{})
}