|
| 1 | +# terraform { |
| 2 | +# required_providers { |
| 3 | +# datadog = { |
| 4 | +# source = "datadog/datadog" |
| 5 | +# } |
| 6 | +# } |
| 7 | +# } |
| 8 | + |
| 9 | +# data "google_secret_manager_secret_version" "datadog_api_key" { |
| 10 | +# secret = "datadog-api-key" |
| 11 | +# project = var.project_id |
| 12 | +# } |
| 13 | + |
| 14 | +# data "google_secret_manager_secret_version" "datadog_app_key" { |
| 15 | +# secret = "datadog-app-key" |
| 16 | +# project = var.project_id |
| 17 | +# } |
| 18 | + |
| 19 | +# provider "datadog" { |
| 20 | +# app_key = data.google_secret_manager_secret_version.datadog_app_key.secret_data |
| 21 | +# api_key = data.google_secret_manager_secret_version.datadog_api_key.secret_data |
| 22 | +# api_url = "https://api.datadoghq.eu/" |
| 23 | +# } |
| 24 | + |
| 25 | +# resource "datadog_integration_gcp" "gcp_project_integration" { |
| 26 | +# project_id = var.project_id |
| 27 | +# private_key_id = jsondecode(base64decode(google_service_account_key.datadog_monitoring.private_key))["private_key_id"] |
| 28 | +# private_key = jsondecode(base64decode(google_service_account_key.datadog_monitoring.private_key))["private_key"] |
| 29 | +# client_email = google_service_account.datadog_gcp_integration.email |
| 30 | +# client_id = google_service_account.datadog_gcp_integration.unique_id |
| 31 | +# } |
| 32 | + |
| 33 | +# resource "google_service_account" "datadog_gcp_integration" { |
| 34 | +# account_id = "appstore-datadog-sa" |
| 35 | +# project = var.project_id |
| 36 | +# display_name = "Datadog <> Google Cloud integration service account" |
| 37 | +# } |
| 38 | + |
| 39 | +# resource "google_service_account_key" "datadog_monitoring" { |
| 40 | +# service_account_id = google_service_account.datadog_gcp_integration.name |
| 41 | +# public_key_type = "TYPE_X509_PEM_FILE" |
| 42 | +# } |
| 43 | + |
| 44 | +# resource "google_logging_project_sink" "log-export-sink" { |
| 45 | +# name = "appstore-datadog-log-sink" |
| 46 | +# destination = module.datadog_pubsub_destination.destination_uri |
| 47 | +# project = var.project_id |
| 48 | +# filter = "resource.type=workflows.googleapis.com/Workflow OR resource.type=cloud_run_revision" |
| 49 | +# unique_writer_identity = true |
| 50 | +# } |
| 51 | + |
| 52 | +# module "datadog_pubsub_destination" { |
| 53 | +# source = "terraform-google-modules/log-export/google//modules/pubsub" |
| 54 | +# create_push_subscriber = true |
| 55 | +# create_subscriber = false |
| 56 | +# log_sink_writer_identity = "serviceAccount:${google_service_account.datadog_gcp_integration.email}" |
| 57 | +# project_id = var.project_id |
| 58 | +# push_endpoint = "https://gcp-intake.logs.datadoghq.eu/v1/input/${data.google_secret_manager_secret_version.datadog_api_key.secret_data}/" |
| 59 | +# topic_name = "datadog-sink" |
| 60 | +# } |
| 61 | + |
| 62 | +# resource "datadog_logs_custom_pipeline" "appstore_cloud_run" { |
| 63 | +# filter { |
| 64 | +# query = "project_id:${var.project_id} source:(\"gcp.cloud.run.revision\" OR \"gcp.workflows.googleapis.com/workflow\")" |
| 65 | +# } |
| 66 | +# name = "${var.project_id} appstore cloud run logs processor" |
| 67 | +# is_enabled = true |
| 68 | +# processor { |
| 69 | +# status_remapper { |
| 70 | +# sources = ["data.severity", "data.jsonPayload.level_name", "data.jsonPayload.level"] |
| 71 | +# name = "Retrieve status from cloud run logs" |
| 72 | +# is_enabled = true |
| 73 | +# } |
| 74 | +# } |
| 75 | +# processor { |
| 76 | +# date_remapper { |
| 77 | +# sources = ["data.timestamp"] |
| 78 | +# name = "Retrieve timestamp from cloud run logs" |
| 79 | +# is_enabled = true |
| 80 | +# } |
| 81 | +# } |
| 82 | +# processor { |
| 83 | +# message_remapper { |
| 84 | +# sources = ["data.jsonPayload.msg", "data.jsonPayload.message"] |
| 85 | +# name = "JSON Payload as log official message" |
| 86 | +# is_enabled = true |
| 87 | +# } |
| 88 | +# } |
| 89 | + |
| 90 | +# } |
| 91 | + |
| 92 | +# resource "google_project_iam_member" "datadog_compute_viewer" { |
| 93 | +# project = var.project_id |
| 94 | +# role = "roles/compute.viewer" |
| 95 | +# member = "serviceAccount:${google_service_account.datadog_gcp_integration.email}" |
| 96 | +# } |
| 97 | + |
| 98 | +# resource "google_project_iam_member" "datadog_monitoring_viewer" { |
| 99 | +# project = var.project_id |
| 100 | +# role = "roles/monitoring.viewer" |
| 101 | +# member = "serviceAccount:${google_service_account.datadog_gcp_integration.email}" |
| 102 | +# } |
| 103 | + |
| 104 | +# resource "google_project_iam_member" "datadog_cloudasset_viewer" { |
| 105 | +# project = var.project_id |
| 106 | +# role = "roles/cloudasset.viewer" |
| 107 | +# member = "serviceAccount:${google_service_account.datadog_gcp_integration.email}" |
| 108 | +# } |
| 109 | + |
| 110 | +# resource "google_project_iam_member" "sink_publisher" { |
| 111 | +# project = var.project_id |
| 112 | +# role = "roles/pubsub.publisher" |
| 113 | +# member = google_logging_project_sink.log-export-sink.writer_identity |
| 114 | +# } |
0 commit comments