You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

147 lines
4.6 KiB

  1. # -*- mode: ruby -*-
  2. # vi: set ft=ruby :
  3. ENV["PORT"] ||= "3000"
  4. $provision = <<SCRIPT
  5. cd /vagrant # This is where the host folder/repo is mounted
  6. # Add the yarn repo + yarn repo keys
  7. curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | sudo apt-key add -
  8. sudo apt-add-repository 'deb https://dl.yarnpkg.com/debian/ stable main'
  9. # Add repo for NodeJS
  10. curl -sL https://deb.nodesource.com/setup_12.x | sudo bash -
  11. # Add firewall rule to redirect 80 to PORT and save
  12. sudo iptables -t nat -A PREROUTING -p tcp --dport 80 -j REDIRECT --to-port #{ENV["PORT"]}
  13. echo iptables-persistent iptables-persistent/autosave_v4 boolean true | sudo debconf-set-selections
  14. echo iptables-persistent iptables-persistent/autosave_v6 boolean true | sudo debconf-set-selections
  15. sudo apt-get install iptables-persistent -y
  16. # Add packages to build and run Mastodon
  17. sudo apt-get install \
  18. git-core \
  19. g++ \
  20. libpq-dev \
  21. libxml2-dev \
  22. libxslt1-dev \
  23. imagemagick \
  24. nodejs \
  25. redis-server \
  26. redis-tools \
  27. postgresql \
  28. postgresql-contrib \
  29. protobuf-compiler \
  30. yarn \
  31. libicu-dev \
  32. libidn11-dev \
  33. libprotobuf-dev \
  34. libreadline-dev \
  35. libpam0g-dev \
  36. -y
  37. # Install rvm
  38. read RUBY_VERSION < .ruby-version
  39. gpg_command="gpg --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 7D2BAF1CF37B13E2069D6956105BD0E739499BDB"
  40. $($gpg_command)
  41. if [ $? -ne 0 ];then
  42. echo "GPG command failed, This prevented RVM from installing."
  43. echo "Retrying once..." && $($gpg_command)
  44. if [ $? -ne 0 ];then
  45. echo "GPG failed for the second time, please ensure network connectivity."
  46. echo "Exiting..." && exit 1
  47. fi
  48. fi
  49. curl -sSL https://raw.githubusercontent.com/rvm/rvm/stable/binscripts/rvm-installer | bash -s stable --ruby=$RUBY_VERSION
  50. source /home/vagrant/.rvm/scripts/rvm
  51. # Install Ruby
  52. rvm reinstall ruby-$RUBY_VERSION --disable-binary
  53. # Configure database
  54. sudo -u postgres createuser -U postgres vagrant -s
  55. sudo -u postgres createdb -U postgres mastodon_development
  56. # Install gems and node modules
  57. gem install bundler foreman
  58. bundle install
  59. yarn install
  60. # Build Mastodon
  61. export RAILS_ENV=development
  62. export $(cat ".env.vagrant" | xargs)
  63. bundle exec rails db:setup
  64. # Configure automatic loading of environment variable
  65. echo 'export RAILS_ENV=development' >> ~/.bash_profile
  66. echo 'export $(cat "/vagrant/.env.vagrant" | xargs)' >> ~/.bash_profile
  67. SCRIPT
  68. $start = <<SCRIPT
  69. echo 'To start server'
  70. echo ' $ vagrant ssh -c "cd /vagrant && foreman start"'
  71. SCRIPT
  72. VAGRANTFILE_API_VERSION = "2"
  73. Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
  74. config.vm.box = "ubuntu/bionic64"
  75. config.vm.provider :virtualbox do |vb|
  76. vb.name = "mastodon"
  77. vb.customize ["modifyvm", :id, "--memory", "2048"]
  78. # Increase the number of CPUs. Uncomment and adjust to
  79. # increase performance
  80. # vb.customize ["modifyvm", :id, "--cpus", "3"]
  81. # Disable VirtualBox DNS proxy to skip long-delay IPv6 resolutions.
  82. # https://github.com/mitchellh/vagrant/issues/1172
  83. vb.customize ["modifyvm", :id, "--natdnsproxy1", "off"]
  84. vb.customize ["modifyvm", :id, "--natdnshostresolver1", "off"]
  85. # Use "virtio" network interfaces for better performance.
  86. vb.customize ["modifyvm", :id, "--nictype1", "virtio"]
  87. vb.customize ["modifyvm", :id, "--nictype2", "virtio"]
  88. end
  89. # This uses the vagrant-hostsupdater plugin, and lets you
  90. # access the development site at http://mastodon.local.
  91. # If you change it, also change it in .env.vagrant before provisioning
  92. # the vagrant server to update the development build.
  93. #
  94. # To install:
  95. # $ vagrant plugin install vagrant-hostsupdater
  96. config.vm.hostname = "mastodon.local"
  97. if defined?(VagrantPlugins::HostsUpdater)
  98. config.vm.network :private_network, ip: "192.168.42.42", nictype: "virtio"
  99. config.hostsupdater.remove_on_suspend = false
  100. end
  101. if config.vm.networks.any? { |type, options| type == :private_network }
  102. config.vm.synced_folder ".", "/vagrant", type: "nfs", mount_options: ['rw', 'vers=3', 'tcp', 'actimeo=1']
  103. else
  104. config.vm.synced_folder ".", "/vagrant"
  105. end
  106. # Otherwise, you can access the site at http://localhost:3000 and http://localhost:4000 , http://localhost:8080
  107. config.vm.network :forwarded_port, guest: 3000, host: 3000
  108. config.vm.network :forwarded_port, guest: 4000, host: 4000
  109. config.vm.network :forwarded_port, guest: 8080, host: 8080
  110. # Full provisioning script, only runs on first 'vagrant up' or with 'vagrant provision'
  111. config.vm.provision :shell, inline: $provision, privileged: false
  112. # Start up script, runs on every 'vagrant up'
  113. config.vm.provision :shell, inline: $start, run: 'always', privileged: false
  114. end