mirror of
https://github.com/wazuh/wazuh-docker.git
synced 2025-10-23 04:51:57 +00:00
72 lines
2.6 KiB
Bash
72 lines
2.6 KiB
Bash
#!/bin/bash
|
|
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
|
|
|
|
WAZUH_MAJOR=3
|
|
|
|
##############################################################################
|
|
# Wait for the Kibana API to start. It is necessary to do it in this container
|
|
# because the others are running Elastic Stack and we can not interrupt them.
|
|
#
|
|
# The following actions are performed:
|
|
#
|
|
# Add the wazuh alerts index as default.
|
|
# Set the Discover time interval to 24 hours instead of 15 minutes.
|
|
# Do not ask user to help providing usage statistics to Elastic.
|
|
##############################################################################
|
|
|
|
##############################################################################
|
|
# Customize elasticsearch ip
|
|
##############################################################################
|
|
if [ "$ELASTICSEARCH_KIBANA_IP" != "" ]; then
|
|
sed -i "s:#elasticsearch.hosts:elasticsearch.hosts:g" /usr/share/kibana/config/kibana.yml
|
|
sed -i 's|http://elasticsearch:9200|'$ELASTICSEARCH_KIBANA_IP'|g' /usr/share/kibana/config/kibana.yml
|
|
fi
|
|
|
|
# If KIBANA_INDEX was set, then change the default index in kibana.yml configuration file. If there was an index, then delete it and recreate.
|
|
if [ "$KIBANA_INDEX" != "" ]; then
|
|
if grep -q 'kibana.index' /usr/share/kibana/config/kibana.yml; then
|
|
sed -i '/kibana.index/d' /usr/share/kibana/config/kibana.yml
|
|
fi
|
|
echo "kibana.index: $KIBANA_INDEX" >> /usr/share/kibana/config/kibana.yml
|
|
fi
|
|
|
|
if [ "$KIBANA_IP" != "" ]; then
|
|
kibana_ip="$KIBANA_IP"
|
|
else
|
|
kibana_ip="kibana"
|
|
fi
|
|
|
|
while [[ "$(curl -XGET -I -s -o /dev/null -w ''%{http_code}'' $kibana_ip:5601/status)" != "200" ]]; do
|
|
echo "Waiting for Kibana API. Sleeping 5 seconds"
|
|
sleep 5
|
|
done
|
|
|
|
# Prepare index selection.
|
|
echo "Kibana API is running"
|
|
|
|
default_index="/tmp/default_index.json"
|
|
|
|
cat > ${default_index} << EOF
|
|
{
|
|
"changes": {
|
|
"defaultIndex": "wazuh-alerts-${WAZUH_MAJOR}.x-*"
|
|
}
|
|
}
|
|
EOF
|
|
|
|
sleep 5
|
|
# Add the wazuh alerts index as default.
|
|
curl -POST "http://$kibana_ip:5601/api/kibana/settings" -H "Content-Type: application/json" -H "kbn-xsrf: true" -d@${default_index}
|
|
rm -f ${default_index}
|
|
|
|
sleep 5
|
|
# Configuring Kibana TimePicker.
|
|
curl -POST "http://$kibana_ip:5601/api/kibana/settings" -H "Content-Type: application/json" -H "kbn-xsrf: true" -d \
|
|
'{"changes":{"timepicker:timeDefaults":"{\n \"from\": \"now-24h\",\n \"to\": \"now\",\n \"mode\": \"quick\"}"}}'
|
|
|
|
sleep 5
|
|
# Do not ask user to help providing usage statistics to Elastic
|
|
curl -POST "http://$kibana_ip:5601/api/telemetry/v2/optIn" -H "Content-Type: application/json" -H "kbn-xsrf: true" -d '{"enabled":false}'
|
|
|
|
echo "End settings"
|