genai-for-marketing/infra/app.tf (131 lines of code) (raw):
/**
* Copyright 2022 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.
*/
resource "google_artifact_registry_repository" "docker-repo" {
project = var.project_id
location = "us-central1"
repository_id = "docker"
format = "DOCKER"
}
resource "google_secret_manager_secret" "secret-cred" {
project = var.project_id
secret_id = "credentials"
replication {
auto {}
}
}
resource "google_secret_manager_secret_version" "secret-cred-version" {
secret = google_secret_manager_secret.secret-cred.id
secret_data = base64decode(google_service_account_key.sa_key.private_key)
}
resource "null_resource" "backend_deployment" {
triggers = {
sa = module.genai_run_service_account.service_account.name
}
provisioner "local-exec" {
command = "cp -rf ../installation_scripts/backend_deployment.sh aux_data/"
}
provisioner "local-exec" {
interpreter = ["/bin/bash", "-c"]
command = "sh aux_data/backend_deployment.sh ${var.region} ${module.genai_run_service_account.email}"
}
depends_on = [google_artifact_registry_repository.docker-repo, local_file.config_toml, local_file.dockerfile]
}
data "google_cloud_run_service" "run_service" {
project = var.project_id
name = "genai-for-marketing"
location = var.region
depends_on = [null_resource.backend_deployment]
}
resource "google_firebase_project" "firebase" {
provider = google-beta
project = var.project_id
}
resource "google_firebase_web_app" "app_front" {
provider = google-beta
project = var.project_id
display_name = "GenAI for marketing"
}
data "google_firebase_web_app_config" "app_front" {
project = var.project_id
provider = google-beta
web_app_id = google_firebase_web_app.app_front.app_id
}
module "gcs_assets_bucket" {
source = "terraform-google-modules/cloud-storage/google"
version = "~> 5.0"
project_id = var.project_id
names = ["marketing"]
prefix = var.project_id
}
resource "local_file" "config_toml" {
content = templatefile("${path.module}/templates/config.toml.tftpl", {
project_id = var.project_id,
region = var.region,
dataset_name = var.dataset_name,
credentials_secret_name = google_secret_manager_secret_version.secret-cred-version.name,
search_datastore_id = google_discovery_engine_data_store.search_datastore.data_store_id,
tag_template_id = var.tag_template_id,
drive_folder_id = local.gdrive_resuts.GDRIVE_FOLDER_ID,
slides_template_id = local.gdrive_resuts.MarketingPptID,
doc_template_id = local.gdrive_resuts.MarketingDocID,
sheet_template_id = local.gdrive_resuts.MarketingExcelID,
domain = var.domain,
gcs_assets_bucket = module.gcs_assets_bucket.name
}
)
filename = "${path.module}/templates/config.toml"
}
resource "local_file" "dockerfile" {
content = templatefile("${path.module}/templates/Dockerfile.tftpl", {
project_id = var.project_id
}
)
filename = "${path.module}/templates/Dockerfile"
}
resource "local_file" "enviroments_ts" {
content = templatefile("${path.module}/templates/environments.ts.tftpl", {
run_service_url = data.google_cloud_run_service.run_service.status[0].url,
fb_api_key = data.google_firebase_web_app_config.app_front.api_key,
fb_auth_domain = data.google_firebase_web_app_config.app_front.auth_domain,
fb_project_id = var.project_id,
fb_storage_bucket = lookup(data.google_firebase_web_app_config.app_front, "storage_bucket", ""),
fb_messaging_sender_id = lookup(data.google_firebase_web_app_config.app_front, "messaging_sender_id", ""),
fb_api_id = google_firebase_web_app.app_front.app_id,
fb_measurement_id = lookup(data.google_firebase_web_app_config.app_front, "measurement_id", ""),
dialogflow_cx_agent_id = google_discovery_engine_chat_engine.chat_app.chat_engine_metadata[0].dialogflow_agent
}
)
filename = "${path.module}/templates/environments.ts"
}
resource "null_resource" "frontend_deployment" {
triggers = {
sa = module.genai_run_service_account.service_account.name
}
provisioner "local-exec" {
command = "cp -rf ../installation_scripts/frontend_deployment.sh aux_data/"
}
provisioner "local-exec" {
interpreter = ["/bin/bash", "-c"]
command = "sh aux_data/frontend_deployment.sh ${var.project_id}"
}
depends_on = [google_artifact_registry_repository.docker-repo, local_file.enviroments_ts]
}
resource "google_firestore_database" "database" {
project = var.project_id
name = "(default)"
location_id = var.region
type = "FIRESTORE_NATIVE"
}