-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmain.k
105 lines (97 loc) · 3.6 KB
/
main.k
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
import models.io.upbound.azure.network.v1beta1 as networkv1beta1
import models.io.upbound.azure.network.v1beta2 as networkv1beta2
import models.io.upbound.azure.v1alpha1 as azurev1alpha1
import models.io.upbound.azure.v1beta1 as azurev1beta1
import models.io.upbound.platform.azure.v1alpha1 as platformazurev1alpha1
import models.k8s.apimachinery.pkg.apis.meta.v1 as metav1
# observed composite resource
oxr = platformazurev1alpha1.XNetwork{**option("params").oxr}
params = oxr.spec.parameters
# observed composed resources
_ocds = option("params").ocds
# desired composite resource
_dxr = option("params").dxr
# desired composed resources
dcds = option("params").dcds
_metadata = lambda name: str -> any {
{
name = name
annotations = {"krm.kcl.dev/composition-resource-name" = name}
labels = {"azure.platform.upbound.io/network-id" = params.id}
}
}
# Helper function to add common spec fields
_add_common_spec_fields = lambda spec: any -> any {
spec | {
deletionPolicy = params.deletionPolicy
providerConfigRef.name = params.providerConfigName
}
}
# Base network resources
_base_resources = [
# Resource Group
azurev1beta1.ResourceGroup {
metadata = _metadata("${params.id}-rg")
spec = _add_common_spec_fields(azurev1beta1.AzureUpboundIoV1beta1ResourceGroupSpec {
forProvider = {
location = params.region
}
})
}
# Virtual Network
networkv1beta2.VirtualNetwork {
metadata = _metadata("${params.id}-vnet")
spec = _add_common_spec_fields(networkv1beta2.NetworkAzureUpboundIoV1beta2VirtualNetworkSpec {
forProvider = {
location = params.region
addressSpace = [params.addressRange]
resourceGroupNameSelector = {
matchControllerRef = True
}
}
})
}
# Subnet for general use
networkv1beta2.Subnet {
metadata = _metadata("${params.id}-sn")
spec = _add_common_spec_fields(networkv1beta2.NetworkAzureUpboundIoV1beta2SubnetSpec {
forProvider = {
addressPrefixes = [params.generalSubnetRange]
resourceGroupNameSelector = {
matchControllerRef = True
}
serviceEndpoints = ["Microsoft.Sql"]
virtualNetworkNameSelector = {
matchControllerRef = True
}
}
})
}
]
# Database subnets (optional)
_subnets_from_spec = params.databaseSubnets or []
_database_subnets = [
networkv1beta2.Subnet {
metadata = _metadata("${params.id}-db-sn-${index}")
spec = _add_common_spec_fields(networkv1beta2.NetworkAzureUpboundIoV1beta2SubnetSpec {
forProvider = {
addressPrefixes = [subnet.addressRange]
delegation = [{
name = "fs"
serviceDelegation = {
actions = ["Microsoft.Network/virtualNetworks/subnets/join/action"]
name = "Microsoft.DBforPostgreSQL/flexibleServers" if subnet.serviceType == "postgresql" else "Microsoft.DBforMySQL/flexibleServers"
}
}]
resourceGroupNameSelector = {
matchControllerRef = True
}
serviceEndpoints = ["Microsoft.Storage"]
virtualNetworkNameSelector = {
matchControllerRef = True
}
}
})
} for index, subnet in _subnets_from_spec
]
items = _base_resources + _database_subnets