-
Notifications
You must be signed in to change notification settings - Fork 129
/
Copy pathaddons-aws-load-balancer-controller-appset.yaml
82 lines (82 loc) · 3.21 KB
/
addons-aws-load-balancer-controller-appset.yaml
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
---
apiVersion: argoproj.io/v1alpha1
kind: ApplicationSet
metadata:
name: addons-aws-load-balancer-controller
spec:
syncPolicy:
preserveResourcesOnDeletion: true
generators:
- merge:
mergeKeys: [server]
generators:
- clusters:
values:
addonChart: aws-load-balancer-controller
# anything not staging or prod use this version
addonChartVersion: 1.7.1
addonChartRepository: https://aws.github.io/eks-charts
selector:
matchExpressions:
- key: akuity.io/argo-cd-cluster-name
operator: NotIn
values: [in-cluster]
- key: enable_aws_load_balancer_controller
operator: In
values: ['true']
- clusters:
selector:
matchLabels:
environment: staging
values:
addonChartVersion: 1.7.1
- clusters:
selector:
matchLabels:
environment: prod
values:
addonChartVersion: 1.7.1
template:
metadata:
name: addon-{{name}}-{{values.addonChart}}
spec:
project: default
sources:
- repoURL: '{{metadata.annotations.addons_repo_url}}'
targetRevision: '{{metadata.annotations.addons_repo_revision}}'
ref: values
- chart: '{{values.addonChart}}'
repoURL: '{{values.addonChartRepository}}'
targetRevision: '{{values.addonChartVersion}}'
helm:
releaseName: '{{values.addonChart}}'
ignoreMissingValueFiles: true
valueFiles:
- $values/{{metadata.annotations.addons_repo_basepath}}environments/default/addons/{{values.addonChart}}/values.yaml
- $values/{{metadata.annotations.addons_repo_basepath}}environments/{{metadata.labels.environment}}/addons/{{values.addonChart}}/values.yaml
- $values/{{metadata.annotations.addons_repo_basepath}}clusters/{{name}}/addons/{{values.addonChart}}/values.yaml
values: |
vpcId: '{{metadata.annotations.aws_vpc_id}}'
clusterName: {{metadata.annotations.aws_cluster_name}}
serviceAccount:
name: {{metadata.annotations.aws_load_balancer_controller_service_account}}
annotations:
eks.amazonaws.com/role-arn: {{metadata.annotations.aws_load_balancer_controller_iam_role_arn}}
destination:
namespace: '{{metadata.annotations.aws_load_balancer_controller_namespace}}'
name: '{{name}}'
syncPolicy:
automated: {}
syncOptions:
- CreateNamespace=true
- ServerSideApply=true # Big CRDs.
ignoreDifferences:
- kind: Secret
name: aws-load-balancer-tls
jsonPointers: [/data]
- group: admissionregistration.k8s.io
kind: MutatingWebhookConfiguration
jqPathExpressions: ['.webhooks[].clientConfig.caBundle']
- group: admissionregistration.k8s.io
kind: ValidatingWebhookConfiguration
jqPathExpressions: ['.webhooks[].clientConfig.caBundle']