mirror of https://github.com/mastodon/mastodon
				
				
				
			Merge pull request #425 from ineffyble/vagrant
Add Vagrant support for easy development environmentspull/428/head
						commit
						2fbb38e4b2
					
				@ -0,0 +1,96 @@
 | 
			
		||||
# -*- 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
 | 
			
		||||
					Loading…
					
					
				
		Reference in New Issue