| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 | # -*- mode: ruby -*-# vi: set ft=ruby :def packages_prepare_wheezy  return <<-EOF      # debian 7 wheezy does not have lz4, but it is available from wheezy-backports:      echo "deb http://http.debian.net/debian wheezy-backports main" > /etc/apt/sources.list.d/wheezy-backports.list  EOFenddef packages_prepare_precise  return <<-EOF      # ubuntu 12.04 precise does not have lz4, but it is available from a ppa:      add-apt-repository -y ppa:gezakovacs/lz4  EOFenddef packages_debianoid  return <<-EOF    apt-get update    apt-get install -y python3-dev python3-setuptools    apt-get install -y libssl-dev libacl1-dev liblz4-dev    apt-get install -y libfuse-dev fuse pkg-config    apt-get install -y fakeroot build-essential git    # this way it works on older dists (like ubuntu 12.04) also:    easy_install3 pip    pip3 install virtualenv  EOFenddef packages_freebsd  return <<-EOF    pkg install -y python34 py34-setuptools34    ln -s /usr/local/bin/python3.4 /usr/local/bin/python3    pkg install -y openssl liblz4    pkg install -y fusefs-libs pkgconf    pkg install -y fakeroot git    easy_install-3.4 pip    pip3 install virtualenv    # make FUSE work    echo 'fuse_load="YES"' >> /boot/loader.conf    echo 'vfs.usermount=1' >> /etc/sysctl.conf    kldload fuse    sysctl vfs.usermount=1    pw groupmod operator -M vagrant  EOFenddef packages_darwin  return <<-EOF    ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"    brew update    # this installs osxfuse 2.8.0 (which is based on libfuse 2.7.3).    # llfuse later complains about needing (libfuse) 2.8.0 at least.    #brew install caskroom/cask/brew-cask    #brew cask install osxfuse  # needs cask install because of apple's unsigned kext ban    # get osxfuse 3.0.x pre-release code from github:    curl https://github.com/osxfuse/osxfuse/releases/download/osxfuse-3.0.5/osxfuse-3.0.5.dmg -L >osxfuse.dmg    MOUNTDIR=$(echo `hdiutil mount osxfuse.dmg | tail -1 | awk '{$1="" ; print $0}'` | xargs -0 echo) \    && sudo installer -pkg "${MOUNTDIR}/Extras/FUSE for OS X 3.0.5.pkg" -target /    brew install openssl    brew install lz4    # looks dirty, is there a better way without root?:    mkdir -p /usr/local/opt/lz4    ln -s /usr/local/Cellar/lz4/r*/include /usr/local/opt/lz4/    ln -s /usr/local/Cellar/lz4/r*/lib /usr/local/opt/lz4/    brew install fakeroot    brew install pyenv    if which pyenv > /dev/null; then        eval "$(pyenv init -)"    fi    pyenv install 3.4.3    pyenv global 3.4.3    pyenv rehash    python -m pip install --user virtualenv  EOFenddef prepare_user(boxname)  return <<-EOF    echo export 'PATH=/usr/local/bin:$PATH' >> ~/.profile    . ~/.profile    # initialize python on darwin    if which pyenv > /dev/null; then        eval "$(pyenv init -)"    fi    cd /vagrant/borg    python -m virtualenv --python=python3 borg-env    . borg-env/bin/activate    cd borg    pip install -U pip setuptools    pip install 'llfuse<0.41'  # 0.41 does not install due to UnicodeDecodeError    pip install -r requirements.d/development.txt    pip install -e .    echo    echo "Run:"    echo "  vagrant rsync #{boxname}"    echo "  vagrant ssh #{boxname} -c 'cd project/path; ...'"  EOFenddef fix_perms  return <<-EOF    chown -R vagrant /vagrant/borg  EOFendVagrant.configure(2) do |config|  # use rsync to copy content to the folder  config.vm.synced_folder ".", "/vagrant/borg/borg", :type => "rsync"  # do not let the VM access . on the host machine via the default shared folder!  config.vm.synced_folder ".", "/vagrant", disabled: true  # fix permissions on synced folder  config.vm.provision "fix perms", :type => :shell, :inline => fix_perms  config.vm.provider :virtualbox do |v|    #v.gui = true    v.cpus = 2  end  config.vm.define "trusty64" do |b|    b.vm.box = "ubuntu/trusty64"    b.vm.provision "packages debianoid", :type => :shell, :inline => packages_debianoid    b.vm.provision "prepare user", :type => :shell, :privileged => false, :inline => prepare_user("trusty64")  end  config.vm.define "precise32" do |b|    b.vm.box = "ubuntu/precise32"    b.vm.provision "packages prepare precise", :type => :shell, :inline => packages_prepare_precise    b.vm.provision "packages debianoid", :type => :shell, :inline => packages_debianoid    b.vm.provision "prepare user", :type => :shell, :privileged => false, :inline => prepare_user("precise32")  end  config.vm.define "jessie64" do |b|    b.vm.box = "debian/jessie64"    b.vm.provision "packages debianoid", :type => :shell, :inline => packages_debianoid    b.vm.provision "prepare user", :type => :shell, :privileged => false, :inline => prepare_user("jessie64")  end  config.vm.define "wheezy32" do |b|    b.vm.box = "puppetlabs/debian-7.8-32-nocm"    b.vm.provision "packages prepare wheezy", :type => :shell, :inline => packages_prepare_wheezy    b.vm.provision "packages debianoid", :type => :shell, :inline => packages_debianoid    b.vm.provision "prepare user", :type => :shell, :privileged => false, :inline => prepare_user("wheezy32")  end  # BSD  config.vm.define "freebsd" do |b|    b.vm.box = "geoffgarside/freebsd-10.2"    b.vm.provision "packages freebsd", :type => :shell, :inline => packages_freebsd    b.vm.provision "prepare user", :type => :shell, :privileged => false, :inline => prepare_user("freebsd")  end  # OS X  config.vm.define "darwin" do |b|    b.vm.box = "jhcook/yosemite-clitools"    b.vm.provision "packages darwin", :type => :shell, :privileged => false, :inline => packages_darwin    b.vm.provision "prepare user",   :type => :shell, :privileged => false, :inline => prepare_user("darwin")  endend
 |