2019-03-05 05:04:18 -05:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
#
|
|
|
|
# Provision virtual machine
|
|
|
|
#
|
|
|
|
# This script is expected to run a part of the vagrant virtual machine provisioning process. It
|
|
|
|
# is run by the root user and should do all required installation and setup:
|
|
|
|
# 1. Install OS packages
|
|
|
|
# 2. Provision Postgres database
|
|
|
|
# 3. Light-touch set up of virtual machine environment for user convenience (other programs
|
|
|
|
# or dependencies, .bashrc or other dotfiles)
|
|
|
|
#
|
|
|
|
|
|
|
|
# Echo commands as they are executed
|
|
|
|
set -x
|
|
|
|
|
|
|
|
# Create vagrant user if not exists
|
|
|
|
id -u vagrant >/dev/null 2>&1 || useradd --create-home vagrant
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Install OS packages
|
|
|
|
#
|
|
|
|
|
|
|
|
apt-get update
|
|
|
|
# Install:
|
|
|
|
# - basics: build-essential git vim-nox
|
|
|
|
# - python with pip and venv: python3 python3-pip python3-dev
|
|
|
|
# - postgres and postgis: postgresql postgresql-contrib libpq-dev postgis postgresql-10-postgis-2.4
|
|
|
|
# - spatial shared libs: gdal-bin libspatialindex-dev libgeos-dev libproj-dev
|
|
|
|
apt-get install -y \
|
|
|
|
build-essential git vim-nox wget curl \
|
|
|
|
python3 python3-pip python3-dev python3-venv \
|
|
|
|
postgresql postgresql-contrib libpq-dev postgis postgresql-10-postgis-2.4 \
|
|
|
|
gdal-bin libspatialindex-dev libgeos-dev libproj-dev
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Install node.js (node and npm)
|
|
|
|
#
|
|
|
|
|
|
|
|
# node version and platform
|
|
|
|
NODE_VERSION=v8.11.3
|
|
|
|
DISTRO=linux-x64
|
|
|
|
|
|
|
|
# download
|
|
|
|
wget -nc https://nodejs.org/dist/$NODE_VERSION/node-$NODE_VERSION-$DISTRO.tar.xz
|
|
|
|
|
|
|
|
# extract
|
|
|
|
sudo mkdir /usr/local/lib/node
|
|
|
|
sudo tar xf node-$NODE_VERSION-$DISTRO.tar.xz -C /usr/local/lib/node
|
|
|
|
sudo mv /usr/local/lib/node/node-$NODE_VERSION-$DISTRO /usr/local/lib/node/node-$NODE_VERSION
|
|
|
|
rm node-$NODE_VERSION-$DISTRO.tar.xz
|
|
|
|
|
|
|
|
# add to user PATH
|
|
|
|
cat >> /home/vagrant/.profile <<EOF
|
|
|
|
# Nodejs
|
|
|
|
export NODEJS_HOME=/usr/local/lib/node/node-$NODE_VERSION/bin
|
|
|
|
export PATH=\$NODEJS_HOME:\$PATH
|
|
|
|
EOF
|
|
|
|
|
|
|
|
# add to current (root user) path
|
|
|
|
export NODEJS_HOME=/usr/local/lib/node/node-$NODE_VERSION/bin
|
|
|
|
export PATH=$NODEJS_HOME:$PATH
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Setup PostgreSQL database
|
|
|
|
#
|
|
|
|
|
|
|
|
# Ensure postgres is running
|
|
|
|
service postgresql start
|
|
|
|
# Ensure en_US locale exists
|
|
|
|
locale-gen en_US.UTF-8
|
|
|
|
# Database config to listen on network connection
|
|
|
|
sed -i "s/#\?listen_address.*/listen_addresses '*'/" /etc/postgresql/9.5/main/postgresql.conf
|
|
|
|
# Allow password connections from any IP (so includes host)
|
|
|
|
echo "host all all all md5" >> /etc/postgresql/10/main/pg_hba.conf
|
|
|
|
# Restart postgres to pick up config changes
|
|
|
|
service postgresql restart
|
|
|
|
|
|
|
|
# Create vagrant role if not exists
|
|
|
|
su postgres -c "psql -c \"SELECT 1 FROM pg_user WHERE usename = 'vagrant';\" " \
|
|
|
|
| grep -q 1 || su postgres -c "psql -c \"CREATE ROLE vagrant SUPERUSER LOGIN PASSWORD 'vagrant';\" "
|
|
|
|
# Create vagrant database if not exists
|
|
|
|
su postgres -c "psql -c \"SELECT 1 FROM pg_database WHERE datname = 'vagrant';\" " \
|
|
|
|
| grep -q 1 || su postgres -c "createdb -E UTF8 -T template0 --locale=en_US.utf8 -O vagrant vagrant"
|
|
|
|
|
|
|
|
# Run all 'up' migrations to create tables, data types, indexes
|
2019-03-05 06:33:24 -05:00
|
|
|
su postgres -c "ls /vagrant/migrations/*.up.sql 2>/dev/null | while read -r migration; do psql < \$migration; done;"
|
2019-03-05 05:04:18 -05:00
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Install python packages
|
|
|
|
#
|
|
|
|
|
|
|
|
# set up env
|
|
|
|
pyvenv colouringlondon
|
|
|
|
source colouringlondon/bin/activate
|
|
|
|
|
|
|
|
# Install smif
|
|
|
|
pip install --upgrade pip
|
|
|
|
pip install --upgrade setuptools wheel
|
|
|
|
pip install -r /vagrant/etl/requirements.txt
|
|
|
|
|
|
|
|
# Make virtualenv user-editable
|
|
|
|
chown -R vagrant:vagrant /home/vagrant/colouringlondon
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# Install node modules
|
|
|
|
#
|
|
|
|
|
|
|
|
# Install latest release of npm
|
|
|
|
npm install -g npm@next
|
|
|
|
|
|
|
|
# Local fixed install of node modules
|
|
|
|
cd /vagrant/app && npm ci
|
|
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
# User config
|
|
|
|
#
|
|
|
|
|
|
|
|
# Copy bash config to vagrant home (making sure to clean windows newlines using tr)
|
|
|
|
tr -d '\r' < /vagrant/provision/.bashrc > /home/vagrant/.bashrc
|
|
|
|
chown vagrant:vagrant /home/vagrant/.bashrc
|