Skip to content

Commit f4c0389

Browse files
authored
docs: Create main.tf
Per b/355941670 Create new Terraform quickstart for Eventarc
1 parent 82bafc5 commit f4c0389

File tree

1 file changed

+130
-0
lines changed

1 file changed

+130
-0
lines changed

eventarc/basic_pubsub/main.tf

Lines changed: 130 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,130 @@
1+
/**
2+
* Copyright 2024 Google LLC
3+
*
4+
* Licensed under the Apache License, Version 2.0 (the "License");
5+
* you may not use this file except in compliance with the License.
6+
* You may obtain a copy of the License at
7+
*
8+
* http://www.apache.org/licenses/LICENSE-2.0
9+
*
10+
* Unless required by applicable law or agreed to in writing, software
11+
* distributed under the License is distributed on an "AS IS" BASIS,
12+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
* See the License for the specific language governing permissions and
14+
* limitations under the License.
15+
*/
16+
17+
# [START eventarc_basic_pubsub_parent_tag]
18+
# [START eventarc_basic_pubsub_enableapis]
19+
# Enable Cloud Run API
20+
resource "google_project_service" "run" {
21+
service = "run.googleapis.com"
22+
disable_on_destroy = false
23+
}
24+
25+
# Enable Eventarc API
26+
resource "google_project_service" "eventarc" {
27+
service = "eventarc.googleapis.com"
28+
disable_on_destroy = false
29+
}
30+
31+
# Enable Pub/Sub API
32+
resource "google_project_service" "pubsub" {
33+
service = "pubsub.googleapis.com"
34+
disable_on_destroy = false
35+
}
36+
# [END eventarc_basic_pubsub_enableapis]
37+
38+
# [START eventarc_basic_pubsub_iam]
39+
# Used to retrieve project information later
40+
data "google_project" "project" {}
41+
42+
# Create a dedicated service account
43+
resource "google_service_account" "eventarc" {
44+
account_id = "eventarc-trigger-sa"
45+
display_name = "Eventarc trigger service account"
46+
}
47+
48+
# Grant permission to receive Eventarc events
49+
resource "google_project_iam_member" "eventreceiver" {
50+
project = data.google_project.project.id
51+
role = "roles/eventarc.eventReceiver"
52+
member = "serviceAccount:${google_service_account.eventarc.email}"
53+
}
54+
55+
# Grant permission to invoke Cloud Run services
56+
resource "google_project_iam_member" "runinvoker" {
57+
project = data.google_project.project.id
58+
role = "roles/run.invoker"
59+
member = "serviceAccount:${google_service_account.eventarc.email}"
60+
}
61+
62+
# Grant permission to publish messages to a Pub/Sub topic
63+
resource "google_project_iam_member" "pubsubpublisher" {
64+
project = data.google_project.project.id
65+
member = "serviceAccount:${google_service_account.eventarc.email}"
66+
role = "roles/pubsub.publisher"
67+
}
68+
# [END eventarc_basic_pubsub_iam]
69+
70+
# [START eventarc_basic_pubsub_deploy_cloud_run]
71+
# Deploy a Cloud Run service
72+
resource "google_cloud_run_v2_service" "default" {
73+
name = "hello-events"
74+
location = "us-central1"
75+
76+
deletion_protection = false # set to "true" in production
77+
78+
template {
79+
containers {
80+
# This container will log received events
81+
image = "us-docker.pkg.dev/cloudrun/container/hello"
82+
}
83+
service_account = google_service_account.eventarc.email
84+
}
85+
86+
depends_on = [google_project_service.run]
87+
}
88+
# [END eventarc_basic_pubsub_deploy_cloud_run]
89+
90+
# [START eventarc_basic_pubsub_topic]
91+
# Create a Pub/Sub topic
92+
resource "google_pubsub_topic" "default" {
93+
name = "pubsub_topic"
94+
}
95+
# [END eventarc_basic_pubsub_topic]
96+
97+
# [START eventarc_basic_pubsub_trigger]
98+
# Create an Eventarc trigger, routing Pub/Sub events to Cloud Run
99+
resource "google_eventarc_trigger" "default" {
100+
name = "trigger-pubsub-cloudrun-tf"
101+
location = google_cloud_run_v2_service.default.location
102+
103+
# Capture messages published to a Pub/Sub topic
104+
matching_criteria {
105+
attribute = "type"
106+
value = "google.cloud.pubsub.topic.v1.messagePublished"
107+
}
108+
109+
# Send events to Cloud Run
110+
destination {
111+
cloud_run_service {
112+
service = google_cloud_run_v2_service.default.name
113+
region = google_cloud_run_v2_service.default.location
114+
}
115+
}
116+
117+
transport {
118+
pubsub {
119+
topic = google_pubsub_topic.default.id
120+
}
121+
}
122+
123+
service_account = google_service_account.eventarc.email
124+
depends_on = [
125+
google_project_service.eventarc,
126+
google_project_iam_member.pubsubpublisher
127+
]
128+
}
129+
# [END eventarc_basic_pubsub_trigger]
130+
# [END eventarc_basic_pubsub_parent_tag]

0 commit comments

Comments
 (0)