-
Notifications
You must be signed in to change notification settings - Fork 69
/
zz_systemtopic_types.go
executable file
·164 lines (124 loc) · 8.97 KB
/
zz_systemtopic_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
/*
Copyright 2022 Upbound Inc.
*/
// 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 SystemTopicIdentityObservation struct {
// Specifies a list of User Assigned Managed Identity IDs to be assigned to this Event Grid System Topic.
IdentityIds []*string `json:"identityIds,omitempty" tf:"identity_ids,omitempty"`
// The Principal ID associated with this Managed Service Identity.
PrincipalID *string `json:"principalId,omitempty" tf:"principal_id,omitempty"`
// The Tenant ID associated with this Managed Service Identity.
TenantID *string `json:"tenantId,omitempty" tf:"tenant_id,omitempty"`
// Specifies the type of Managed Service Identity that should be configured on this Event Grid System Topic. Possible values are SystemAssigned, UserAssigned.
Type *string `json:"type,omitempty" tf:"type,omitempty"`
}
type SystemTopicIdentityParameters struct {
// Specifies a list of User Assigned Managed Identity IDs to be assigned to this Event Grid System Topic.
// +kubebuilder:validation:Optional
IdentityIds []*string `json:"identityIds,omitempty" tf:"identity_ids,omitempty"`
// Specifies the type of Managed Service Identity that should be configured on this Event Grid System Topic. Possible values are SystemAssigned, UserAssigned.
// +kubebuilder:validation:Required
Type *string `json:"type" tf:"type,omitempty"`
}
type SystemTopicObservation struct {
// The ID of the Event Grid System Topic.
ID *string `json:"id,omitempty" tf:"id,omitempty"`
// An identity block as defined below.
Identity []SystemTopicIdentityObservation `json:"identity,omitempty" tf:"identity,omitempty"`
// The Azure Region where the Event Grid System Topic should exist. Changing this forces a new Event Grid System Topic to be created.
Location *string `json:"location,omitempty" tf:"location,omitempty"`
// The Metric ARM Resource ID of the Event Grid System Topic.
MetricArmResourceID *string `json:"metricArmResourceId,omitempty" tf:"metric_arm_resource_id,omitempty"`
// The name of the Resource Group where the Event Grid System Topic should exist. Changing this forces a new Event Grid System Topic to be created.
ResourceGroupName *string `json:"resourceGroupName,omitempty" tf:"resource_group_name,omitempty"`
// The ID of the Event Grid System Topic ARM Source. Changing this forces a new Event Grid System Topic to be created.
SourceArmResourceID *string `json:"sourceArmResourceId,omitempty" tf:"source_arm_resource_id,omitempty"`
// A mapping of tags which should be assigned to the Event Grid System Topic.
Tags map[string]*string `json:"tags,omitempty" tf:"tags,omitempty"`
// The Topic Type of the Event Grid System Topic. The topic type is validated by Azure and there may be additional topic types beyond the following: Microsoft.AppConfiguration.ConfigurationStores, Microsoft.Communication.CommunicationServices, Microsoft.ContainerRegistry.Registries, Microsoft.Devices.IoTHubs, Microsoft.EventGrid.Domains, Microsoft.EventGrid.Topics, Microsoft.Eventhub.Namespaces, Microsoft.KeyVault.vaults, Microsoft.MachineLearningServices.Workspaces, Microsoft.Maps.Accounts, Microsoft.Media.MediaServices, Microsoft.Resources.ResourceGroups, Microsoft.Resources.Subscriptions, Microsoft.ServiceBus.Namespaces, Microsoft.SignalRService.SignalR, Microsoft.Storage.StorageAccounts, Microsoft.Web.ServerFarms and Microsoft.Web.Sites. Changing this forces a new Event Grid System Topic to be created.
TopicType *string `json:"topicType,omitempty" tf:"topic_type,omitempty"`
}
type SystemTopicParameters struct {
// An identity block as defined below.
// +kubebuilder:validation:Optional
Identity []SystemTopicIdentityParameters `json:"identity,omitempty" tf:"identity,omitempty"`
// The Azure Region where the Event Grid System Topic should exist. Changing this forces a new Event Grid System Topic to be created.
// +kubebuilder:validation:Optional
Location *string `json:"location,omitempty" tf:"location,omitempty"`
// The name of the Resource Group where the Event Grid System Topic should exist. Changing this forces a new Event Grid System Topic to be created.
// +crossplane:generate:reference:type=github.com/upbound/provider-azure/apis/azure/v1beta1.ResourceGroup
// +kubebuilder:validation:Optional
ResourceGroupName *string `json:"resourceGroupName,omitempty" tf:"resource_group_name,omitempty"`
// Reference to a ResourceGroup in azure to populate resourceGroupName.
// +kubebuilder:validation:Optional
ResourceGroupNameRef *v1.Reference `json:"resourceGroupNameRef,omitempty" tf:"-"`
// Selector for a ResourceGroup in azure to populate resourceGroupName.
// +kubebuilder:validation:Optional
ResourceGroupNameSelector *v1.Selector `json:"resourceGroupNameSelector,omitempty" tf:"-"`
// The ID of the Event Grid System Topic ARM Source. Changing this forces a new Event Grid System Topic to be created.
// +crossplane:generate:reference:type=github.com/upbound/provider-azure/apis/storage/v1beta1.Account
// +crossplane:generate:reference:extractor=github.com/upbound/upjet/pkg/resource.ExtractResourceID()
// +kubebuilder:validation:Optional
SourceArmResourceID *string `json:"sourceArmResourceId,omitempty" tf:"source_arm_resource_id,omitempty"`
// Reference to a Account in storage to populate sourceArmResourceId.
// +kubebuilder:validation:Optional
SourceArmResourceIDRef *v1.Reference `json:"sourceArmResourceIdRef,omitempty" tf:"-"`
// Selector for a Account in storage to populate sourceArmResourceId.
// +kubebuilder:validation:Optional
SourceArmResourceIDSelector *v1.Selector `json:"sourceArmResourceIdSelector,omitempty" tf:"-"`
// A mapping of tags which should be assigned to the Event Grid System Topic.
// +kubebuilder:validation:Optional
Tags map[string]*string `json:"tags,omitempty" tf:"tags,omitempty"`
// The Topic Type of the Event Grid System Topic. The topic type is validated by Azure and there may be additional topic types beyond the following: Microsoft.AppConfiguration.ConfigurationStores, Microsoft.Communication.CommunicationServices, Microsoft.ContainerRegistry.Registries, Microsoft.Devices.IoTHubs, Microsoft.EventGrid.Domains, Microsoft.EventGrid.Topics, Microsoft.Eventhub.Namespaces, Microsoft.KeyVault.vaults, Microsoft.MachineLearningServices.Workspaces, Microsoft.Maps.Accounts, Microsoft.Media.MediaServices, Microsoft.Resources.ResourceGroups, Microsoft.Resources.Subscriptions, Microsoft.ServiceBus.Namespaces, Microsoft.SignalRService.SignalR, Microsoft.Storage.StorageAccounts, Microsoft.Web.ServerFarms and Microsoft.Web.Sites. Changing this forces a new Event Grid System Topic to be created.
// +kubebuilder:validation:Optional
TopicType *string `json:"topicType,omitempty" tf:"topic_type,omitempty"`
}
// SystemTopicSpec defines the desired state of SystemTopic
type SystemTopicSpec struct {
v1.ResourceSpec `json:",inline"`
ForProvider SystemTopicParameters `json:"forProvider"`
}
// SystemTopicStatus defines the observed state of SystemTopic.
type SystemTopicStatus struct {
v1.ResourceStatus `json:",inline"`
AtProvider SystemTopicObservation `json:"atProvider,omitempty"`
}
// +kubebuilder:object:root=true
// SystemTopic is the Schema for the SystemTopics API. Manages an Event Grid System Topic
// +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,azure}
type SystemTopic struct {
metav1.TypeMeta `json:",inline"`
metav1.ObjectMeta `json:"metadata,omitempty"`
// +kubebuilder:validation:XValidation:rule="self.managementPolicy == 'ObserveOnly' || has(self.forProvider.location)",message="location is a required parameter"
// +kubebuilder:validation:XValidation:rule="self.managementPolicy == 'ObserveOnly' || has(self.forProvider.topicType)",message="topicType is a required parameter"
Spec SystemTopicSpec `json:"spec"`
Status SystemTopicStatus `json:"status,omitempty"`
}
// +kubebuilder:object:root=true
// SystemTopicList contains a list of SystemTopics
type SystemTopicList struct {
metav1.TypeMeta `json:",inline"`
metav1.ListMeta `json:"metadata,omitempty"`
Items []SystemTopic `json:"items"`
}
// Repository type metadata.
var (
SystemTopic_Kind = "SystemTopic"
SystemTopic_GroupKind = schema.GroupKind{Group: CRDGroup, Kind: SystemTopic_Kind}.String()
SystemTopic_KindAPIVersion = SystemTopic_Kind + "." + CRDGroupVersion.String()
SystemTopic_GroupVersionKind = CRDGroupVersion.WithKind(SystemTopic_Kind)
)
func init() {
SchemeBuilder.Register(&SystemTopic{}, &SystemTopicList{})
}