-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathVagrantfile
98 lines (83 loc) · 3.72 KB
/
Vagrantfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
# -*- mode: ruby -*-
# vi: set ft=ruby :
require 'yaml'
dir = File.dirname(File.expand_path(__FILE__))
configValues = YAML.load_file("#{dir}/vagrant/puppet/config/config.yaml")
data = configValues['vagrant']
mysqlData = configValues['mysql']
Vagrant.configure("2") do |config|
config.vm.box = "#{data['vm']['box']}"
config.vm.box_url = "#{data['vm']['box_url']}"
data['vm']['network']['forwarded_port'].each do |i, port|
if port['guest'] != '' && port['host'] != ''
config.vm.network :forwarded_port, guest: port['guest'].to_i, host: port['host'].to_i
end
end
# Create a private network, which allows host-only access to the machine
# using a specific IP.
if data['vm']['network']['private_network'].to_s != ''
config.vm.network :private_network, ip: "#{data['vm']['network']['private_network']}"
end
# Set Timezone
# if data['vm']['timezone'] != ''
# config.vm.provision :shell,
# :inline => "echo #{data['vm']['timezone']} | sudo tee /etc/timezone && sudo dpkg-reconfigure --frontend noninteractive tzdata"
# end
# 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.
data['vm']['synced_folder'].each do |i, folder|
if folder['source'] != '' && folder['target'] != ''
nfs = (folder['nfs'] == "true") ? "nfs" : nil
if nfs == "nfs"
config.vm.synced_folder "#{folder['source']}", "#{folder['target']}", id: "#{i}", type: nfs
else
config.vm.synced_folder "#{folder['source']}", "#{folder['target']}", id: "#{i}", type: nfs,
group: "#{folder['group']}", owner: "#{folder['owner']}", mount_options: ["dmode=755", "fmode=644"]
end
end
end
# 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|
vb.customize [
"modifyvm", :id,
"--memory", "#{data['vm']['memory']}",
"--cpus", "#{data['vm']['cpus']}",
"--ioapic", "on",
"--natdnshostresolver1", "on",
"--natdnsproxy1", "on"
]
end
config.vm.provision :puppet do |puppet|
puppet.manifests_path = "#{data['vm']['provision']['puppet']['manifests_path']}"
puppet.module_path = "#{data['vm']['provision']['puppet']['module_path']}"
puppet.manifest_file = "#{data['vm']['provision']['puppet']['manifest_file']}"
if !data['vm']['provision']['puppet']['options'].empty?
puppet.options = data['vm']['provision']['puppet']['options']
end
end
# Before halt and destroy, dump the database.
config.trigger.before [:halt, :destroy], :stdout => true do
info "DUMPING DATABASE"
db = mysqlData['database']
user = mysqlData['user']
password = mysqlData['password']
run "vagrant ssh -c 'if [ type mysql >/dev/null 2>&1 ]; then
mysqldump -u #{user} -p\'#{password}\' #{db} > /vagrant/db/#{db}.sql
fi'"
end
# After bringing the box up, import the database.
config.trigger.after :up, :stdout => true do
info "IMPORTING DATABASE"
db = mysqlData['database']
user = mysqlData['user']
password = mysqlData['password']
run "vagrant ssh -c 'if [ type mysql >/dev/null 2>&1 && -f /vagrant/db/#{db}.sql ]; then
mysql -u #{user} -p\'#{password}\' #{db} < /vagrant/db/#{db}.sql
fi'"
end
end