# -*- mode: ruby -*-
# vi: set ft=ruby :

$provision = <<SCRIPT

cd /vagrant # This is where the host folder/repo is mounted

# Add repo for Ruby 2.3 binaries
sudo apt-add-repository ppa:brightbox/ruby-ng

# Add repo for NodeJS
curl -sL https://deb.nodesource.com/setup_4.x | sudo bash -

# Add firewall rule to redirect 80 to 3000 and save
sudo iptables -t nat -A PREROUTING -p tcp --dport 80 -j REDIRECT --to-port 3000
echo iptables-persistent iptables-persistent/autosave_v4 boolean true | sudo debconf-set-selections
echo iptables-persistent iptables-persistent/autosave_v6 boolean true | sudo debconf-set-selections
sudo apt-get install iptables-persistent -y

# Add packages to build and run Mastodon
sudo apt-get install \
  git-core \
  ruby-build \
  libpq-dev \
  libxml2-dev \
  libxslt1-dev \
  imagemagick \
  nodejs \
  ruby2.3 \
  ruby2.3-dev \
  ruby-switch \
  redis-server \
  redis-tools \
  postgresql \
  postgresql-contrib \
  -y

# Set Ruby 2.3 as 'ruby'
sudo ruby-switch --set ruby2.3

# Configure database
sudo -u postgres createuser -U postgres vagrant -s
sudo -u postgres createdb -U postgres mastodon_development

# Install gems and node modules
sudo gem install bundler
bundle install
yarn install

# Build Mastodon
bundle exec rails db:setup
bundle exec rails assets:precompile

SCRIPT

$start = <<SCRIPT

cd /vagrant
export $(cat ".env.vagrant" | xargs)
killall ruby2.3
rails s -d -b 0.0.0.0

SCRIPT

VAGRANTFILE_API_VERSION = "2"

Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|

  config.vm.box = "ubuntu/trusty64"

  config.vm.provider :virtualbox do |vb|
    vb.name = "mastodon"
    vb.customize ["modifyvm", :id, "--memory", "1024"]
  end

  config.vm.hostname = "mastodon.dev"

  # This uses the vagrant-hostsupdater plugin, and lets you
  # access the development site at http://mastodon.dev.
  # To install:
  #   $ vagrant plugin install hostsupdater
  if defined?(VagrantPlugins::HostsUpdater)
    config.vm.network :private_network, ip: "192.168.42.42"
    config.hostsupdater.remove_on_suspend = false
  end

  # Otherwise, you can access the site at http://localhost:3000
  config.vm.network :forwarded_port, guest: 80, host: 3000

  # Full provisioning script, only runs on first 'vagrant up' or with 'vagrant provision'
  config.vm.provision :shell, inline: $provision, privileged: false

  # Start up script, runs on every 'vagrant up'
  config.vm.provision :shell, inline: $start, run: 'always', privileged: false

end