| 
									
										
										
										
											2017-09-26 15:15:17 +00:00
										 |  |  |  | #/bin/bash | 
					
						
							|  |  |  |  | # Restore folder based ES backup | 
					
						
							|  |  |  |  | # Make sure ES is available | 
					
						
							|  |  |  |  | myES="http://127.0.0.1:64298/" | 
					
						
							| 
									
										
										
										
											2019-03-01 20:29:47 +00:00
										 |  |  |  | myESSTATUS=$(curl -s -XGET ''$myES'_cluster/health' | jq '.' | grep -c "green\|yellow") | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:17 +00:00
										 |  |  |  | if ! [ "$myESSTATUS" = "1" ] | 
					
						
							|  |  |  |  |   then | 
					
						
							| 
									
										
										
										
											2019-03-01 20:29:47 +00:00
										 |  |  |  |     echo "### Elasticsearch is not available, try starting via 'systemctl start tpot'." | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:17 +00:00
										 |  |  |  |     exit | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     echo "### Elasticsearch is available, now continuing." | 
					
						
							|  |  |  |  | fi | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | # Let's ensure normal operation on exit or if interrupted ... | 
					
						
							|  |  |  |  | function fuCLEANUP { | 
					
						
							|  |  |  |  |   rm -rf tmp | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | trap fuCLEANUP EXIT | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | # Set vars | 
					
						
							|  |  |  |  | myDUMP=$1 | 
					
						
							|  |  |  |  | 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-elk.sh <es_dump.tar>"$myCOL0 | 
					
						
							|  |  |  |  |       echo  | 
					
						
							|  |  |  |  |       exit  | 
					
						
							|  |  |  |  | fi | 
					
						
							|  |  |  |  | if ! [ -a $myDUMP ]; | 
					
						
							|  |  |  |  |     then | 
					
						
							|  |  |  |  |       echo $myCOL1"### File not found."$myCOL0  | 
					
						
							|  |  |  |  |       exit | 
					
						
							|  |  |  |  | fi | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | # Unpack tar archive | 
					
						
							|  |  |  |  | echo $myCOL1"### Now unpacking tar archive: "$myDUMP $myCOL0 | 
					
						
							|  |  |  |  | tar xvf $myDUMP | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | # Build indices list | 
					
						
							| 
									
										
										
										
											2019-03-01 20:29:47 +00:00
										 |  |  |  | myINDICES="$(ls tmp/logstash*.gz | cut -c 5- | rev | cut -c 4- | rev)" | 
					
						
							| 
									
										
										
										
											2018-04-23 17:18:32 +00:00
										 |  |  |  | myINDICES+=" .kibana" | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:17 +00:00
										 |  |  |  | echo $myCOL1"### The following indices will be restored: "$myCOL0 | 
					
						
							|  |  |  |  | echo $myINDICES | 
					
						
							|  |  |  |  | echo | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-01 20:29:47 +00:00
										 |  |  |  | # Force single seat template for everything | 
					
						
							|  |  |  |  | echo -n $myCOL1"### Forcing single seat template: "$myCOL0 | 
					
						
							|  |  |  |  | curl -s XPUT ''$myES'_template/.*' -H 'Content-Type: application/json' -d' | 
					
						
							|  |  |  |  | { "index_patterns": ".*", | 
					
						
							|  |  |  |  |   "order": 1, | 
					
						
							|  |  |  |  |   "settings":  | 
					
						
							|  |  |  |  |     {  | 
					
						
							|  |  |  |  |       "number_of_shards": 1, | 
					
						
							|  |  |  |  |       "number_of_replicas": 0  | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | }' | 
					
						
							|  |  |  |  | echo | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-28 15:30:49 +02:00
										 |  |  |  | # Set logstash template | 
					
						
							|  |  |  |  | echo -n $myCOL1"### Setting up logstash template: "$myCOL0 | 
					
						
							|  |  |  |  | curl -s XPUT ''$myES'_template/logstash' -H 'Content-Type: application/json' -d' | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   "index_patterns": "logstash-*", | 
					
						
							|  |  |  |  |     "settings" : { | 
					
						
							|  |  |  |  |       "index" : {  | 
					
						
							|  |  |  |  |         "number_of_shards": 1, | 
					
						
							|  |  |  |  |         "number_of_replicas": 0, | 
					
						
							|  |  |  |  |           "mapping" : {  | 
					
						
							|  |  |  |  |             "total_fields" : { | 
					
						
							|  |  |  |  |               "limit" : "2000" | 
					
						
							|  |  |  |  |             }  | 
					
						
							|  |  |  |  |           }   | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | }' | 
					
						
							|  |  |  |  | echo | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:17 +00:00
										 |  |  |  | # Restore indices | 
					
						
							| 
									
										
										
										
											2019-03-01 20:29:47 +00:00
										 |  |  |  | curl -s -X DELETE ''$myES'.kibana*' > /dev/null | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:17 +00:00
										 |  |  |  | for i in $myINDICES; | 
					
						
							|  |  |  |  |   do | 
					
						
							|  |  |  |  |     # Delete index if it already exists | 
					
						
							| 
									
										
										
										
											2019-03-01 20:29:47 +00:00
										 |  |  |  |     curl -s -X DELETE $myES$i > /dev/null | 
					
						
							| 
									
										
										
										
											2017-09-26 15:15:17 +00:00
										 |  |  |  |     echo $myCOL1"### Now uncompressing: tmp/$i.gz" $myCOL0 | 
					
						
							|  |  |  |  |     gunzip -f tmp/$i.gz | 
					
						
							|  |  |  |  |     # Restore index to ES | 
					
						
							|  |  |  |  |     echo $myCOL1"### Now restoring: "$i $myCOL0 | 
					
						
							|  |  |  |  |     elasticdump --input=tmp/$i --output=$myES$i --limit 7500 | 
					
						
							|  |  |  |  |     rm tmp/$i | 
					
						
							|  |  |  |  |   done; | 
					
						
							|  |  |  |  | echo $myCOL1"### Done."$myCOL0 |