70 lines
3.0 KiB
Ruby
70 lines
3.0 KiB
Ruby
# -*- mode: ruby -*-
|
|
# vi: set ft=ruby :
|
|
|
|
Vagrant::Config.run do |config|
|
|
# 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"
|
|
|
|
# Boot with a GUI so you can see the screen. (Default is headless)
|
|
# config.vm.boot_mode = :gui
|
|
|
|
# Assign this VM to a host-only network IP, allowing you to access it
|
|
# via the IP. Host-only networks can talk to the host machine as well as
|
|
# any other machines on the same network, but cannot be accessed (through this
|
|
# network interface) by any external networks.
|
|
# config.vm.network :hostonly, "192.168.33.10"
|
|
|
|
# Assign this VM to a bridged network, allowing you to connect directly to a
|
|
# network using the host's network device. This makes the VM appear as another
|
|
# physical device on your network.
|
|
# config.vm.network :bridged
|
|
|
|
# Forward a port from the guest to the host, which allows for outside
|
|
# computers to access the VM, whereas host only networking does not.
|
|
config.vm.forward_port 80, 8080
|
|
|
|
# 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"
|
|
# # }
|
|
|
|
# Share an additional folder to the guest VM. The first argument is
|
|
# an identifier, the second is the path on the guest to mount the
|
|
# folder, and the third is the path on the host to the actual folder.
|
|
# # config.vm.share_folder "v-icinga2-web-pub", "/var/www/html/icinga2-web", "./pub"
|
|
config.vm.share_folder "v-test", "/vagrant/config", "./config", :owner => 'vagrant', :group => 'apache', :extra => 'dmode=775,fmode=775'
|
|
config.vm.customize ["setextradata", :id, "VBoxInternal2/SharedFoldersEnableSymlinksCreate/v-test", "1"]
|
|
|
|
# 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 default.pp in the manifests_path directory.
|
|
config.vm.provision :puppet do |puppet|
|
|
puppet.module_path = ".vagrant-puppet/modules"
|
|
puppet.manifests_path = ".vagrant-puppet/manifests"
|
|
# # puppet.options = "-v -d"
|
|
end
|
|
|
|
# The npm module jquery won't install via puppet because of an mysterious error
|
|
# when node-gyp rebuilding the dependent contextify module
|
|
config.vm.provision :shell do |shell|
|
|
shell.inline = "[ -d /usr/lib/node_modules/jquery ] || npm install --silent -g jquery"
|
|
end
|
|
end
|