blob: 44b137c60be1a7c43f1296830617ff2510ef055c [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.
*/
resource "google_project_service" "required" {
for_each = toset([
"container",
"iam",
])
service = "${each.key}.googleapis.com"
disable_on_destroy = false
}
// Query the VPC network to make sure it exists.
data "google_compute_network" "default" {
depends_on = [google_project_service.required]
name = var.network
}
// Query the VPC subnetwork to make sure it exists in the region specified.
data "google_compute_subnetwork" "default" {
depends_on = [google_project_service.required]
name = var.subnetwork
region = var.region
lifecycle {
postcondition {
condition = self.private_ip_google_access
error_message = <<EOT
fatal: ${self.id} misconfigured: private Google access disabled.
See https://cloud.google.com/vpc/docs/configure-private-google-access for details.
EOT
}
}
}
// Query the Google Compute Router to make sure it exists; needed to access resources outside the VPC network
// for private nodes.
data "google_compute_router" "default" {
name = var.router
network = data.google_compute_network.default.name
region = data.google_compute_subnetwork.default.region
}
// Query the Google Compute Router NAT to make sure it exists.
data "google_compute_router_nat" "default" {
name = var.router_nat
router = data.google_compute_router.default.name
region = data.google_compute_router.default.region
}
// Query the Service Account.
data "google_service_account" "default" {
depends_on = [google_project_service.required]
account_id = var.service_account_id
}