-
Notifications
You must be signed in to change notification settings - Fork 55
/
Copy pathrun.sh
executable file
·163 lines (140 loc) · 5.63 KB
/
run.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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
#!/bin/bash
if [[ $SUMO_ACCESS_ID_FILE ]]; then
export SUMO_ACCESS_ID=$(cat $SUMO_ACCESS_ID_FILE)
fi
if [[ $SUMO_ACCESS_KEY_FILE ]]; then
export SUMO_ACCESS_KEY=$(cat $SUMO_ACCESS_KEY_FILE)
fi
if [[ $SUMO_INSTALLATION_TOKEN_FILE ]]; then
export SUMO_INSTALLATION_TOKEN=$(cat $SUMO_INSTALLATION_TOKEN_FILE)
fi
SUMO_GENERATE_USER_PROPERTIES=${SUMO_GENERATE_USER_PROPERTIES:=true}
SUMO_GENERATE_COLLECTOR_PROPERTIES=${SUMO_GENERATE_COLLECTOR_PROPERTIES:=true}
SUMO_ACCESS_ID=${SUMO_ACCESS_ID:=$1}
SUMO_ACCESS_KEY=${SUMO_ACCESS_KEY:=$2}
SUMO_RECEIVER_URL=${SUMO_RECEIVER_URL:=https://collectors.sumologic.com}
# Handle case for an empty string
SUMO_COLLECTOR_NAME=${SUMO_COLLECTOR_NAME_PREFIX='collector_container-'}${SUMO_COLLECTOR_NAME:=$(cat /etc/hostname)}
SUMO_SOURCES_JSON=${SUMO_SOURCES_JSON:=/etc/sumo-sources.json}
SUMO_SYNC_SOURCES=${SUMO_SYNC_SOURCES:=false}
SUMO_COLLECTOR_EPHEMERAL=${SUMO_COLLECTOR_EPHEMERAL:=true}
SUMO_COLLECTOR_HOSTNAME=${SUMO_COLLECTOR_HOSTNAME:=$(cat /etc/hostname)}
generate_collector_properties_file() {
# Read values from ENV variables and place them in collector/config/collector.properties file
declare -A SUPPORTED_OPTIONS
SUPPORTED_OPTIONS=(
["SUMO_UDP_READ_BUFFER_SIZE"]="collector.syslog.udp.readBufferSize"
)
COLLECTOR_PROPERTIES=""
for key in "${!SUPPORTED_OPTIONS[@]}"
do
value=${!key}
if [ -n "${value}" ]; then
COLLECTOR_PROPERTIES="${COLLECTOR_PROPERTIES}${SUPPORTED_OPTIONS[$key]}=${value}\n"
fi
done
if [ -n "${COLLECTOR_PROPERTIES}" ]; then
echo -e ${COLLECTOR_PROPERTIES} > /opt/SumoCollector/config/collector.properties
fi
}
generate_user_properties_file() {
if [ -z "$SUMO_ACCESS_ID" ] && [ -z "$SUMO_ACCESS_KEY" ]; then
if [ -z "$SUMO_INSTALLATION_TOKEN" ]; then
echo "FATAL: Please provide credentials via:"
echo " * the SUMO_ACCESS_ID and SUMO_ACCESS_KEY environment variables,"
echo " * as the first two command line arguments, or"
echo " * in files references by SUMO_ACCESS_ID_FILE and SUMO_ACCESS_KEY_FILE"
echo " You can also provide an installation token via:"
echo " * the SUMO_INSTALLATION_TOKEN environment variable, or"
echo " * in a file referenced by the SUMO_INSTALLATION_TOKEN_FILE environment variable"
exit 1
fi
fi
# Support using env as replacement within sources.
# Gather all template files
declare -a TEMPLATE_FILES
if [ -r "${SUMO_SOURCES_JSON}.tmpl" ]; then
TEMPLATE_FILES+=("${SUMO_SOURCES_JSON}.tmpl")
fi
if [ -d "${SUMO_SOURCES_JSON}" ]; then
for f in $(find ${SUMO_SOURCES_JSON} -name '*.tmpl'); do TEMPLATE_FILES+=(${f}); done
fi
for from in "${TEMPLATE_FILES[@]}"
do
# Replace all env variables and remove .tmpl extension
to=${from%.*}
echo > ${to}
if [ $? -ne 0 ]; then
echo "FATAL: unable to write to ${to}"
exit 1
fi
OLD_IFS=$IFS
IFS=$'\n'
while read -r line; do
line_escape_backslashes=${line//\\/\\\\}
printf "%s\n" "$(eval echo "\"${line_escape_backslashes//\"/\\\"}\"")" >> ${to}
done <${from}
IFS=${OLD_IFS}
echo "INFO: Replacing environment variables from ${from} into ${to}"
done
if [ ! -e "${SUMO_SOURCES_JSON}" ]; then
echo "FATAL: Unable to find $SUMO_SOURCES_JSON - please make sure you include it in your image!"
exit 1
fi
if [ "${SUMO_SYNC_SOURCES}" == "true" ]; then
SUMO_SYNC_SOURCES=${SUMO_SOURCES_JSON}
unset SUMO_SOURCES_JSON
else
unset SUMO_SYNC_SOURCES
fi
# Supported user.properties configuration parameters
# More information https://help.sumologic.com/Send_Data/Installed_Collectors/stu_user.properties
declare -A SUPPORTED_OPTIONS
SUPPORTED_OPTIONS=(
["SUMO_ACCESS_ID"]="accessid"
["SUMO_ACCESS_KEY"]="accesskey"
["SUMO_INSTALLATION_TOKEN"]="token"
["SUMO_RECEIVER_URL"]="url"
["SUMO_COLLECTOR_NAME"]="name"
["SUMO_COLLECTOR_HOSTNAME"]="hostName"
["SUMO_SOURCES_JSON"]="sources"
["SUMO_SYNC_SOURCES"]="syncSources"
["SUMO_COLLECTOR_EPHEMERAL"]="ephemeral"
["SUMO_PROXY_HOST"]="proxyHost"
["SUMO_PROXY_PORT"]="proxyPort"
["SUMO_PROXY_USER"]="proxyUser"
["SUMO_PROXY_PASSWORD"]="proxyPassword"
["SUMO_PROXY_NTLM_DOMAIN"]="proxyNtlmDomain"
["SUMO_CLOBBER"]="clobber"
["SUMO_DISABLE_SCRIPTS"]="disableScriptSource"
["SUMO_ENABLE_SCRIPTS"]="enableScriptSource"
["SUMO_JAVA_MEMORY_INIT"]="wrapper.java.initmemory"
["SUMO_JAVA_MEMORY_MAX"]="wrapper.java.maxmemory"
["SUMO_COLLECTOR_FIELDS"]="fields"
["SUMO_COLLECTOR_CATEGORY"]="category"
)
USER_PROPERTIES=""
for key in "${!SUPPORTED_OPTIONS[@]}"
do
value=${!key}
if [ -n "${value}" ]; then
USER_PROPERTIES="${USER_PROPERTIES}${SUPPORTED_OPTIONS[$key]}=${value}\n"
fi
done
if [ -n "${USER_PROPERTIES}" ]; then
echo -e ${USER_PROPERTIES} > /opt/SumoCollector/config/user.properties
fi
}
# If the user didn't supply their own user.properties file, generate it
$SUMO_GENERATE_USER_PROPERTIES && {
generate_user_properties_file
}
# If the user didn't supply their own collector.properties file, generate it
$SUMO_GENERATE_COLLECTOR_PROPERTIES && {
generate_collector_properties_file
}
if [ "${SUMO_FIPS_JCE}" == "true" ]; then
/opt/SumoCollector/script/configureFipsMode.sh
fi
# Don't leave our shell hanging around
exec /opt/SumoCollector/collector console