mirror of
https://github.com/telekom-security/tpotce.git
synced 2025-04-29 03:38:51 +00:00
76 lines
2.5 KiB
Bash
76 lines
2.5 KiB
Bash
![]() |
#!/bin/bash
|
|||
|
myDUMP=$1
|
|||
|
myES="http://127.0.0.1:64298/"
|
|||
|
myCOL1="[0;34m"
|
|||
|
myCOL0="[0;0m"
|
|||
|
|
|||
|
# Check if parameter is given and file exists
|
|||
|
if [ "$myDUMP" = "" ];
|
|||
|
then
|
|||
|
echo $myCOL1"### Please provide a backup file name."$myCOL0
|
|||
|
echo $myCOL1"### restore-kibana-objects.sh <kibana-objects.tgz>"$myCOL0
|
|||
|
echo
|
|||
|
exit
|
|||
|
fi
|
|||
|
if ! [ -a $myDUMP ];
|
|||
|
then
|
|||
|
echo $myCOL1"### File not found."$myCOL0
|
|||
|
exit
|
|||
|
fi
|
|||
|
|
|||
|
# Unpack tar
|
|||
|
tar xvfz $myDUMP > /dev/null
|
|||
|
|
|||
|
# Restore index patterns
|
|||
|
myINDEXCOUNT=$(cat patterns/index-patterns.json | tr '\\' '\n' | grep "scripted" | wc -w)
|
|||
|
echo $myCOL1"### Now restoring"$myCOL0 $myINDEXCOUNT $myCOL1"index patterns." $myCOL0
|
|||
|
curl -s -XDELETE ''$myES'.kibana/index-pattern/logstash-*' > /dev/null
|
|||
|
curl -s -XPUT ''$myES'.kibana/index-pattern/logstash-*' -T patterns/index-patterns.json > /dev/null
|
|||
|
echo
|
|||
|
|
|||
|
# Restore dashboards
|
|||
|
myDASHBOARDS=$(basename -s .json -a dashboards/*.json)
|
|||
|
echo $myCOL1"### Now restoring "$myCOL0$(echo $myDASHBOARDS | wc -w)$myCOL1 "dashboards." $myCOL0
|
|||
|
for i in $myDASHBOARDS;
|
|||
|
do
|
|||
|
echo $myCOL1"###### "$i $myCOL0
|
|||
|
curl -s -XDELETE ''$myES'.kibana/dashboard/'$i'' > /dev/null
|
|||
|
curl -s -XPUT ''$myES'.kibana/dashboard/'$i'' -T dashboards/$i.json > /dev/null
|
|||
|
done;
|
|||
|
echo
|
|||
|
|
|||
|
# Restore visualizations
|
|||
|
myVISUALIZATIONS=$(basename -s .json -a visualizations/*.json)
|
|||
|
echo $myCOL1"### Now restoring "$myCOL0$(echo $myVISUALIZATIONS | wc -w)$myCOL1 "visualizations." $myCOL0
|
|||
|
for i in $myVISUALIZATIONS;
|
|||
|
do
|
|||
|
echo $myCOL1"###### "$i $myCOL0
|
|||
|
curl -s -XDELETE ''$myES'.kibana/visualization/'$i'' > /dev/null
|
|||
|
curl -s -XPUT ''$myES'.kibana/visualization/'$i'' -T visualizations/$i.json > /dev/null
|
|||
|
done;
|
|||
|
echo
|
|||
|
|
|||
|
# Restore searches
|
|||
|
mySEARCHES=$(basename -s .json -a searches/*.json)
|
|||
|
echo $myCOL1"### Now restoring "$myCOL0$(echo $mySEARCHES | wc -w)$myCOL1 "searches." $myCOL0
|
|||
|
for i in $mySEARCHES;
|
|||
|
do
|
|||
|
echo $myCOL1"###### "$i $myCOL0
|
|||
|
curl -s -XDELETE ''$myES'.kibana/search/'$i'' > /dev/null
|
|||
|
curl -s -XPUT ''$myES'.kibana/search/'$i'' -T searches/$i.json > /dev/null
|
|||
|
done;
|
|||
|
echo
|
|||
|
|
|||
|
# Clean up
|
|||
|
rm -rf patterns dashboards visualizations searches
|
|||
|
|
|||
|
# Stats
|
|||
|
echo
|
|||
|
echo $myCOL1"### Statistics"
|
|||
|
echo $myCOL1"###### Restored"$myCOL0 $myINDEXCOUNT $myCOL1"index patterns." $myCOL0
|
|||
|
echo $myCOL1"###### Restored"$myCOL0 $(echo $myDASHBOARDS | wc -w) $myCOL1"dashboards." $myCOL0
|
|||
|
echo $myCOL1"###### Restored"$myCOL0 $(echo $myVISUALIZATIONS | wc -w) $myCOL1"visualizations." $myCOL0
|
|||
|
echo $myCOL1"###### Restored"$myCOL0 $(echo $mySEARCHES | wc -w) $myCOL1"searches." $myCOL0
|
|||
|
echo
|
|||
|
|