-
Notifications
You must be signed in to change notification settings - Fork 64
/
zz_datasetaccess_types.go
executable file
·238 lines (187 loc) · 9.66 KB
/
zz_datasetaccess_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
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
/*
Copyright 2021 The Crossplane Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
// 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 DatasetAccessDatasetDatasetObservation struct {
}
type DatasetAccessDatasetDatasetParameters struct {
// The ID of the dataset containing this table.
// +crossplane:generate:reference:type=github.com/upbound/provider-gcp/apis/bigquery/v1beta1.Dataset
// +kubebuilder:validation:Optional
DatasetID *string `json:"datasetId,omitempty" tf:"dataset_id,omitempty"`
// Reference to a Dataset in bigquery to populate datasetId.
// +kubebuilder:validation:Optional
DatasetIDRef *v1.Reference `json:"datasetIdRef,omitempty" tf:"-"`
// Selector for a Dataset in bigquery to populate datasetId.
// +kubebuilder:validation:Optional
DatasetIDSelector *v1.Selector `json:"datasetIdSelector,omitempty" tf:"-"`
// The ID of the project containing this table.
// +kubebuilder:validation:Required
ProjectID *string `json:"projectId" tf:"project_id,omitempty"`
}
type DatasetAccessDatasetObservation struct {
}
type DatasetAccessDatasetParameters struct {
// The dataset this entry applies to
// Structure is documented below.
// +kubebuilder:validation:Required
Dataset []DatasetAccessDatasetDatasetParameters `json:"dataset" tf:"dataset,omitempty"`
// Which resources in the dataset this entry applies to. Currently, only views are supported,
// but additional target types may be added in the future. Possible values: VIEWS
// +kubebuilder:validation:Required
TargetTypes []*string `json:"targetTypes" tf:"target_types,omitempty"`
}
type DatasetAccessObservation struct {
APIUpdatedMember *bool `json:"apiUpdatedMember,omitempty" tf:"api_updated_member,omitempty"`
// an identifier for the resource with format projects/{{project}}/datasets/{{dataset_id}}
ID *string `json:"id,omitempty" tf:"id,omitempty"`
}
type DatasetAccessParameters struct {
// Grants all resources of particular types in a particular dataset read access to the current dataset.
// Structure is documented below.
// +kubebuilder:validation:Optional
Dataset []DatasetAccessDatasetParameters `json:"dataset,omitempty" tf:"dataset,omitempty"`
// A unique ID for this dataset, without the project name. The ID
// must contain only letters (a-z, A-Z), numbers (0-9), or
// underscores (_). The maximum length is 1,024 characters.
// +crossplane:generate:reference:type=github.com/upbound/provider-gcp/apis/bigquery/v1beta1.Dataset
// +kubebuilder:validation:Optional
DatasetID *string `json:"datasetId,omitempty" tf:"dataset_id,omitempty"`
// Reference to a Dataset in bigquery to populate datasetId.
// +kubebuilder:validation:Optional
DatasetIDRef *v1.Reference `json:"datasetIdRef,omitempty" tf:"-"`
// Selector for a Dataset in bigquery to populate datasetId.
// +kubebuilder:validation:Optional
DatasetIDSelector *v1.Selector `json:"datasetIdSelector,omitempty" tf:"-"`
// A domain to grant access to. Any users signed in with the
// domain specified will be granted the specified access
// +kubebuilder:validation:Optional
Domain *string `json:"domain,omitempty" tf:"domain,omitempty"`
// An email address of a Google Group to grant access to.
// +kubebuilder:validation:Optional
GroupByEmail *string `json:"groupByEmail,omitempty" tf:"group_by_email,omitempty"`
// Some other type of member that appears in the IAM Policy but isn't a user,
// group, domain, or special group. For example: allUsers
// +kubebuilder:validation:Optional
IAMMember *string `json:"iamMember,omitempty" tf:"iam_member,omitempty"`
// The ID of the project in which the resource belongs.
// If it is not provided, the provider project is used.
// +kubebuilder:validation:Optional
Project *string `json:"project,omitempty" tf:"project,omitempty"`
// Describes the rights granted to the user specified by the other
// member of the access object. Basic, predefined, and custom roles are
// supported. Predefined roles that have equivalent basic roles are
// swapped by the API to their basic counterparts, and will show a diff
// post-create. See
// official docs.
// +kubebuilder:validation:Optional
Role *string `json:"role,omitempty" tf:"role,omitempty"`
// A special group to grant access to. Possible values include:
// +kubebuilder:validation:Optional
SpecialGroup *string `json:"specialGroup,omitempty" tf:"special_group,omitempty"`
// An email address of a user to grant access to. For example:
// fred@example.com
// +crossplane:generate:reference:type=github.com/upbound/provider-gcp/apis/cloudplatform/v1beta1.ServiceAccount
// +crossplane:generate:reference:extractor=github.com/upbound/upjet/pkg/resource.ExtractParamPath("email",true)
// +kubebuilder:validation:Optional
UserByEmail *string `json:"userByEmail,omitempty" tf:"user_by_email,omitempty"`
// Reference to a ServiceAccount in cloudplatform to populate userByEmail.
// +kubebuilder:validation:Optional
UserByEmailRef *v1.Reference `json:"userByEmailRef,omitempty" tf:"-"`
// Selector for a ServiceAccount in cloudplatform to populate userByEmail.
// +kubebuilder:validation:Optional
UserByEmailSelector *v1.Selector `json:"userByEmailSelector,omitempty" tf:"-"`
// A view from a different dataset to grant access to. Queries
// executed against that view will have read access to tables in
// this dataset. The role field is not required when this field is
// set. If that view is updated by any user, access to the view
// needs to be granted again via an update operation.
// Structure is documented below.
// +kubebuilder:validation:Optional
View []DatasetAccessViewParameters `json:"view,omitempty" tf:"view,omitempty"`
}
type DatasetAccessViewObservation struct {
}
type DatasetAccessViewParameters struct {
// The ID of the dataset containing this table.
// +crossplane:generate:reference:type=github.com/upbound/provider-gcp/apis/bigquery/v1beta1.Dataset
// +kubebuilder:validation:Optional
DatasetID *string `json:"datasetId,omitempty" tf:"dataset_id,omitempty"`
// Reference to a Dataset in bigquery to populate datasetId.
// +kubebuilder:validation:Optional
DatasetIDRef *v1.Reference `json:"datasetIdRef,omitempty" tf:"-"`
// Selector for a Dataset in bigquery to populate datasetId.
// +kubebuilder:validation:Optional
DatasetIDSelector *v1.Selector `json:"datasetIdSelector,omitempty" tf:"-"`
// The ID of the project containing this table.
// +kubebuilder:validation:Required
ProjectID *string `json:"projectId" tf:"project_id,omitempty"`
// The ID of the table. The ID must contain only letters (a-z,
// A-Z), numbers (0-9), or underscores (_). The maximum length
// is 1,024 characters.
// +crossplane:generate:reference:type=github.com/upbound/provider-gcp/apis/bigquery/v1beta1.Table
// +kubebuilder:validation:Optional
TableID *string `json:"tableId,omitempty" tf:"table_id,omitempty"`
// Reference to a Table in bigquery to populate tableId.
// +kubebuilder:validation:Optional
TableIDRef *v1.Reference `json:"tableIdRef,omitempty" tf:"-"`
// Selector for a Table in bigquery to populate tableId.
// +kubebuilder:validation:Optional
TableIDSelector *v1.Selector `json:"tableIdSelector,omitempty" tf:"-"`
}
// DatasetAccessSpec defines the desired state of DatasetAccess
type DatasetAccessSpec struct {
v1.ResourceSpec `json:",inline"`
ForProvider DatasetAccessParameters `json:"forProvider"`
}
// DatasetAccessStatus defines the observed state of DatasetAccess.
type DatasetAccessStatus struct {
v1.ResourceStatus `json:",inline"`
AtProvider DatasetAccessObservation `json:"atProvider,omitempty"`
}
// +kubebuilder:object:root=true
// DatasetAccess is the Schema for the DatasetAccesss API. Gives dataset access for a single entity.
// +kubebuilder:printcolumn:name="READY",type="string",JSONPath=".status.conditions[?(@.type=='Ready')].status"
// +kubebuilder:printcolumn:name="SYNCED",type="string",JSONPath=".status.conditions[?(@.type=='Synced')].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:subresource:status
// +kubebuilder:resource:scope=Cluster,categories={crossplane,managed,gcp}
type DatasetAccess struct {
metav1.TypeMeta `json:",inline"`
metav1.ObjectMeta `json:"metadata,omitempty"`
Spec DatasetAccessSpec `json:"spec"`
Status DatasetAccessStatus `json:"status,omitempty"`
}
// +kubebuilder:object:root=true
// DatasetAccessList contains a list of DatasetAccesss
type DatasetAccessList struct {
metav1.TypeMeta `json:",inline"`
metav1.ListMeta `json:"metadata,omitempty"`
Items []DatasetAccess `json:"items"`
}
// Repository type metadata.
var (
DatasetAccess_Kind = "DatasetAccess"
DatasetAccess_GroupKind = schema.GroupKind{Group: CRDGroup, Kind: DatasetAccess_Kind}.String()
DatasetAccess_KindAPIVersion = DatasetAccess_Kind + "." + CRDGroupVersion.String()
DatasetAccess_GroupVersionKind = CRDGroupVersion.WithKind(DatasetAccess_Kind)
)
func init() {
SchemeBuilder.Register(&DatasetAccess{}, &DatasetAccessList{})
}