2016-07-03 17:13:34 +02:00
|
|
|
#!/bin/bash
|
|
|
|
#
|
|
|
|
# .---. . .
|
|
|
|
# | | |
|
|
|
|
# |--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-.
|
|
|
|
# | | (.-' (.-' ( | ( )| | | | )( )| | (.-'
|
|
|
|
# ' ' --' --' -' - -' ' ' -' -' -' ' - --'
|
|
|
|
#
|
|
|
|
# Freedom in the Cloud
|
|
|
|
#
|
|
|
|
# Tox Application
|
|
|
|
#
|
|
|
|
# License
|
|
|
|
# =======
|
|
|
|
#
|
|
|
|
# Copyright (C) 2014-2016 Bob Mottram <bob@robotics.uk.to>
|
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU Affero General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU Affero General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU Affero General Public License
|
|
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2016-07-06 17:47:55 +02:00
|
|
|
VARIANTS='full chat'
|
|
|
|
|
2016-07-03 17:13:34 +02:00
|
|
|
TOX_PORT=33445
|
|
|
|
TOXCORE_REPO="git://github.com/irungentoo/toxcore.git"
|
|
|
|
TOXCORE_COMMIT='532629d486e3361c7d8d95b38293cc7d61dc4ee5'
|
|
|
|
TOXID_REPO="https://github.com/bashrc/toxid"
|
|
|
|
TOX_BOOTSTRAP_ID_FILE=/var/lib/tox-bootstrapd/pubkey.txt
|
|
|
|
# These are some default nodes, but you can replace them with trusted nodes
|
|
|
|
# as you prefer. See https://wiki.tox.im/Nodes
|
|
|
|
TOX_NODES=
|
|
|
|
#TOX_NODES=(
|
|
|
|
# '192.254.75.102,2607:5600:284::2,33445,951C88B7E75C867418ACDB5D273821372BB5BD652740BCDF623A4FA293E75D2F,Tox RELENG,US'
|
|
|
|
# '144.76.60.215,2a01:4f8:191:64d6::1,33445,04119E835DF3E78BACF0F84235B300546AF8B936F035185E2A8E9E0A67C8924F,sonOfRa,DE'
|
|
|
|
#)
|
|
|
|
TOXIC_REPO="https://github.com/Tox/toxic"
|
|
|
|
TOXIC_COMMIT='cf16849b374e484a33a4dffa3dfb937b59d537f2'
|
|
|
|
TOXIC_FILE=/usr/local/bin/toxic
|
|
|
|
|
2016-07-09 12:36:12 +02:00
|
|
|
function reconfigure_tox {
|
2016-07-09 22:52:17 +02:00
|
|
|
echo -n ''
|
2016-07-09 12:36:12 +02:00
|
|
|
}
|
|
|
|
|
2016-07-06 16:01:28 +02:00
|
|
|
function upgrade_tox {
|
2016-07-06 16:40:09 +02:00
|
|
|
if ! grep -Fxq "install_tox" $COMPLETION_FILE; then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
function_check set_repo_commit
|
|
|
|
set_repo_commit $INSTALL_DIR/toxcore "toxcore commit" "$TOXCORE_COMMIT" $TOXCORE_REPO
|
|
|
|
|
|
|
|
function_check set_repo_commit
|
|
|
|
set_repo_commit $INSTALL_DIR/toxic "Toxic commit" "$TOXIC_COMMIT" $TOXIC_REPO
|
2016-07-06 16:01:28 +02:00
|
|
|
}
|
|
|
|
|
2016-07-06 15:55:09 +02:00
|
|
|
function backup_local_tox {
|
2016-07-07 21:42:25 +02:00
|
|
|
if [ -d /var/lib/tox-bootstrapd ]; then
|
|
|
|
echo $"Backing up Tox"
|
|
|
|
|
|
|
|
if [ -d /var/lib/tox-bootstrapd ]; then
|
|
|
|
cp /etc/tox-bootstrapd.conf /var/lib/tox-bootstrapd
|
|
|
|
if [ -d /var/lib/tox-bootstrapd/Maildir ]; then
|
|
|
|
rm -rf /var/lib/tox-bootstrapd/Maildir
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
function_check backup_directory_to_usb
|
|
|
|
backup_directory_to_usb /var/lib/tox-bootstrapd tox
|
|
|
|
|
|
|
|
echo $"Backup of Tox complete"
|
|
|
|
fi
|
2016-07-06 15:55:09 +02:00
|
|
|
}
|
|
|
|
|
2016-07-08 17:18:23 +02:00
|
|
|
function restore_local_tox {
|
|
|
|
if [ -d $USB_MOUNT/backup/tox ]; then
|
|
|
|
echo $"Restoring Tox node settings"
|
|
|
|
function_check restore_directory_from_usb
|
|
|
|
restore_directory_from_usb / tox
|
|
|
|
if [ ! "$?" = "0" ]; then
|
|
|
|
function_check set_user_permissions
|
|
|
|
set_user_permissions
|
|
|
|
function_check backup_unmount_drive
|
|
|
|
backup_unmount_drive
|
|
|
|
exit 6393
|
|
|
|
fi
|
|
|
|
cp /var/lib/tox-bootstrapd/tox-bootstrapd.conf /etc/tox-bootstrapd.conf
|
|
|
|
systemctl restart tox-bootstrapd.service
|
|
|
|
if [ ! "$?" = "0" ]; then
|
|
|
|
systemctl status tox-bootstrapd.service
|
|
|
|
function_check set_user_permissions
|
|
|
|
set_user_permissions
|
|
|
|
function_check backup_unmount_drive
|
|
|
|
backup_unmount_drive
|
|
|
|
exit 59369
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2016-07-06 15:55:09 +02:00
|
|
|
function backup_remote_tox {
|
2016-07-09 22:52:17 +02:00
|
|
|
if [ -d /var/lib/tox-bootstrapd ]; then
|
|
|
|
echo "Backing up Tox node settings"
|
|
|
|
if [ -d /var/lib/tox-bootstrapd/Maildir ]; then
|
|
|
|
rm -rf /var/lib/tox-bootstrapd/Maildir
|
|
|
|
fi
|
|
|
|
cp /etc/tox-bootstrapd.conf /var/lib/tox-bootstrapd
|
|
|
|
backup_directory_to_friend /var/lib/tox-bootstrapd tox
|
|
|
|
echo "Backup of Tox node settings complete"
|
|
|
|
fi
|
2016-07-08 17:18:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function restore_remote_tox {
|
2016-07-10 15:54:19 +02:00
|
|
|
if [ -d $SERVER_DIRECTORY/backup/tox ]; then
|
|
|
|
echo $"Restoring Tox node settings"
|
|
|
|
function_check restore_directory_from_friend
|
|
|
|
restore_directory_from_friend / tox
|
|
|
|
if [ ! "$?" = "0" ]; then
|
|
|
|
exit 93653
|
|
|
|
fi
|
|
|
|
cp /var/lib/tox-bootstrapd/tox-bootstrapd.conf /etc/tox-bootstrapd.conf
|
|
|
|
systemctl restart tox-bootstrapd.service
|
|
|
|
if [ ! "$?" = "0" ]; then
|
|
|
|
systemctl status tox-bootstrapd.service
|
|
|
|
exit 59369
|
|
|
|
fi
|
|
|
|
echo $"Restore of Tox node complete"
|
|
|
|
fi
|
2016-07-04 22:02:22 +02:00
|
|
|
}
|
|
|
|
|
2016-07-04 14:32:23 +02:00
|
|
|
function remove_tox_node {
|
|
|
|
if ! grep -Fxq "install_tox_node" $COMPLETION_FILE; then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
|
|
|
|
iptables -D INPUT -p tcp --dport $TOX_PORT -j ACCEPT
|
|
|
|
function_check save_firewall_settings
|
|
|
|
save_firewall_settings
|
|
|
|
|
|
|
|
function_check remove_onion_service
|
|
|
|
remove_onion_service tox ${TOX_PORT}
|
|
|
|
|
|
|
|
${PROJECT_NAME}-mesh-install -f tox_node --remove yes
|
|
|
|
if [ ! "$?" = "0" ]; then
|
|
|
|
echo $'Failed to remove tox node'
|
|
|
|
exit 763836
|
|
|
|
fi
|
|
|
|
sed -i '/install_tox_node/d' $COMPLETION_FILE
|
2016-07-04 20:03:55 +02:00
|
|
|
sed -i '/configure_firewall_for_tox/d' $COMPLETION_FILE
|
|
|
|
}
|
|
|
|
|
|
|
|
function remove_tox_avahi {
|
|
|
|
if ! grep -Fxq "tox_avahi" $COMPLETION_FILE; then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
cd $INSTALL_DIR/toxid
|
|
|
|
make uninstall
|
|
|
|
rm -rf $INSTALL_DIR/toxid
|
|
|
|
sed -i '/toxavahi/d' /etc/crontab
|
|
|
|
systemctl restart cron
|
|
|
|
sed -i '/tox_avahi/d' $COMPLETION_FILE
|
|
|
|
}
|
|
|
|
|
|
|
|
function remove_tox_client {
|
|
|
|
if ! grep -Fxq "install_tox_client" $COMPLETION_FILE; then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
|
|
|
|
${PROJECT_NAME}-mesh-install -f tox_client --remove yes
|
|
|
|
if [ ! "$?" = "0" ]; then
|
|
|
|
echo $'Could not remove Tox client'
|
|
|
|
exit 737253
|
|
|
|
fi
|
|
|
|
sed -i '/install_tox_client/d' $COMPLETION_FILE
|
|
|
|
sed -i '/Tox /d' $COMPLETION_FILE
|
|
|
|
sed -i '/Toxic /d' $COMPLETION_FILE
|
|
|
|
}
|
|
|
|
|
|
|
|
function remove_tox {
|
|
|
|
remove_tox_client
|
|
|
|
remove_tox_avahi
|
|
|
|
remove_tox_node
|
2016-07-04 14:32:23 +02:00
|
|
|
}
|
|
|
|
|
2016-07-03 19:52:57 +02:00
|
|
|
function configure_firewall_for_tox {
|
|
|
|
if grep -Fxq "configure_firewall_for_tox" $COMPLETION_FILE; then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
|
|
|
|
# docker does its own firewalling
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
if [[ $ONION_ONLY != "no" ]]; then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
iptables -A INPUT -p tcp --dport $TOX_PORT -j ACCEPT
|
|
|
|
function_check save_firewall_settings
|
|
|
|
save_firewall_settings
|
|
|
|
|
|
|
|
OPEN_PORTS+=("Tox $TOX_PORT")
|
|
|
|
echo 'configure_firewall_for_tox' >> $COMPLETION_FILE
|
|
|
|
}
|
|
|
|
|
2016-07-03 17:13:34 +02:00
|
|
|
function tox_avahi {
|
|
|
|
if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
if grep -Fxq "tox_avahi" $COMPLETION_FILE; then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ ! -d /etc/avahi ]; then
|
|
|
|
echo $'tox_avahi: avahi is not installed'
|
|
|
|
exit 87359
|
|
|
|
fi
|
|
|
|
|
|
|
|
# install a command to obtain the Tox ID
|
|
|
|
cd $INSTALL_DIR
|
|
|
|
function_check git_clone
|
|
|
|
git_clone $TOXID_REPO $INSTALL_DIR/toxid
|
|
|
|
if [ ! -d $INSTALL_DIR/toxid ]; then
|
|
|
|
exit 63921
|
|
|
|
fi
|
|
|
|
cd $INSTALL_DIR/toxid
|
|
|
|
make
|
|
|
|
if [ ! "$?" = "0" ]; then
|
|
|
|
exit 58432
|
|
|
|
fi
|
|
|
|
make install
|
|
|
|
|
|
|
|
toxavahi
|
|
|
|
|
|
|
|
# publish regularly
|
|
|
|
function_check cron_add_mins
|
|
|
|
cron_add_mins 1 'toxavahi > /dev/null'
|
|
|
|
|
|
|
|
systemctl restart avahi-daemon
|
|
|
|
|
|
|
|
echo 'tox_avahi' >> $COMPLETION_FILE
|
|
|
|
}
|
|
|
|
|
|
|
|
function install_tox_node {
|
|
|
|
if grep -Fxq "install_tox_node" $COMPLETION_FILE; then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
|
|
|
|
${PROJECT_NAME}-mesh-install -f tox_node
|
|
|
|
if [ ! "$?" = "0" ]; then
|
|
|
|
echo $'Failed to install tox node'
|
|
|
|
exit 26778
|
|
|
|
fi
|
|
|
|
|
|
|
|
TOX_ONION_HOSTNAME=$(add_onion_service tox ${TOX_PORT} ${TOX_PORT})
|
|
|
|
|
|
|
|
if ! grep -q "tox onion domain" $COMPLETION_FILE; then
|
|
|
|
echo "tox onion domain:${TOX_ONION_HOSTNAME}" >> $COMPLETION_FILE
|
|
|
|
else
|
|
|
|
sed -i "s|tox onion domain.*|tox onion domain:${TOX_ONION_HOSTNAME}|g" $COMPLETION_FILE
|
|
|
|
fi
|
|
|
|
|
|
|
|
systemctl restart tox-bootstrapd.service
|
|
|
|
|
|
|
|
TOX_PUBLIC_KEY=$(cat /var/log/syslog | grep tox | grep "Public Key" | awk -F ' ' '{print $8}' | tail -1)
|
|
|
|
if [ ${#TOX_PUBLIC_KEY} -lt 30 ]; then
|
|
|
|
echo $'Could not obtain the tox node public key'
|
|
|
|
exit 6529
|
|
|
|
fi
|
|
|
|
|
|
|
|
# save the public key for later reference
|
|
|
|
echo "$TOX_PUBLIC_KEY" > $TOX_BOOTSTRAP_ID_FILE
|
|
|
|
|
|
|
|
function_check configure_firewall_for_tox
|
|
|
|
configure_firewall_for_tox
|
|
|
|
|
|
|
|
if ! grep -q $"Your Tox node public key is" /home/$MY_USERNAME/README; then
|
|
|
|
echo '' >> /home/$MY_USERNAME/README
|
|
|
|
echo '' >> /home/$MY_USERNAME/README
|
|
|
|
echo 'Tox' >> /home/$MY_USERNAME/README
|
|
|
|
echo '===' >> /home/$MY_USERNAME/README
|
|
|
|
echo $"tox onion domain: ${TOX_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
|
|
|
|
echo $"Your Tox node public key is: $TOX_PUBLIC_KEY" >> /home/$MY_USERNAME/README
|
|
|
|
echo $'In the Toxic client you can connect to it with:' >> /home/$MY_USERNAME/README
|
|
|
|
echo " /connect $DEFAULT_DOMAIN_NAME.local $TOX_PORT $TOX_PUBLIC_KEY" >> /home/$MY_USERNAME/README
|
|
|
|
chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
|
|
|
|
chmod 600 /home/$MY_USERNAME/README
|
|
|
|
fi
|
|
|
|
|
|
|
|
function_check configure_firewall_for_tox
|
|
|
|
configure_firewall_for_tox
|
|
|
|
echo 'install_tox_node' >> $COMPLETION_FILE
|
|
|
|
}
|
|
|
|
|
|
|
|
function install_tox_client {
|
|
|
|
if grep -Fxq "install_tox_client" $COMPLETION_FILE; then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
|
|
|
|
${PROJECT_NAME}-mesh-install -f tox_client
|
|
|
|
if [ ! "$?" = "0" ]; then
|
|
|
|
echo $'Could not install Tox client'
|
|
|
|
exit 67248
|
|
|
|
fi
|
|
|
|
|
|
|
|
# initial setup of username
|
|
|
|
#su -c "echo 'n
|
|
|
|
#/nick $MY_USERNAME
|
|
|
|
#/exit
|
|
|
|
#' | $TOXIC_FILE -d" - $MY_USERNAME
|
|
|
|
|
|
|
|
echo 'install_tox_client' >> $COMPLETION_FILE
|
|
|
|
}
|
|
|
|
|
2016-07-05 21:07:43 +02:00
|
|
|
function install_tox {
|
2016-07-06 16:40:09 +02:00
|
|
|
if grep -Fxq "install_tox" $COMPLETION_FILE; then
|
2016-07-05 21:07:43 +02:00
|
|
|
return
|
|
|
|
fi
|
|
|
|
configure_firewall_for_tox
|
|
|
|
install_tox_node
|
|
|
|
tox_avahi
|
|
|
|
install_tox_client
|
|
|
|
echo 'install_tox' >> $COMPLETION_FILE
|
|
|
|
}
|
|
|
|
|
2016-07-03 17:13:34 +02:00
|
|
|
# NOTE: deliberately no exit 0
|