# -*- mode: ruby -*- VAGRANTFILE_API_VERSION = "2" def command?(name) `which #{name} > /dev/null 2>&1` $?.success? end if Vagrant::VERSION == "1.8.7" then path = `which curl` if path.include?('/opt/vagrant/embedded/bin/curl') then puts "In Vagrant 1.8.7, curl is broken. Please use Vagrant 2.0.2 "\ "or run 'sudo rm -f /opt/vagrant/embedded/bin/curl' to fix the "\ "issue before provisioning. See "\ "https://github.com/mitchellh/vagrant/issues/7997 "\ "for reference." exit end end # Workaround: Vagrant removed the atlas.hashicorp.com to # vagrantcloud.com redirect in February 2018. The value of # DEFAULT_SERVER_URL in Vagrant versions less than 1.9.3 is # atlas.hashicorp.com, which means that removal broke the fetching and # updating of boxes (since the old URL doesn't work). See # https://github.com/hashicorp/vagrant/issues/9442 Vagrant::DEFAULT_SERVER_URL.replace('https://vagrantcloud.com') Vagrant.configure(VAGRANTFILE_API_VERSION) do |config| # For LXC. VirtualBox hosts use a different box, described below. config.vm.box = "fgrehm/trusty64-lxc" # The Zulip development environment runs on 9991 on the guest. host_port = 9991 http_proxy = https_proxy = no_proxy = nil host_ip_addr = "127.0.0.1" config.vm.synced_folder ".", "/vagrant", disabled: true if (/darwin/ =~ RUBY_PLATFORM) != nil config.vm.synced_folder ".", "/srv/zulip", type: "nfs", linux__nfs_options: ['rw'] config.vm.network "private_network", type: "dhcp" else config.vm.synced_folder ".", "/srv/zulip" end vagrant_config_file = ENV['HOME'] + "/.zulip-vagrant-config" if File.file?(vagrant_config_file) IO.foreach(vagrant_config_file) do |line| line.chomp! key, value = line.split(nil, 2) case key when /^([#;]|$)/; # ignore comments when "HTTP_PROXY"; http_proxy = value when "HTTPS_PROXY"; https_proxy = value when "NO_PROXY"; no_proxy = value when "HOST_PORT"; host_port = value.to_i when "HOST_IP_ADDR"; host_ip_addr = value end end end if Vagrant.has_plugin?("vagrant-proxyconf") if !http_proxy.nil? config.proxy.http = http_proxy end if !https_proxy.nil? config.proxy.https = https_proxy end if !no_proxy.nil? config.proxy.no_proxy = no_proxy end elsif !http_proxy.nil? or !https_proxy.nil? # This prints twice due to https://github.com/hashicorp/vagrant/issues/7504 # We haven't figured out a workaround. puts 'You have specified value for proxy in ~/.zulip-vagrant-config file but did not ' \ 'install the vagrant-proxyconf plugin. To install it, run `vagrant plugin install ' \ 'vagrant-proxyconf` in a terminal. This error will appear twice.' exit end config.vm.network "forwarded_port", guest: 9991, host: host_port, host_ip: host_ip_addr # Specify LXC provider before VirtualBox provider so it's preferred. config.vm.provider "lxc" do |lxc| if command? "lxc-ls" LXC_VERSION = `lxc-ls --version`.strip unless defined? LXC_VERSION if LXC_VERSION >= "1.1.0" # Allow start without AppArmor, otherwise Box will not Start on Ubuntu 14.10 # see https://github.com/fgrehm/vagrant-lxc/issues/333 lxc.customize 'aa_allow_incomplete', 1 end if LXC_VERSION >= "2.0.0" lxc.backingstore = 'dir' end end end config.vm.provider "virtualbox" do |vb, override| override.vm.box = "ubuntu/trusty64" # It's possible we can get away with just 1.5GB; more testing needed vb.memory = 2048 vb.cpus = 2 end config.vm.provider "vmware_fusion" do |vb, override| override.vm.box = "puphpet/ubuntu1404-x64" vb.vmx["memsize"] = "2048" vb.vmx["numvcpus"] = "2" end $provision_script = <