* var definitions * skeleton, untested * fix errors, test with existing cluster * test vpc creation, todo notes * initial variables for AR and image * initial variables for AR and image * Add support for remote repositories to artifact-registry * Add support for virtual repositories to artifact-registry * Add support for extra config options to artifact-registry * artifact registry module: add validation and precondition, fix tests * ar module id/name * registry * service accoutn and roles * fetch pods, remove image prefix * small changes * use additive IAM at project level * use additive IAM at project level * configmaps * manifests * fix statefulset manifest * service manifest * fix configmap mode * add todo * job (broken) * job * wait on manifest, endpoints datasource * fix job * Fix local * sa * Update README.md * Restructure gke bp * refactor tree and infra variables * no create test * simplify cluster SA * test cluster and vpc creation * project creation fixes * use iam_members variable * nits * readme with examples * readme with examples * outputs * variables, provider configuration * variables, manifests * start cluster job * fix redis cluster creation Co-authored-by: Julio Castillo <juliocc@users.noreply.github.com> * Revert changes in autopilot cluster * Default templates path, use namespace for node names * Update readmes * Fix IAM bindings * Make STABLE the default release channel * Use Cloud DNS as default DNS provider * Allow optional Cloud NAT creation * Allow backup agent and proxy only subnet * Work around terraform not short-circuiting logical operators * Rename create variables to be more consistent with other blueprints * Add basic features * Update variable names * Initial kafka JS * Move providers to a new file * Kafka / Strimzi * First possibily working version for MySQL (with a lot of todo's left) * Explicitly use proxy repo + some other fixes * Strimzi draft * Refactor variables, use CluterIP as pointer for mysql-router for bootstraping * Validate number of replicas, autoscale required number of running nodes to n/2+1 * Use seaprate service for bootstrap, do not recreate all resources on change of replicas count as the config is preserved in PV * Test dual chart kafka * Update chart for kafka * Expose basic kafka configuration options * Remove unused manifest * Added batch blueprint * Added README * switch to kubectl_manifest * Add README and support for static IP address * Move namespace creation to helm * Interpolate kafka variables * Rename kafka-strimzi to kafka * Added TUTORIAL for cloudshell for batch blueprint * deleted tutorial * Remove commented replace trigger * Move to helm chart * WIP of Cloud Shell tutorial for MySQL * Rename folders * Fix rename * Update paths * Unify styles * Update paths * Add Readme links * Update mysql tutorial * Fix path according to self-link * Use relative path to cwd * Fix service_account variable location * Fix tfvars creation * Restore some fixes for helm deployment * Add cluster deletion_prevention * Fixes for tutorial * Update cluster docs * Fixes to batch tutorial * Bare bones readme for batch * Update batch readme * README fixes * Fix README title for redis * Fix Typos * Make it easy to pass variables from autopilot-cluster to other modules * Add connectivity test and bastion host * updates to readme, and gpu fix * Add versions.tf and README updates * Fix typo * Kafka and Redis README updates * Update versions.tf * Fixes * Add boilerplate * Fix linting * Move mysql to separate branch * Update cloud shell links * Fix broken link --------- Co-authored-by: Ludo <ludomagno@google.com> Co-authored-by: Daniel Marzini <44803752+danielmarzini@users.noreply.github.com> Co-authored-by: Wiktor Niesiobędzki <wiktorn@google.com> Co-authored-by: Miren Esnaola <mirene@google.com>
74 lines
2.3 KiB
HCL
74 lines
2.3 KiB
HCL
/**
|
|
* Copyright 2024 Google LLC
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
output "created_resources" {
|
|
description = "IDs of the resources created, if any."
|
|
value = merge(
|
|
var.project_create == null ? {} : {
|
|
project = module.project.project_id
|
|
},
|
|
!local.vpc_create ? {} : {
|
|
subnet_id = one(values(module.vpc.0.subnet_ids))
|
|
vpc_id = module.vpc.0.id
|
|
},
|
|
!var.registry_create ? {} : {
|
|
registry = module.registry.0.image_path
|
|
},
|
|
!local.cluster_create ? {} : {
|
|
cluster = module.cluster.0.id
|
|
node_service_account = module.cluster-service-account.0.email
|
|
},
|
|
!local.create_nat ? {} : {
|
|
router = module.nat.0.id
|
|
cloud_nat = module.nat.0.router.id
|
|
},
|
|
local.proxy_only_subnet == null ? {} : {
|
|
proxy_only_subnet = one(values(module.vpc.0.subnets_proxy_only)).id
|
|
},
|
|
)
|
|
}
|
|
|
|
output "credentials_config" {
|
|
description = "Configure how Terraform authenticates to the cluster."
|
|
value = {
|
|
fleet_host = local.fleet_host
|
|
}
|
|
}
|
|
|
|
output "fleet_host" {
|
|
description = "Fleet Connect Gateway host that can be used to configure the GKE provider."
|
|
value = local.fleet_host
|
|
}
|
|
|
|
output "get_credentials" {
|
|
description = "Run one of these commands to get cluster credentials. Credentials via fleet allow reaching private clusters without no direct connectivity."
|
|
value = {
|
|
direct = join("", [
|
|
"gcloud container clusters get-credentials ${var.cluster_name} ",
|
|
"--project ${var.project_id} --location ${var.region}"
|
|
])
|
|
fleet = join("", [
|
|
"gcloud container fleet memberships get-credentials ${var.cluster_name}",
|
|
" --project ${var.project_id}"
|
|
])
|
|
}
|
|
}
|
|
|
|
output "region" {
|
|
description = "Region used for cluster and network resources."
|
|
value = var.region
|
|
}
|