Skip to content

Commit 7d970fd

Browse files
author
Andrew Trice
authored
updated tf dependencies for generating helm chart (#23)
Signed-off-by: Andrew Trice <[email protected]>
1 parent 3d868df commit 7d970fd

File tree

1 file changed

+60
-58
lines changed

1 file changed

+60
-58
lines changed

main.tf

Lines changed: 60 additions & 58 deletions
Original file line numberDiff line numberDiff line change
@@ -1,31 +1,31 @@
11

22
locals {
3-
tmp_dir = "${path.cwd}/.tmp"
4-
ingress_host = "${var.hostname}-${var.releases_namespace}.${var.cluster_ingress_hostname}"
5-
ingress_url = "https://${local.ingress_host}"
6-
service_url = "http://sonarqube-sonarqube.${var.releases_namespace}:9000"
7-
secret_name = "sonarqube-access"
8-
config_name = "sonarqube-config"
3+
tmp_dir = "${path.cwd}/.tmp"
4+
ingress_host = "${var.hostname}-${var.releases_namespace}.${var.cluster_ingress_hostname}"
5+
ingress_url = "https://${local.ingress_host}"
6+
service_url = "http://sonarqube-sonarqube.${var.releases_namespace}:9000"
7+
secret_name = "sonarqube-access"
8+
config_name = "sonarqube-config"
99
config_sa_name = "sonarqube-job-sa"
10-
gitops_dir = var.gitops_dir != "" ? var.gitops_dir : "${path.cwd}/gitops"
11-
chart_dir = "${local.gitops_dir}/sonarqube"
12-
global_config = {
13-
storageClass = var.storage_class
14-
clusterType = var.cluster_type
10+
gitops_dir = var.gitops_dir != "" ? var.gitops_dir : "${path.cwd}/gitops"
11+
chart_dir = "${local.gitops_dir}/sonarqube"
12+
global_config = {
13+
storageClass = var.storage_class
14+
clusterType = var.cluster_type
1515
ingressSubdomain = var.cluster_ingress_hostname
1616
}
1717
sonarqube_config = {
1818
persistence = {
19-
enabled = false
19+
enabled = false
2020
storageClass = var.storage_class
2121
}
2222
serviceAccount = {
2323
create = true
24-
name = var.service_account_name
24+
name = var.service_account_name
2525
}
2626
postgresql = {
27-
enabled = !var.postgresql.external
28-
postgresqlServer = var.postgresql.external ? var.postgresql.hostname : ""
27+
enabled = !var.postgresql.external
28+
postgresqlServer = var.postgresql.external ? var.postgresql.hostname : ""
2929
postgresqlDatabase = var.postgresql.external ? var.postgresql.database_name : "sonarDB"
3030
postgresqlUsername = var.postgresql.external ? var.postgresql.username : "sonarUser"
3131
postgresqlPassword = var.postgresql.external ? var.postgresql.password : "sonarPass"
@@ -34,10 +34,10 @@ locals {
3434
}
3535
serviceAccount = {
3636
enabled = true
37-
name = var.service_account_name
37+
name = var.service_account_name
3838
}
3939
persistence = {
40-
enabled = false
40+
enabled = false
4141
storageClass = var.storage_class
4242
}
4343
volumePermissions = {
@@ -47,10 +47,10 @@ locals {
4747
ingress = {
4848
enabled = var.cluster_type == "kubernetes"
4949
annotations = {
50-
"kubernetes.io/ingress.class" = "nginx"
50+
"kubernetes.io/ingress.class" = "nginx"
5151
"nginx.ingress.kubernetes.io/proxy-body-size" = "20m"
52-
"ingress.kubernetes.io/proxy-body-size" = "20M"
53-
"ingress.bluemix.net/client-max-body-size" = "20m"
52+
"ingress.kubernetes.io/proxy-body-size" = "20M"
53+
"ingress.bluemix.net/client-max-body-size" = "20m"
5454
}
5555
hosts = [{
5656
name = local.ingress_host
@@ -67,9 +67,9 @@ locals {
6767
}
6868
}
6969
service_account_config = {
70-
name = var.service_account_name
70+
name = var.service_account_name
7171
create = false
72-
sccs = ["anyuid", "privileged"]
72+
sccs = ["anyuid", "privileged"]
7373
}
7474
config_service_account_config = {
7575
name = local.config_sa_name
@@ -88,72 +88,74 @@ locals {
8888
}
8989
]
9090
}
91-
ocp_route_config = {
92-
nameOverride = "sonarqube"
93-
targetPort = "http"
94-
app = "sonarqube"
95-
serviceName = "sonarqube-sonarqube"
96-
termination = "edge"
91+
ocp_route_config = {
92+
nameOverride = "sonarqube"
93+
targetPort = "http"
94+
app = "sonarqube"
95+
serviceName = "sonarqube-sonarqube"
96+
termination = "edge"
9797
insecurePolicy = "Redirect"
9898
consoleLink = {
99-
enabled = true
100-
section = "Cloud-Native Toolkit"
99+
enabled = true
100+
section = "Cloud-Native Toolkit"
101101
displayName = "SonarQube"
102-
imageUrl = ""
103-
category = "code-analysis"
102+
imageUrl = ""
103+
category = "code-analysis"
104104
}
105105
}
106106
tool_config = {
107-
name = "SonarQube"
107+
name = "SonarQube"
108108
privateUrl = local.service_url
109-
username = "admin"
110-
password = "admin"
109+
username = "admin"
110+
password = "admin"
111111
}
112-
job_config = {
113-
name = "sonarqube"
112+
job_config = {
113+
name = "sonarqube"
114114
serviceAccountName = local.config_sa_name
115-
command = "setup-sonarqube"
115+
command = "setup-sonarqube"
116116
secret = {
117117
name = local.secret_name
118118
key = "SONARQUBE_URL"
119119
}
120120
}
121121
}
122122

123-
module setup_clis {
123+
module "setup_clis" {
124124
source = "github.com/cloud-native-toolkit/terraform-util-clis.git"
125125

126126
clis = ["helm"]
127127
}
128128

129-
resource null_resource print_toolkit_namespace {
129+
resource "null_resource" "print_toolkit_namespace" {
130130
provisioner "local-exec" {
131131
command = "echo 'Toolkit namespace: ${var.toolkit_namespace}'"
132132
}
133133
}
134134

135-
resource null_resource setup-chart {
135+
resource "null_resource" "setup-chart" {
136136
depends_on = [null_resource.print_toolkit_namespace]
137137

138138
provisioner "local-exec" {
139139
command = "mkdir -p ${local.chart_dir} && cp -R ${path.module}/chart/sonarqube/* ${local.chart_dir}"
140140
}
141141
}
142142

143-
resource local_file sonarqube-values {
144-
content = yamlencode({
145-
global = local.global_config
146-
sonarqube = local.sonarqube_config
147-
service-account = local.service_account_config
143+
resource "local_file" "sonarqube-values" {
144+
depends_on = [null_resource.setup-chart]
145+
146+
content = yamlencode({
147+
global = local.global_config
148+
sonarqube = local.sonarqube_config
149+
service-account = local.service_account_config
148150
config-service-account = local.config_service_account_config
149-
ocp-route = local.ocp_route_config
150-
tool-config = local.tool_config
151-
setup-job = local.job_config
151+
ocp-route = local.ocp_route_config
152+
tool-config = local.tool_config
153+
setup-job = local.job_config
152154
})
153155
filename = "${local.chart_dir}/values.yaml"
154156
}
155157

156-
resource null_resource print-chart {
158+
resource "null_resource" "print-chart" {
157159
provisioner "local-exec" {
158160
command = "cat ${local_file.sonarqube-values.filename}"
159161
}
@@ -163,15 +165,15 @@ resource null_resource print-chart {
163165
}
164166
}
165167

166-
resource null_resource sonarqube_helm {
167-
depends_on = [local_file.sonarqube-values]
168-
count = var.mode != "setup" ? 1 : 0
168+
resource "null_resource" "sonarqube_helm" {
169+
depends_on = [local_file.sonarqube-values, null_resource.print-chart]
170+
count = var.mode != "setup" ? 1 : 0
169171

170172
triggers = {
171-
bin_dir = module.setup_clis.bin_dir
172-
namespace = var.releases_namespace
173+
bin_dir = module.setup_clis.bin_dir
174+
namespace = var.releases_namespace
173175
kubeconfig = var.cluster_config_file
174-
name = "sonarqube"
176+
name = "sonarqube"
175177
}
176178

177179
provisioner "local-exec" {
@@ -192,9 +194,9 @@ resource null_resource sonarqube_helm {
192194
}
193195
}
194196

195-
resource null_resource wait-for-config-job {
197+
resource "null_resource" "wait-for-config-job" {
196198
depends_on = [null_resource.sonarqube_helm]
197-
count = var.mode != "setup" ? 1 : 0
199+
count = var.mode != "setup" ? 1 : 0
198200

199201
provisioner "local-exec" {
200202
command = "kubectl wait -n ${var.releases_namespace} --for=condition=complete --timeout=30m job -l app=sonarqube"

0 commit comments

Comments
 (0)