adsb-receiver/bash/image.sh

353 wiersze
16 KiB
Bash
Czysty Zwykły widok Historia

2016-02-05 21:44:31 +00:00
#!/bin/bash
#####################################################################################
2016-02-18 15:41:39 +00:00
# ADS-B RECEIVER #
2016-02-05 21:44:31 +00:00
#####################################################################################
# #
# A set of scripts created to automate the process of installing the software #
# needed to setup a Mode S decoder as well as feeders which are capable of #
# sharing your ADS-B results with many of the most popular ADS-B aggregate sites. #
# #
# Project Hosted On GitHub: https://github.com/jprochazka/adsb-feeder #
# #
# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
# #
# Copyright (c) 2015 Joseph A. Prochazka #
# #
# Permission is hereby granted, free of charge, to any person obtaining a copy #
# of this software and associated documentation files (the "Software"), to deal #
# in the Software without restriction, including without limitation the rights #
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell #
# copies of the Software, and to permit persons to whom the Software is #
# furnished to do so, subject to the following conditions: #
# #
# The above copyright notice and this permission notice shall be included in all #
# copies or substantial portions of the Software. #
# #
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR #
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, #
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE #
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER #
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, #
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE #
# SOFTWARE. #
# #
# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
source bash/functions.sh
2016-05-02 00:31:15 +00:00
BUILDDIR="$PWD/build"
2016-05-13 00:07:21 +00:00
# Assign the Lighthttpd document root directory to a variable.
RAWDOCUMENTROOT=`/usr/sbin/lighttpd -f /etc/lighttpd/lighttpd.conf -p | grep server.document-root`
DOCUMENTROOT=`sed 's/.*"\(.*\)"[^"]*$/\1/' <<< $RAWDOCUMENTROOT`
2016-04-14 15:59:16 +00:00
## CONFIGURE DUMP1090-MUTABILITY
2016-02-05 21:44:31 +00:00
2016-04-14 15:59:16 +00:00
# Set latitude and longitude in the dump1090-mutability configuration file.
2016-02-05 21:44:31 +00:00
echo -e "\033[31m"
echo "SET THE LATITUDE AND LONGITUDE OF YOUR FEEDER"
echo -e "\033[33m"
echo "In order for some performance graphs to work properly you will need to"
echo "set the latitude and longitude of your feeder. If you do not know the"
echo "latitude and longitude of your feeder you can find out this information"
echo "by using Geocode by Address tool found on my web site."
echo ""
2016-02-23 04:28:28 +00:00
echo " https://www.swiftbyte.com/toolbox/geocode"
echo ""
echo "NOT SETTING LATITUDE AND LONGITUDE WILL BREAK THE RANGE PERFORMANCE GRAPH"
echo ""
2016-02-05 21:44:31 +00:00
echo -e "\033[37m"
2016-04-14 15:59:16 +00:00
read -p "Feeder Latitude: (Decimal Degrees XX-XXXXXXX) " FEEDERLAT
read -p "Feeder Longitude: (Decimal Degrees XX-XXXXXXX) " FEEDERLON
2016-02-05 21:44:31 +00:00
echo ""
ChangeConfig "LAT" $FEEDERLAT "/etc/default/dump1090-mutability"
ChangeConfig "LON" $FEEDERLON "/etc/default/dump1090-mutability"
# Ask if dump1090-mutability should bind on all IP addresses.
echo -e "\033[33m"
echo "By default dump1090-mutability on binds to the localhost IP address of 127.0.0.1 which is a good thing."
echo ""
echo "However..."
echo "Some people like for dump1090-mutability to bind on all available IP addresses for a mutitude of reasons."
echo "The scripts can bind dump190-mutability to all available IP addresses however this is not recommended"
echo "unless you understand the possible consequences of doing so."
echo -e "\033[37m"
2016-02-16 22:18:03 +00:00
read -p "Would you like dump1090-mutability to bind to all available IP addresses? [y/N] " BINDTOALLIPS
if [[ $BINDTOALLIPS =~ ^[yY]$ ]]; then
ChangeConfig "NET_BIND_ADDRESS" "0.0.0.0" "/etc/default/dump1090-mutability"
fi
2016-02-05 21:44:31 +00:00
# Setup Heywhatsthat.com max range circles for dump1090-mutability.
echo -e "\033[33m"
echo "Dump1090-mutability is able to display terrain limit rings using data obtained"
echo "from the website http://www.heywhatsthat.com. Some work will be required on your"
echo "part including visiting http://www.heywhatsthat.com and generating a new"
echo "panorama set to your location."
echo -e "\033[37m"
read -p "Do you wish to add terrain limit rings to the dump1090 map? [Y/n] " ADDTERRAINRINGS
if [[ ! $ADDTERRAINRINGS =~ ^[Nn]$ ]]; then
echo -e "\033[31m"
echo "READ THE FOLLOWING INSTRUCTION CAREFULLY!"
echo -e "\033[33m"
echo "To set up terrain limit rings you will need to first generate a panorama on the website"
echo "heywhatsthat.com. To do so visit the following URL:"
echo ""
echo " http://www.heywhatsthat.com"
echo ""
echo "Once the webpage has loaded click on the tab titled New panorama. Fill out the required"
echo "information in the form to the left of the map."
echo ""
echo "After submitting the form your request will be put into a queue to be generated shortly."
echo "You will be informed when the generation of your panorama has been completed."
echo ""
echo "Once generated visit your newly created panorama. Near the top left of the page you will"
echo "see a URL displayed which will point you to your newly created panorama. Within this URL's"
echo "query string you will see ?view=XXXXXXXX where XXXXXXXX is the identifier for this panorama."
echo "Enter below the letters and numbers making up the view identifier displayed there."
echo ""
echo "Positions for terrain rings for both 10,000 and 40,000 feet will be downloaded by this"
echo "script once the panorama has been generated and you are ready to continue."
echo -e "\033[37m"
read -p "Your heywhatsthat.com view identifier: " HEYWHATSTHATVIEWID
read -e -p "First ring altitude in meters (default 3048 meters or 10000 feet): " -i "3048" HEYWHATSTHATRINGONE
read -e -p "Second ring altitude in meters (default 12192 meters or 40000 feet): " -i "12192" HEYWHATSTHATRINGTWO
# Download the generated panoramas JSON data.
echo -e "\033[33m"
echo "Downloading JSON data pertaining to the panorama ID you supplied..."
echo -e "\033[37m"
sudo wget -O /usr/share/dump1090-mutability/html/upintheair.json "http://www.heywhatsthat.com/api/upintheair.json?id=${HEYWHATSTHATVIEWID}&refraction=0.25&alts=$HEYWHATSTHATRINGONE,$HEYWHATSTHATRINGTWO"
fi
2016-02-06 02:00:53 +00:00
# Restart dump1090-mutability.
2016-02-05 21:44:31 +00:00
echo -e "\033[33m"
echo "Restarting dump1090-mutability..."
echo -e "\033[37m"
sudo /etc/init.d/dump1090-mutability restart
2016-04-14 15:59:16 +00:00
## SETUP THE PORTAL
echo -e "\033[31m"
echo "Do you wish to enable advanced features?"
echo -e "\033[33m"
echo "ENABLING ADVANCED FEATURES ON DEVICES USING SD CARDS CAN SHORTEN THE LIFE OF THE SD CARD IMMENSELY"
echo -e "\033[33m"
echo "By enabling advanced features the portal will log all flights seen as well as the path of the flight."
echo "This data is stored in either a MySQL or SQLite database. This will result in a lot more data being"
echo "stored on your devices hard drive. Keep this and your devices hardware capabilities in mind before"
echo "selecting to enable these features."
echo ""
echo "You have been warned."
echo -e "\033[37m"
read -p "Use portal with advanced features? [y/N] " ADVANCED
2016-04-30 04:14:13 +00:00
## ASK IF ADVANCED FEATURES ARE TO BE USED
2016-04-14 15:59:16 +00:00
if [[ $ADVANCED =~ ^[yY]$ ]]; then
echo -e "\033[31m"
echo "Select Database Engine"
echo -e "\033[33m"
echo " 1) MySQL"
echo " 2) SQLLite"
echo -e "\033[37m"
read -p "Use portal with advanced features? [1] " DATABASEENGINE
# Check if the user is using a remote MySQL database.
2016-04-30 07:19:34 +00:00
if [[ $DATABASEENGINE != 2 ]]; then
echo -e "\033[31m"
echo "Will the database be hosted locally on this device or remotely?"
echo -e "\033[33m"
echo " 1) Locally"
echo " 2) Remotely"
echo -e "\033[37m"
read -p "Use portal with advanced features? [1] " LOCALDATABASE
fi
2016-04-14 15:59:16 +00:00
fi
2016-04-30 03:25:14 +00:00
## CHECK FOR PREREQUISITE PACKAGES
2016-04-14 15:59:16 +00:00
echo -e "\033[33m"
echo "Installing packages needed to build and fulfill dependencies..."
echo -e "\033[37m"
CheckPackage libpython2.7
if [[ $ADVANCED =~ ^[yY]$ ]]; then
if [[ $DATABASEENGINE == 2 ]]; then
CheckPackage sqlite3
CheckPackage php5-sqlite
else
if [[ $LOCALDATABASE != 2 ]]; then
# Install MySQL locally.
CheckPackage mysql-server
fi
2016-04-30 03:25:14 +00:00
CheckPackage mysql-client
2016-04-14 15:59:16 +00:00
CheckPackage php5-mysql
CheckPackage python-mysqldb
fi
fi
2016-05-12 22:34:37 +00:00
# Restart Lighttpd after installing the prerequisite packages.
echo -e "\033[33m"
echo -e "Restarting lighttpd...\033[37m"
sudo /etc/init.d/lighttpd restart
2016-04-30 04:14:13 +00:00
## CREATE THE DATABASE IF ADVANCED FEATURES WAS SELECTED
if [[ $ADVANCED =~ ^[yY]$ ]]; then
if [[ $DATABASEENGINE != 2 ]]; then
echo -e "\033[31m"
echo "Gathering Database Information"
echo -e "\033[33m"
echo "Please supply the information pertaining to the new password when asked."
echo ""
2016-05-16 19:18:58 +00:00
echo -e "\033[31mNOTE:"
2016-04-30 04:14:13 +00:00
echo "If the database will be hosted locally on this device a database will be"
2016-05-16 19:18:58 +00:00
echo "created automatically for you."
echo ""
echo "If you are hosting your database remotely YOU WILL NEED TO MANUALLY CREATE"
echo "THE DATABASE AND USER BEFORE PROCEEDING WITH THE INSTALLATION."
2016-04-30 04:14:13 +00:00
echo -e "\033[37m"
2016-04-30 03:25:14 +00:00
2016-04-30 04:14:13 +00:00
DATABASEHOST="localhost"
2016-05-16 19:18:58 +00:00
if [[ $LOCALDATABASE == 1 ]]; then
read -p "MySQL user login: [root] " DATABASEUSER
read -p "Password for MySQL user: " DATABASEPASSWORD
if [[ $LOCALDATABASE == "" ]]; then
DATABASEUSER="root"
fi
# Check that the supplied password is correct.
while ! mysql -u${DATABASEUSER} -p${DATABASEPASSWORD} -e ";" ; do
echo -e "\033[31m"
echo -e "Unable to connect to the MySQL server using the supplied login and password.\033[37m"
read -p "MySQL user login: [root] " DATABASEUSER
read -p "Password for MySQL user: " DATABASEPASSWORD
if [[ $LOCALDATABASE == "" ]]; then
DATABASEUSER="root"
fi
done
fi
2016-04-30 04:14:13 +00:00
if [[ $LOCALDATABASE == 2 ]]; then
# Ask for remote MySQL address if the database is hosted remotely.
2016-05-16 19:18:58 +00:00
read -p "MySQL Server Address: " DATABASEHOST
2016-04-30 04:14:13 +00:00
fi
2016-05-16 19:18:58 +00:00
read -p "Database Name: " DATABASENAME
read -p "Database User Name: " DATABASEUSER
read -p "Database User Password: " DATABASEPASSWORD
2016-04-30 03:25:14 +00:00
2016-05-16 19:18:58 +00:00
if [[ $LOCALDATABASE == 2 ]]; then
# Check the connection to the remote MySQL server.
while ! mysql -u${DATABASEUSER} -p${DATABASEPASSWORD} -h ${DATABASEHOST} -e ";" ; do
echo -e "\033[31m"
echo -e "Unable to connect to the MySQL server using the supplied login and password.\033[37m"
read -p "MySQL Server Address: " DATABASEHOST
read -p "Database user Name: " DATABASEUSER
read -p "Database User Password: " DATABASEPASSWORD
done
else
# Create the database and user if running MySQL locally.
echo -e "\033[33m"
2016-04-30 04:14:13 +00:00
echo -e "Creating MySQL database and user...\033[37m"
2016-05-16 19:18:58 +00:00
mysql -u${DATABASEUSER} -p${DATABASEPASSWORD} -e "CREATE DATABASE ${DATABASENAME};"
mysql -u${DATABASEUSER} -p${DATABASEPASSWORD} -e "CREATE USER '${DATABASEUSER}'@'localhost' IDENTIFIED BY \"${DATABASEPASSWORD}\";";
mysql -u${DATABASEUSER} -p${DATABASEPASSWORD} -e "GRANT ALL PRIVILEGES ON ${DATABASENAME}.* TO '${DATABASEUSER}'@'localhost';"
mysql -u${DATABASEUSER} -p${DATABASEPASSWORD} -e "FLUSH PRIVILEGES;"
2016-04-30 04:14:13 +00:00
fi
2016-04-30 03:25:14 +00:00
2016-04-30 04:14:13 +00:00
echo -e "\033[31m"
echo "BE SURE TO WRITE THIS INFORMATION DOWN."
echo -e "\033[33m"
echo "This information will be needed in order to complete the installation of the portal."
echo ""
echo "Database Server: ${DATABASEHOST}"
echo "Database User: ${DATABASEUSER}"
echo "Database Password: ${DATABASEPASSWORD}"
echo "Database Name: ${DATABASENAME}"
echo -e "\033[37m"
read -p "Press enter to continue..." CONTINUE
2016-05-13 00:48:46 +00:00
fi
if [[ $DATABASEENGINE == 2 ]]; then
# Create and empty SQLite databse and set the proper permissions on it.
sudo sqlite3 ${DOCUMENTROOT}/data/portal.sqlite ""
sudo chmod 666 ${DOCUMENTROOT}/data/portal.sqlite
2016-04-30 04:14:13 +00:00
fi
2016-04-14 15:59:16 +00:00
2016-04-30 04:14:13 +00:00
## SETUP FLIGHT LOGGING SCRIPT
2016-04-30 03:25:14 +00:00
2016-04-30 04:14:13 +00:00
echo -e "\033[33m"
echo -e "Creating configuration file...\033[37m"
case $DATABASEENGINE in
"2")
tee $BUILDDIR/portal/logging/config.json > /dev/null <<EOF
2016-04-14 15:59:16 +00:00
{
"database":{"type":"sqlite",
"host":"",
"user":"",
"passwd":"",
2016-04-30 03:25:14 +00:00
"db":"${DOCUMENTROOT}/data/portal.sqlite"}
2016-04-14 15:59:16 +00:00
}
EOF
2016-04-30 04:14:13 +00:00
;;
*)
tee $BUILDDIR/portal/logging/config.json > /dev/null <<EOF
2016-04-14 15:59:16 +00:00
{
"database":{"type":"mysql",
"host":"${DATABASEHOST}",
2016-04-14 15:59:16 +00:00
"user":"${DATABASEUSER}",
"passwd":"${DATABASEPASSWORD}",
"db":"${DATABASENAME}"}
}
EOF
2016-04-30 04:14:13 +00:00
;;
esac
2016-04-14 15:59:16 +00:00
2016-04-30 04:14:13 +00:00
# Create and set permissions on the flight logging maintainance script.
PYTHONPATH=`which python`
tee $BUILDDIR/portal/logging/flights-maint.sh > /dev/null <<EOF
2016-04-14 15:59:16 +00:00
#!/bin/sh
while true
do
sleep 30
2016-04-30 03:25:14 +00:00
${PYTHONPATH} ${BUILDDIR}/portal/logging/flights.py
2016-04-14 15:59:16 +00:00
done
EOF
2016-04-30 04:14:13 +00:00
chmod +x $BUILDDIR/portal/logging/flights-maint.sh
2016-04-14 15:59:16 +00:00
2016-04-30 04:14:13 +00:00
# Add flight logging maintainance script to rc.local.
if ! grep -Fxq "${BUILDDIR}/portal/logging/flights-maint.sh &" /etc/rc.local; then
2016-04-14 15:59:16 +00:00
echo -e "\033[33m"
2016-04-30 04:14:13 +00:00
echo -e "Adding startup line to rc.local...\033[37m"
lnum=($(sed -n '/exit 0/=' /etc/rc.local))
((lnum>0)) && sudo sed -i "${lnum[$((${#lnum[@]}-1))]}i ${BUILDDIR}/portal/logging/flights-maint.sh &\n" /etc/rc.local
2016-04-14 15:59:16 +00:00
fi
2016-04-30 04:14:13 +00:00
# Start flight logging.
echo -e "\033[33m"
echo -e "Starting flight logging...\033[37m"
nohup ${BUILDDIR}/portal/logging/flights-maint.sh > /dev/null 2>&1 &
2016-04-14 15:59:16 +00:00
fi
## FINISH CONFIGURATION
2016-05-16 19:23:34 +00:00
# This assigns the first IP address in the list to the $IPADDRESS variable.
IPADDRESS=`ip addr | grep 'state UP' -A2 | tail -n1 | awk '{print $2}' | cut -f1 -d'/'`
2016-04-14 15:59:16 +00:00
# Display further portal setup instructions.
echo -e "\033[33m"
echo "PORTAL SETUP IS NOT YET COMPLETE"
echo -e "\033[33m"
echo "In order to complete the portal setup process visit the following URL in your favorite web browser."
echo ""
2016-05-16 19:23:34 +00:00
echo "http://${IPADDRESS}/install/"
2016-04-14 15:59:16 +00:00
echo ""
echo "Enter the requested information and submit the form to complete the portal setup."
echo "It is recomended that after setting up the portal you delete the install.php file."
echo -e "\033[37m"
2016-02-05 21:44:31 +00:00
2016-04-14 15:59:16 +00:00
# Remove the "image" file now that setup has been ran.
2016-02-05 21:44:31 +00:00
rm -f image