forked from dome9/gcp-onboarding
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathonboardingFlowLogs.sh
executable file
·109 lines (98 loc) · 4.14 KB
/
onboardingFlowLogs.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
#!/bin/bash
REGION=$1
AUDIENCE="dome9-gcp-logs-collector"
PROJECT=$2
TOPIC_NAME="cloudguard-fl-topic"
SERVICE_ACCOUNT_NAME="cloudguard-fl-authentication"
SUBSCRIPTION_NAME="cloudguard-fl-subscription"
MAX_RETRY_DELAY=60
MIN_RETRY_DELAY=10
ACK_DEADLINE=60
EXPIRATION_PERIOD="never"
SINK_NAME="cloudguard-fl-sink"
LOG_FILTER='LOG_ID("compute.googleapis.com%2Fvpc_flows")'
if [[ "$REGION" == "central" ]]; then
ENDPOINT="https://gcp-flowlogs-endpoint.dome9.com"
else
ENDPOINT="https://gcp-flowlogs-endpoint.logic."$REGION".dome9.com"
fi
# delete existing sink if exists
sink=$(gcloud logging sinks list --filter="name.scope(sink):"$SINK_NAME"" 2>&1)
if [[ ! "$sink" =~ "0 items" ]]; then
sink=$(gcloud logging sinks delete "$SINK_NAME")
if [[ "$sink" =~ "ERROR" ]]; then
echo "could not delete existing sink "$SINK_NAME" EXITING WITHOUT DEPLOYMENT"
exit 1
fi
fi
# delete existing subscription if exists
pubsubSubscription=$(gcloud pubsub subscriptions list --filter="name.scope(subscription):"$SUBSCRIPTION_NAME"" 2>&1)
if [[ ! "$pubsubSubscription" =~ "0 items" ]]; then
pubsubSubscription=$(gcloud pubsub subscriptions delete "$SUBSCRIPTION_NAME")
if [[ "$pubsubSubscription" =~ "ERROR" ]]; then
echo "could not delete existing subscription "$SUBSCRIPTION_NAME" EXITING WITHOUT DEPLOYMENT"
exit 1
fi
fi
# delete existing topic if exists
topic=$(gcloud pubsub topics list --filter="name.scope(topic):"$TOPIC_NAME"" 2>&1)
if [[ ! "$topic" =~ "0 items" ]]; then
topic=$(gcloud pubsub topics delete "$TOPIC_NAME")
if [[ "$topic" =~ "ERROR" ]]; then
echo "could not delete existing topic "$TOPIC_NAME" EXITING WITHOUT DEPLOYMENT"
exit 1
fi
fi
# delete existing service account if exists
serviceAccount=$(gcloud iam service-accounts list --filter="name.scope(service account):$SERVICE_ACCOUNT_NAME" 2>&1)
if [[ ! "$serviceAccount" =~ "0 items" ]]; then
serviceAccount=$(gcloud iam service-accounts delete "$SERVICE_ACCOUNT_NAME"@"$PROJECT".iam.gserviceaccount.com)
if [[ "$serviceAccount" =~ "ERROR" ]]; then
echo "could not delete existing service account "$SERVICE_ACCOUNT_NAME" EXITING WITHOUT DEPLOYMENT"
exit 1
fi
fi
# service account creation
serviceAccount=$(gcloud iam service-accounts create $SERVICE_ACCOUNT_NAME --display-name="$SERVICE_ACCOUNT_NAME" 2>&1)
echo "$serviceAccount"
if [[ "$serviceAccount" =~ "ERROR" ]]; then
echo "could not create service account "$SERVICE_ACCOUNT_NAME" EXITING WITHOUT DEPLOYMENT"
exit 1
fi
# topic creation
topic=$(gcloud pubsub topics create "$TOPIC_NAME" 2>&1)
echo "$topic"
if [[ "$topic" =~ "ERROR" ]]; then
echo "could not create topic "$TOPIC_NAME" EXITING WITHOUT DEPLOYMENT"
exit 1
fi
# subscription creation
pubsubSubscription=$(gcloud pubsub subscriptions create "$SUBSCRIPTION_NAME" \
--topic="$TOPIC_NAME" \
--ack-deadline="$ACK_DEADLINE" \
--expiration-period="$EXPIRATION_PERIOD" \
--push-endpoint="$ENDPOINT" \
--push-auth-service-account="$SERVICE_ACCOUNT_NAME"@"$PROJECT".iam.gserviceaccount.com \
--push-auth-token-audience="$AUDIENCE" \
--max-retry-delay="$MAX_RETRY_DELAY" \
--min-retry-delay="$MIN_RETRY_DELAY" 2>&1)
echo "$pubsubSubscription"
if [[ "$pubsubSubscription" =~ "ERROR" ]]; then
echo "could not create subscription "$SUBSCRIPTION_NAME" EXITING WITHOUT DEPLOYMENT"
exit 1
fi
# sink creation
sink=$(gcloud logging sinks create "$SINK_NAME" pubsub.googleapis.com/projects/"$PROJECT"/topics/"$TOPIC_NAME" \
--log-filter="$LOG_FILTER" 2>&1)
echo "$sink"
if [[ "$sink" =~ "ERROR" ]]; then
echo "could not create sink "$SINK_NAME" EXITING WITHOUT DEPLOYMENT"
exit 1
fi
# granting write permissions to sink
writerIdentity=$(gcloud logging sinks describe --format='value(writerIdentity)' "$SINK_NAME" 2>&1)
gcloud pubsub topics add-iam-policy-binding "$TOPIC_NAME" --member="$writerIdentity" --role=roles/pubsub.publisher
green='\033[0;32m'
clear='\033[0m'
bold=$(tput bold)
echo -e "${bold}${green}Project Successfully Onboarded.${clear}"