2016-09-11 23:52:31 +00:00
#!/bin/bash
2017-03-16 13:35:41 +00:00
__dirname = $( cd $( dirname " $0 " ) ; pwd -P)
cd ${ __dirname }
2016-12-01 15:39:42 +00:00
2016-12-29 21:15:59 +00:00
echo -e "\033[92m"
2016-12-01 15:39:42 +00:00
echo " _ __ __ ____ ____ __ ___"
echo "| | / /__ / /_ / __ \/ __ \/ |/ /"
echo "| | /| / / _ \/ __ \/ / / / / / / /|_/ / "
echo "| |/ |/ / __/ /_/ / /_/ / /_/ / / / / "
echo "|__/|__/\___/_.___/\____/_____/_/ /_/ "
echo
2016-12-29 21:15:59 +00:00
echo -e "\033[39m"
2016-12-01 15:39:42 +00:00
2016-12-12 19:09:25 +00:00
almost_there( ) {
2016-12-01 15:39:42 +00:00
echo
echo "===================="
echo "You're almost there!"
echo "===================="
2016-12-12 19:09:25 +00:00
}
# Check python version
python -c "import sys;ret = 1 if sys.version_info <= (3, 0) else 0;print('Checking python version... ' + ('3.x, good!' if ret == 0 else '2.x'));sys.exit(ret);"
2016-12-14 14:06:04 +00:00
if [ $? -ne 0 ] ; then
2016-12-12 19:09:25 +00:00
almost_there
2016-12-29 21:15:59 +00:00
echo -e "\033[33mYour system is currently using Python 2.x. You need to install or configure your system to use Python 3.x. Check out http://docs.python-guide.org/en/latest/dev/virtualenvs/ for information on how to setup Python 3.x alongside your Python 2.x install.\033[39m"
2016-12-01 15:39:42 +00:00
echo
exit
fi
2016-12-12 19:09:25 +00:00
# Check GDAL version
python -c "import sys;import re;import subprocess;version = subprocess.Popen([\"gdalinfo\", \"--version\"], stdout=subprocess.PIPE).communicate()[0].decode().rstrip();ret = 0 if re.compile('^GDAL [2-9]\.[1-9]+').match(version) else 1; print('Checking GDAL version... ' + ('{}, excellent!'.format(version) if ret == 0 else version));sys.exit(ret);"
2016-12-14 14:06:04 +00:00
if [ $? -ne 0 ] ; then
2016-12-12 19:09:25 +00:00
almost_there
2016-12-29 21:15:59 +00:00
echo -e "\033[33mYour system is currently using a version of GDAL that is too old, or GDAL is not installed. You need to install or configure your system to use GDAL 2.1 or higher. If you have installed multiple versions of GDAL, make sure the newer one takes priority in your PATH environment variable.\033[39m"
2016-12-12 19:09:25 +00:00
echo
exit
fi
2017-05-19 20:39:43 +00:00
if [ " $1 " = "--setup-devenv" ] || [ " $2 " = "--setup-devenv" ] ; then
2017-03-15 16:25:02 +00:00
echo Setup git modules...
2017-03-16 13:35:41 +00:00
git submodule update --init
2017-03-15 16:25:02 +00:00
echo Setup npm dependencies...
npm install
cd nodeodm/external/node-OpenDroneMap
npm install
cd /webodm
echo Setup webpack watch...
webpack --watch &
fi
2016-10-11 17:42:17 +00:00
2016-09-27 21:11:02 +00:00
echo Running migrations
python manage.py migrate
2016-09-11 23:52:31 +00:00
2017-05-19 20:39:43 +00:00
if [ [ " $1 " = "--create-default-pnode" ] ] ; then
2016-12-01 15:39:42 +00:00
echo "from nodeodm.models import ProcessingNode; ProcessingNode.objects.update_or_create(hostname='node-odm-1', defaults={'hostname': 'node-odm-1', 'port': 3000})" | python manage.py shell
fi
2017-01-21 16:44:10 +00:00
( sleep 5; echo
echo -e "\033[92m"
echo "Congratulations! └@(・◡・)@┐"
echo = = = = = = = = = = = = = = = = = = = = = = = = = =
echo -e "\033[39m"
2017-01-21 17:50:53 +00:00
echo "If there are no errors, WebODM should be up and running!"
2017-01-21 16:44:10 +00:00
echo -e "\033[93m"
echo Open a web browser and navigate to http://localhost:8000
echo -e "\033[39m"
echo -e "\033[91mNOTE:\033[39m Windows users using docker should replace localhost with the IP of their docker machine's IP. To find what that is, run: docker-machine ip" ) &
2017-05-21 19:08:19 +00:00
if [ " $1 " = "--setup-devenv" ] || [ " $2 " = "--setup-devenv" ] || [ " $1 " = "--no-gunicorn" ] ; then
2017-05-19 20:15:26 +00:00
python manage.py runserver 0.0.0.0:8000
else
2017-06-05 22:32:26 +00:00
if [ ! -e /webodm/build/static ] ; then
echo -e "\033[91mWARN:\033[39m /webodm/build/static does not exist, CSS, JS and other files might not be available."
fi
2017-06-05 22:25:17 +00:00
nginx -c $( pwd ) /nginx/nginx.conf
2017-06-07 19:27:02 +00:00
gunicorn webodm.wsgi --bind unix:/tmp/gunicorn.sock --timeout 360 --preload
2017-05-19 20:15:26 +00:00
fi
2017-01-21 16:44:10 +00:00
# If this is executed, it means the previous command failed, don't display the congratulations message
kill %1