11
22locals {
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