2013-05-29 17:34:18 +02:00
|
|
|
# -*- mode: ruby -*-
|
|
|
|
# vi: set ft=ruby :
|
|
|
|
|
2014-05-30 16:21:04 +02:00
|
|
|
VAGRANTFILE_API_VERSION = "2"
|
|
|
|
VAGRANT_REQUIRED_VERSION = "1.2.0"
|
|
|
|
|
|
|
|
# Require 1.2.x at least
|
|
|
|
if ! defined? Vagrant.require_version
|
|
|
|
if Gem::Version.new(Vagrant::VERSION) < Gem::Version.new(VAGRANT_REQUIRED_VERSION)
|
|
|
|
puts "Vagrant >= " + VAGRANT_REQUIRED_VERSION + " required. Your version is " + Vagrant::VERSION
|
|
|
|
exit 1
|
|
|
|
end
|
|
|
|
else
|
|
|
|
Vagrant.require_version ">= " + VAGRANT_REQUIRED_VERSION
|
|
|
|
end
|
|
|
|
|
|
|
|
Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
|
2013-05-29 17:34:18 +02:00
|
|
|
# All Vagrant configuration is done here. The most common configuration
|
|
|
|
# options are documented and commented below. For a complete reference,
|
|
|
|
# please see the online documentation at vagrantup.com.
|
|
|
|
|
|
|
|
# Every Vagrant virtual environment requires a box to build off of.
|
|
|
|
config.vm.box = "centos-6.4-x64-vbox"
|
|
|
|
|
|
|
|
# The url from where the 'config.vm.box' box will be fetched if it
|
|
|
|
# doesn't already exist on the user's system.
|
|
|
|
config.vm.box_url = "http://vagrant-boxes.icinga.org/centos-64-x64-vbox4212.box"
|
|
|
|
|
2013-07-23 16:26:14 +02:00
|
|
|
# Create a forwarded port mapping which allows access to a specific port
|
|
|
|
# within the machine from a port on the host machine. In the example below,
|
|
|
|
# accessing "localhost:8080" will access port 80 on the guest machine.
|
|
|
|
config.vm.network :forwarded_port, guest: 80, host: 8080,
|
|
|
|
# Port collision auto-correction must be manually enabled for each forwarded port,
|
|
|
|
# since it is often surprising when it occurs and can lead the Vagrant user to
|
|
|
|
# think that the port wasn't properly forwarded. During a vagrant up or vagrant reload,
|
|
|
|
# Vagrant will output information about any collisions detections and auto corrections made,
|
|
|
|
# so you can take notice and act accordingly.
|
|
|
|
auto_correct: true
|
2013-05-29 17:34:18 +02:00
|
|
|
|
2013-07-23 16:26:14 +02:00
|
|
|
# Create a private network, which allows host-only access to the machine
|
|
|
|
# using a specific IP.
|
|
|
|
# config.vm.network :private_network, ip: "192.168.33.10"
|
2013-05-29 17:34:18 +02:00
|
|
|
|
2013-07-23 16:26:14 +02:00
|
|
|
# Create a public network, which generally matched to bridged network.
|
|
|
|
# Bridged networks make the machine appear as another physical device on
|
|
|
|
# your network.
|
|
|
|
# config.vm.network :public_network
|
2013-05-29 17:34:18 +02:00
|
|
|
|
2013-07-23 16:26:14 +02:00
|
|
|
# If true, then any SSH connections made will enable agent forwarding.
|
|
|
|
# Default value: false
|
|
|
|
# config.ssh.forward_agent = true
|
2013-05-29 17:34:18 +02:00
|
|
|
|
2013-07-23 16:26:14 +02:00
|
|
|
# Share an additional folder to the guest VM. The first argument is
|
|
|
|
# the path on the host to the actual folder. The second argument is
|
|
|
|
# the path on the guest to mount the folder. And the optional third
|
|
|
|
# argument is a set of non-required options.
|
|
|
|
config.vm.synced_folder "./config", "/vagrant/config"
|
2013-08-14 17:52:11 +02:00
|
|
|
config.vm.synced_folder "./var/log", "/vagrant/var/log"
|
2013-07-23 16:26:14 +02:00
|
|
|
|
|
|
|
# Provider-specific configuration so you can fine-tune various
|
|
|
|
# backing providers for Vagrant. These expose provider-specific options.
|
|
|
|
# Example for VirtualBox:
|
|
|
|
#
|
|
|
|
# config.vm.provider :virtualbox do |vb|
|
|
|
|
# # Don't boot with headless mode
|
|
|
|
# vb.gui = true
|
|
|
|
#
|
|
|
|
# # Use VBoxManage to customize the VM. For example to change memory:
|
|
|
|
# vb.customize ["modifyvm", :id, "--memory", "1024"]
|
|
|
|
# end
|
|
|
|
#
|
|
|
|
# View the documentation for the provider you're using for more
|
|
|
|
# information on available options.
|
|
|
|
config.vm.provider "virtualbox" do |vb|
|
|
|
|
vb.customize ["setextradata", :id, "VBoxInternal2/SharedFoldersEnableSymlinksCreate//vagrant/config", "1"]
|
|
|
|
end
|
|
|
|
|
|
|
|
# Enable provisioning with Puppet stand alone. Puppet manifests
|
|
|
|
# are contained in a directory path relative to this Vagrantfile.
|
|
|
|
# You will need to create the manifests directory and a manifest in
|
|
|
|
# the file base.pp in the manifests_path directory.
|
|
|
|
#
|
2013-05-29 17:34:18 +02:00
|
|
|
# An example Puppet manifest to provision the message of the day:
|
|
|
|
#
|
|
|
|
# # group { "puppet":
|
|
|
|
# # ensure => "present",
|
|
|
|
# # }
|
|
|
|
# #
|
|
|
|
# # File { owner => 0, group => 0, mode => 0644 }
|
|
|
|
# #
|
|
|
|
# # file { '/etc/motd':
|
|
|
|
# # content => "Welcome to your Vagrant-built virtual machine!
|
|
|
|
# # Managed by Puppet.\n"
|
|
|
|
# # }
|
2013-07-23 16:26:14 +02:00
|
|
|
#
|
|
|
|
# config.vm.provision :puppet do |puppet|
|
|
|
|
# puppet.manifests_path = "manifests"
|
|
|
|
# puppet.manifest_file = "init.pp"
|
|
|
|
# end
|
2013-05-29 17:34:18 +02:00
|
|
|
config.vm.provision :puppet do |puppet|
|
|
|
|
puppet.module_path = ".vagrant-puppet/modules"
|
|
|
|
puppet.manifests_path = ".vagrant-puppet/manifests"
|
2013-07-22 14:47:33 +02:00
|
|
|
# puppet.options = "-v -d"
|
2013-06-28 13:45:13 +02:00
|
|
|
end
|
|
|
|
|
2013-07-22 14:47:33 +02:00
|
|
|
config.vm.provision :shell, :path => ".vagrant-puppet/manifests/finalize.sh"
|
2013-05-29 17:34:18 +02:00
|
|
|
end
|