vagrant-lxc 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (473) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +29 -0
  3. data/.gitmodules +3 -0
  4. data/.rspec +2 -0
  5. data/.travis.yml +8 -0
  6. data/.vimrc +1 -0
  7. data/Gemfile +19 -0
  8. data/Gemfile.lock +89 -0
  9. data/Guardfile +34 -0
  10. data/LICENSE.txt +22 -0
  11. data/README.md +209 -0
  12. data/Rakefile +5 -0
  13. data/bin/vagrant-lxc +9 -0
  14. data/boxes/quantal64/download-ubuntu +103 -0
  15. data/boxes/quantal64/lxc-template +567 -0
  16. data/boxes/quantal64/metadata.json +9 -0
  17. data/development/Vagrantfile.1.0 +35 -0
  18. data/development/Vagrantfile.1.1 +55 -0
  19. data/development/lxc-configs/lxc-dev-box +37 -0
  20. data/development/lxc-configs/vbox +37 -0
  21. data/development/shell-provisioning/upgrade-kernel +14 -0
  22. data/development/site.pp +125 -0
  23. data/example/Vagrantfile +42 -0
  24. data/example/puppet/manifests/site.pp +5 -0
  25. data/example/puppet/modules/hello_world/manifests/init.pp +3 -0
  26. data/lib/vagrant-lxc.rb +6 -0
  27. data/lib/vagrant-lxc/action.rb +188 -0
  28. data/lib/vagrant-lxc/action/base_action.rb +11 -0
  29. data/lib/vagrant-lxc/action/boot.rb +55 -0
  30. data/lib/vagrant-lxc/action/check_created.rb +17 -0
  31. data/lib/vagrant-lxc/action/check_running.rb +17 -0
  32. data/lib/vagrant-lxc/action/create.rb +14 -0
  33. data/lib/vagrant-lxc/action/created.rb +16 -0
  34. data/lib/vagrant-lxc/action/destroy.rb +14 -0
  35. data/lib/vagrant-lxc/action/forced_halt.rb +22 -0
  36. data/lib/vagrant-lxc/action/handle_box_metadata.rb +47 -0
  37. data/lib/vagrant-lxc/action/is_running.rb +15 -0
  38. data/lib/vagrant-lxc/action/network.rb +21 -0
  39. data/lib/vagrant-lxc/action/share_folders.rb +65 -0
  40. data/lib/vagrant-lxc/config.rb +14 -0
  41. data/lib/vagrant-lxc/container.rb +170 -0
  42. data/lib/vagrant-lxc/container/cli.rb +124 -0
  43. data/lib/vagrant-lxc/errors.rb +12 -0
  44. data/lib/vagrant-lxc/machine_state.rb +25 -0
  45. data/lib/vagrant-lxc/plugin.rb +23 -0
  46. data/lib/vagrant-lxc/provider.rb +74 -0
  47. data/lib/vagrant-lxc/version.rb +5 -0
  48. data/lib/vendored_vagrant.rb +9 -0
  49. data/locales/en.yml +17 -0
  50. data/spec/fixtures/sample-arp-output +4 -0
  51. data/spec/fixtures/sample-config +47 -0
  52. data/spec/spec_helper.rb +32 -0
  53. data/spec/support/unit_example_group.rb +28 -0
  54. data/spec/unit/action/handle_box_metadata_spec.rb +44 -0
  55. data/spec/unit/container/cli_spec.rb +148 -0
  56. data/spec/unit/container_spec.rb +151 -0
  57. data/spec/unit/machine_state_spec.rb +39 -0
  58. data/spec/unit_helper.rb +9 -0
  59. data/tasks/boxes.rake +17 -0
  60. data/tasks/spec.rake +30 -0
  61. data/vagrant-lxc.gemspec +32 -0
  62. data/vendor/.gitkeep +0 -0
  63. data/vendor/vagrant/.gitignore +31 -0
  64. data/vendor/vagrant/.travis.yml +7 -0
  65. data/vendor/vagrant/.yardopts +1 -0
  66. data/vendor/vagrant/CHANGELOG.md +803 -0
  67. data/vendor/vagrant/Gemfile +3 -0
  68. data/vendor/vagrant/LICENSE +21 -0
  69. data/vendor/vagrant/README.md +89 -0
  70. data/vendor/vagrant/Rakefile +18 -0
  71. data/vendor/vagrant/bin/vagrant +84 -0
  72. data/vendor/vagrant/config/default.rb +35 -0
  73. data/vendor/vagrant/contrib/README.md +12 -0
  74. data/vendor/vagrant/contrib/bash/completion.sh +3 -0
  75. data/vendor/vagrant/contrib/emacs/vagrant.el +8 -0
  76. data/vendor/vagrant/contrib/vim/vagrantfile.vim +9 -0
  77. data/vendor/vagrant/keys/README.md +17 -0
  78. data/vendor/vagrant/keys/vagrant +27 -0
  79. data/vendor/vagrant/keys/vagrant.pub +1 -0
  80. data/vendor/vagrant/lib/vagrant.rb +251 -0
  81. data/vendor/vagrant/lib/vagrant/action.rb +42 -0
  82. data/vendor/vagrant/lib/vagrant/action/builder.rb +154 -0
  83. data/vendor/vagrant/lib/vagrant/action/builtin/box_add.rb +79 -0
  84. data/vendor/vagrant/lib/vagrant/action/builtin/call.rb +67 -0
  85. data/vendor/vagrant/lib/vagrant/action/builtin/config_validate.rb +30 -0
  86. data/vendor/vagrant/lib/vagrant/action/builtin/confirm.rb +38 -0
  87. data/vendor/vagrant/lib/vagrant/action/builtin/env_set.rb +24 -0
  88. data/vendor/vagrant/lib/vagrant/action/builtin/graceful_halt.rb +73 -0
  89. data/vendor/vagrant/lib/vagrant/action/builtin/handle_box_url.rb +43 -0
  90. data/vendor/vagrant/lib/vagrant/action/builtin/handle_forwarded_port_collisions.rb +117 -0
  91. data/vendor/vagrant/lib/vagrant/action/builtin/lock.rb +57 -0
  92. data/vendor/vagrant/lib/vagrant/action/builtin/nfs.rb +117 -0
  93. data/vendor/vagrant/lib/vagrant/action/builtin/provision.rb +70 -0
  94. data/vendor/vagrant/lib/vagrant/action/builtin/set_hostname.rb +27 -0
  95. data/vendor/vagrant/lib/vagrant/action/builtin/ssh_exec.rb +42 -0
  96. data/vendor/vagrant/lib/vagrant/action/builtin/ssh_run.rb +43 -0
  97. data/vendor/vagrant/lib/vagrant/action/general/package.rb +102 -0
  98. data/vendor/vagrant/lib/vagrant/action/hook.rb +103 -0
  99. data/vendor/vagrant/lib/vagrant/action/runner.rb +69 -0
  100. data/vendor/vagrant/lib/vagrant/action/warden.rb +103 -0
  101. data/vendor/vagrant/lib/vagrant/box.rb +93 -0
  102. data/vendor/vagrant/lib/vagrant/box_collection.rb +315 -0
  103. data/vendor/vagrant/lib/vagrant/cli.rb +82 -0
  104. data/vendor/vagrant/lib/vagrant/config.rb +63 -0
  105. data/vendor/vagrant/lib/vagrant/config/container.rb +37 -0
  106. data/vendor/vagrant/lib/vagrant/config/loader.rb +222 -0
  107. data/vendor/vagrant/lib/vagrant/config/v1.rb +9 -0
  108. data/vendor/vagrant/lib/vagrant/config/v1/dummy_config.rb +13 -0
  109. data/vendor/vagrant/lib/vagrant/config/v1/loader.rb +105 -0
  110. data/vendor/vagrant/lib/vagrant/config/v1/root.rb +60 -0
  111. data/vendor/vagrant/lib/vagrant/config/v2.rb +9 -0
  112. data/vendor/vagrant/lib/vagrant/config/v2/dummy_config.rb +13 -0
  113. data/vendor/vagrant/lib/vagrant/config/v2/loader.rb +141 -0
  114. data/vendor/vagrant/lib/vagrant/config/v2/root.rb +105 -0
  115. data/vendor/vagrant/lib/vagrant/config/v2/util.rb +21 -0
  116. data/vendor/vagrant/lib/vagrant/config/version_base.rb +80 -0
  117. data/vendor/vagrant/lib/vagrant/downloaders.rb +7 -0
  118. data/vendor/vagrant/lib/vagrant/downloaders/base.rb +22 -0
  119. data/vendor/vagrant/lib/vagrant/downloaders/file.rb +28 -0
  120. data/vendor/vagrant/lib/vagrant/downloaders/http.rb +116 -0
  121. data/vendor/vagrant/lib/vagrant/environment.rb +729 -0
  122. data/vendor/vagrant/lib/vagrant/errors.rb +486 -0
  123. data/vendor/vagrant/lib/vagrant/hosts.rb +28 -0
  124. data/vendor/vagrant/lib/vagrant/machine.rb +325 -0
  125. data/vendor/vagrant/lib/vagrant/machine_state.rb +45 -0
  126. data/vendor/vagrant/lib/vagrant/plugin.rb +6 -0
  127. data/vendor/vagrant/lib/vagrant/plugin/v1.rb +19 -0
  128. data/vendor/vagrant/lib/vagrant/plugin/v1/command.rb +169 -0
  129. data/vendor/vagrant/lib/vagrant/plugin/v1/communicator.rb +98 -0
  130. data/vendor/vagrant/lib/vagrant/plugin/v1/config.rb +112 -0
  131. data/vendor/vagrant/lib/vagrant/plugin/v1/errors.rb +15 -0
  132. data/vendor/vagrant/lib/vagrant/plugin/v1/guest.rb +92 -0
  133. data/vendor/vagrant/lib/vagrant/plugin/v1/host.rb +66 -0
  134. data/vendor/vagrant/lib/vagrant/plugin/v1/manager.rb +131 -0
  135. data/vendor/vagrant/lib/vagrant/plugin/v1/plugin.rb +229 -0
  136. data/vendor/vagrant/lib/vagrant/plugin/v1/provider.rb +68 -0
  137. data/vendor/vagrant/lib/vagrant/plugin/v1/provisioner.rb +50 -0
  138. data/vendor/vagrant/lib/vagrant/plugin/v2.rb +22 -0
  139. data/vendor/vagrant/lib/vagrant/plugin/v2/command.rb +234 -0
  140. data/vendor/vagrant/lib/vagrant/plugin/v2/communicator.rb +98 -0
  141. data/vendor/vagrant/lib/vagrant/plugin/v2/components.rb +29 -0
  142. data/vendor/vagrant/lib/vagrant/plugin/v2/config.rb +101 -0
  143. data/vendor/vagrant/lib/vagrant/plugin/v2/errors.rb +15 -0
  144. data/vendor/vagrant/lib/vagrant/plugin/v2/guest.rb +92 -0
  145. data/vendor/vagrant/lib/vagrant/plugin/v2/host.rb +66 -0
  146. data/vendor/vagrant/lib/vagrant/plugin/v2/manager.rb +158 -0
  147. data/vendor/vagrant/lib/vagrant/plugin/v2/plugin.rb +217 -0
  148. data/vendor/vagrant/lib/vagrant/plugin/v2/provider.rb +69 -0
  149. data/vendor/vagrant/lib/vagrant/plugin/v2/provisioner.rb +47 -0
  150. data/vendor/vagrant/lib/vagrant/registry.rb +78 -0
  151. data/vendor/vagrant/lib/vagrant/ssh.rb +132 -0
  152. data/vendor/vagrant/lib/vagrant/test_helpers.rb +154 -0
  153. data/vendor/vagrant/lib/vagrant/ui.rb +170 -0
  154. data/vendor/vagrant/lib/vagrant/util.rb +12 -0
  155. data/vendor/vagrant/lib/vagrant/util/ansi_escape_code_remover.rb +34 -0
  156. data/vendor/vagrant/lib/vagrant/util/busy.rb +59 -0
  157. data/vendor/vagrant/lib/vagrant/util/counter.rb +24 -0
  158. data/vendor/vagrant/lib/vagrant/util/file_checksum.rb +38 -0
  159. data/vendor/vagrant/lib/vagrant/util/file_mode.rb +12 -0
  160. data/vendor/vagrant/lib/vagrant/util/hash_with_indifferent_access.rb +63 -0
  161. data/vendor/vagrant/lib/vagrant/util/is_port_open.rb +38 -0
  162. data/vendor/vagrant/lib/vagrant/util/line_ending_helpers.rb +14 -0
  163. data/vendor/vagrant/lib/vagrant/util/network_ip.rb +28 -0
  164. data/vendor/vagrant/lib/vagrant/util/platform.rb +68 -0
  165. data/vendor/vagrant/lib/vagrant/util/retryable.rb +31 -0
  166. data/vendor/vagrant/lib/vagrant/util/safe_exec.rb +36 -0
  167. data/vendor/vagrant/lib/vagrant/util/safe_puts.rb +31 -0
  168. data/vendor/vagrant/lib/vagrant/util/scoped_hash_override.rb +45 -0
  169. data/vendor/vagrant/lib/vagrant/util/ssh.rb +126 -0
  170. data/vendor/vagrant/lib/vagrant/util/stacked_proc_runner.rb +35 -0
  171. data/vendor/vagrant/lib/vagrant/util/string_block_editor.rb +75 -0
  172. data/vendor/vagrant/lib/vagrant/util/subprocess.rb +270 -0
  173. data/vendor/vagrant/lib/vagrant/util/template_renderer.rb +83 -0
  174. data/vendor/vagrant/lib/vagrant/util/which.rb +43 -0
  175. data/vendor/vagrant/lib/vagrant/version.rb +6 -0
  176. data/vendor/vagrant/plugins/README.md +5 -0
  177. data/vendor/vagrant/plugins/commands/box/command/add.rb +52 -0
  178. data/vendor/vagrant/plugins/commands/box/command/list.rb +41 -0
  179. data/vendor/vagrant/plugins/commands/box/command/remove.rb +37 -0
  180. data/vendor/vagrant/plugins/commands/box/command/repackage.rb +43 -0
  181. data/vendor/vagrant/plugins/commands/box/command/root.rb +75 -0
  182. data/vendor/vagrant/plugins/commands/box/plugin.rb +15 -0
  183. data/vendor/vagrant/plugins/commands/destroy/command.rb +31 -0
  184. data/vendor/vagrant/plugins/commands/destroy/plugin.rb +18 -0
  185. data/vendor/vagrant/plugins/commands/halt/command.rb +33 -0
  186. data/vendor/vagrant/plugins/commands/halt/plugin.rb +18 -0
  187. data/vendor/vagrant/plugins/commands/init/command.rb +40 -0
  188. data/vendor/vagrant/plugins/commands/init/plugin.rb +18 -0
  189. data/vendor/vagrant/plugins/commands/package/command.rb +78 -0
  190. data/vendor/vagrant/plugins/commands/package/plugin.rb +18 -0
  191. data/vendor/vagrant/plugins/commands/plugin/action.rb +52 -0
  192. data/vendor/vagrant/plugins/commands/plugin/action/bundler_check.rb +25 -0
  193. data/vendor/vagrant/plugins/commands/plugin/action/install_gem.rb +70 -0
  194. data/vendor/vagrant/plugins/commands/plugin/action/license_plugin.rb +54 -0
  195. data/vendor/vagrant/plugins/commands/plugin/action/list_plugins.rb +54 -0
  196. data/vendor/vagrant/plugins/commands/plugin/action/prune_gems.rb +149 -0
  197. data/vendor/vagrant/plugins/commands/plugin/action/uninstall_plugin.rb +23 -0
  198. data/vendor/vagrant/plugins/commands/plugin/command/base.rb +22 -0
  199. data/vendor/vagrant/plugins/commands/plugin/command/install.rb +39 -0
  200. data/vendor/vagrant/plugins/commands/plugin/command/license.rb +31 -0
  201. data/vendor/vagrant/plugins/commands/plugin/command/list.rb +28 -0
  202. data/vendor/vagrant/plugins/commands/plugin/command/root.rb +75 -0
  203. data/vendor/vagrant/plugins/commands/plugin/command/uninstall.rb +28 -0
  204. data/vendor/vagrant/plugins/commands/plugin/gem_helper.rb +74 -0
  205. data/vendor/vagrant/plugins/commands/plugin/plugin.rb +22 -0
  206. data/vendor/vagrant/plugins/commands/plugin/state_file.rb +57 -0
  207. data/vendor/vagrant/plugins/commands/provision/command.rb +34 -0
  208. data/vendor/vagrant/plugins/commands/provision/plugin.rb +18 -0
  209. data/vendor/vagrant/plugins/commands/reload/command.rb +37 -0
  210. data/vendor/vagrant/plugins/commands/reload/plugin.rb +18 -0
  211. data/vendor/vagrant/plugins/commands/resume/command.rb +25 -0
  212. data/vendor/vagrant/plugins/commands/resume/plugin.rb +17 -0
  213. data/vendor/vagrant/plugins/commands/ssh/command.rb +66 -0
  214. data/vendor/vagrant/plugins/commands/ssh/plugin.rb +17 -0
  215. data/vendor/vagrant/plugins/commands/ssh_config/command.rb +49 -0
  216. data/vendor/vagrant/plugins/commands/ssh_config/plugin.rb +18 -0
  217. data/vendor/vagrant/plugins/commands/status/command.rb +39 -0
  218. data/vendor/vagrant/plugins/commands/status/plugin.rb +18 -0
  219. data/vendor/vagrant/plugins/commands/suspend/command.rb +25 -0
  220. data/vendor/vagrant/plugins/commands/suspend/plugin.rb +18 -0
  221. data/vendor/vagrant/plugins/commands/up/command.rb +45 -0
  222. data/vendor/vagrant/plugins/commands/up/plugin.rb +17 -0
  223. data/vendor/vagrant/plugins/commands/up/start_mixins.rb +26 -0
  224. data/vendor/vagrant/plugins/communicators/ssh/communicator.rb +317 -0
  225. data/vendor/vagrant/plugins/communicators/ssh/plugin.rb +19 -0
  226. data/vendor/vagrant/plugins/guests/arch/guest.rb +41 -0
  227. data/vendor/vagrant/plugins/guests/arch/plugin.rb +15 -0
  228. data/vendor/vagrant/plugins/guests/debian/guest.rb +72 -0
  229. data/vendor/vagrant/plugins/guests/debian/plugin.rb +15 -0
  230. data/vendor/vagrant/plugins/guests/fedora/guest.rb +71 -0
  231. data/vendor/vagrant/plugins/guests/fedora/plugin.rb +15 -0
  232. data/vendor/vagrant/plugins/guests/freebsd/config.rb +13 -0
  233. data/vendor/vagrant/plugins/guests/freebsd/guest.rb +70 -0
  234. data/vendor/vagrant/plugins/guests/freebsd/plugin.rb +20 -0
  235. data/vendor/vagrant/plugins/guests/gentoo/guest.rb +51 -0
  236. data/vendor/vagrant/plugins/guests/gentoo/plugin.rb +15 -0
  237. data/vendor/vagrant/plugins/guests/linux/config.rb +13 -0
  238. data/vendor/vagrant/plugins/guests/linux/guest.rb +118 -0
  239. data/vendor/vagrant/plugins/guests/linux/plugin.rb +20 -0
  240. data/vendor/vagrant/plugins/guests/openbsd/guest.rb +13 -0
  241. data/vendor/vagrant/plugins/guests/openbsd/plugin.rb +15 -0
  242. data/vendor/vagrant/plugins/guests/redhat/guest.rb +74 -0
  243. data/vendor/vagrant/plugins/guests/redhat/plugin.rb +15 -0
  244. data/vendor/vagrant/plugins/guests/solaris/config.rb +18 -0
  245. data/vendor/vagrant/plugins/guests/solaris/guest.rb +73 -0
  246. data/vendor/vagrant/plugins/guests/solaris/plugin.rb +20 -0
  247. data/vendor/vagrant/plugins/guests/suse/guest.rb +24 -0
  248. data/vendor/vagrant/plugins/guests/suse/plugin.rb +15 -0
  249. data/vendor/vagrant/plugins/guests/ubuntu/guest.rb +44 -0
  250. data/vendor/vagrant/plugins/guests/ubuntu/plugin.rb +15 -0
  251. data/vendor/vagrant/plugins/hosts/arch/host.rb +68 -0
  252. data/vendor/vagrant/plugins/hosts/arch/plugin.rb +15 -0
  253. data/vendor/vagrant/plugins/hosts/bsd/host.rb +102 -0
  254. data/vendor/vagrant/plugins/hosts/bsd/plugin.rb +15 -0
  255. data/vendor/vagrant/plugins/hosts/fedora/host.rb +51 -0
  256. data/vendor/vagrant/plugins/hosts/fedora/plugin.rb +15 -0
  257. data/vendor/vagrant/plugins/hosts/freebsd/host.rb +43 -0
  258. data/vendor/vagrant/plugins/hosts/freebsd/plugin.rb +15 -0
  259. data/vendor/vagrant/plugins/hosts/gentoo/host.rb +24 -0
  260. data/vendor/vagrant/plugins/hosts/gentoo/plugin.rb +15 -0
  261. data/vendor/vagrant/plugins/hosts/linux/host.rb +95 -0
  262. data/vendor/vagrant/plugins/hosts/linux/plugin.rb +15 -0
  263. data/vendor/vagrant/plugins/hosts/opensuse/host.rb +34 -0
  264. data/vendor/vagrant/plugins/hosts/opensuse/plugin.rb +15 -0
  265. data/vendor/vagrant/plugins/hosts/windows/host.rb +17 -0
  266. data/vendor/vagrant/plugins/hosts/windows/plugin.rb +15 -0
  267. data/vendor/vagrant/plugins/kernel_v1/config/nfs.rb +20 -0
  268. data/vendor/vagrant/plugins/kernel_v1/config/package.rb +17 -0
  269. data/vendor/vagrant/plugins/kernel_v1/config/ssh.rb +46 -0
  270. data/vendor/vagrant/plugins/kernel_v1/config/vagrant.rb +31 -0
  271. data/vendor/vagrant/plugins/kernel_v1/config/vm.rb +184 -0
  272. data/vendor/vagrant/plugins/kernel_v1/plugin.rb +44 -0
  273. data/vendor/vagrant/plugins/kernel_v2/config/nfs.rb +10 -0
  274. data/vendor/vagrant/plugins/kernel_v2/config/package.rb +9 -0
  275. data/vendor/vagrant/plugins/kernel_v2/config/ssh.rb +35 -0
  276. data/vendor/vagrant/plugins/kernel_v2/config/vagrant.rb +9 -0
  277. data/vendor/vagrant/plugins/kernel_v2/config/vm.rb +314 -0
  278. data/vendor/vagrant/plugins/kernel_v2/config/vm_provisioner.rb +40 -0
  279. data/vendor/vagrant/plugins/kernel_v2/config/vm_subvm.rb +30 -0
  280. data/vendor/vagrant/plugins/kernel_v2/plugin.rb +44 -0
  281. data/vendor/vagrant/plugins/providers/virtualbox/action.rb +308 -0
  282. data/vendor/vagrant/plugins/providers/virtualbox/action/boot.rb +49 -0
  283. data/vendor/vagrant/plugins/providers/virtualbox/action/check_accessible.rb +23 -0
  284. data/vendor/vagrant/plugins/providers/virtualbox/action/check_created.rb +21 -0
  285. data/vendor/vagrant/plugins/providers/virtualbox/action/check_guest_additions.rb +45 -0
  286. data/vendor/vagrant/plugins/providers/virtualbox/action/check_running.rb +21 -0
  287. data/vendor/vagrant/plugins/providers/virtualbox/action/check_virtualbox.rb +22 -0
  288. data/vendor/vagrant/plugins/providers/virtualbox/action/clean_machine_folder.rb +43 -0
  289. data/vendor/vagrant/plugins/providers/virtualbox/action/clear_forwarded_ports.rb +18 -0
  290. data/vendor/vagrant/plugins/providers/virtualbox/action/clear_network_interfaces.rb +31 -0
  291. data/vendor/vagrant/plugins/providers/virtualbox/action/clear_shared_folders.rb +17 -0
  292. data/vendor/vagrant/plugins/providers/virtualbox/action/created.rb +20 -0
  293. data/vendor/vagrant/plugins/providers/virtualbox/action/customize.rb +36 -0
  294. data/vendor/vagrant/plugins/providers/virtualbox/action/destroy.rb +19 -0
  295. data/vendor/vagrant/plugins/providers/virtualbox/action/destroy_confirm.rb +17 -0
  296. data/vendor/vagrant/plugins/providers/virtualbox/action/destroy_unused_network_interfaces.rb +16 -0
  297. data/vendor/vagrant/plugins/providers/virtualbox/action/discard_state.rb +20 -0
  298. data/vendor/vagrant/plugins/providers/virtualbox/action/export.rb +57 -0
  299. data/vendor/vagrant/plugins/providers/virtualbox/action/forced_halt.rb +25 -0
  300. data/vendor/vagrant/plugins/providers/virtualbox/action/forward_ports.rb +79 -0
  301. data/vendor/vagrant/plugins/providers/virtualbox/action/import.rb +51 -0
  302. data/vendor/vagrant/plugins/providers/virtualbox/action/is_paused.rb +20 -0
  303. data/vendor/vagrant/plugins/providers/virtualbox/action/is_running.rb +20 -0
  304. data/vendor/vagrant/plugins/providers/virtualbox/action/is_saved.rb +20 -0
  305. data/vendor/vagrant/plugins/providers/virtualbox/action/match_mac_address.rb +21 -0
  306. data/vendor/vagrant/plugins/providers/virtualbox/action/message_not_created.rb +16 -0
  307. data/vendor/vagrant/plugins/providers/virtualbox/action/message_not_running.rb +16 -0
  308. data/vendor/vagrant/plugins/providers/virtualbox/action/message_will_not_destroy.rb +17 -0
  309. data/vendor/vagrant/plugins/providers/virtualbox/action/network.rb +366 -0
  310. data/vendor/vagrant/plugins/providers/virtualbox/action/package.rb +20 -0
  311. data/vendor/vagrant/plugins/providers/virtualbox/action/package_vagrantfile.rb +33 -0
  312. data/vendor/vagrant/plugins/providers/virtualbox/action/prepare_forwarded_port_collision_params.rb +35 -0
  313. data/vendor/vagrant/plugins/providers/virtualbox/action/prepare_nfs_settings.rb +51 -0
  314. data/vendor/vagrant/plugins/providers/virtualbox/action/prune_nfs_exports.rb +20 -0
  315. data/vendor/vagrant/plugins/providers/virtualbox/action/resume.rb +25 -0
  316. data/vendor/vagrant/plugins/providers/virtualbox/action/sane_defaults.rb +87 -0
  317. data/vendor/vagrant/plugins/providers/virtualbox/action/set_name.rb +40 -0
  318. data/vendor/vagrant/plugins/providers/virtualbox/action/setup_package_files.rb +51 -0
  319. data/vendor/vagrant/plugins/providers/virtualbox/action/share_folders.rb +113 -0
  320. data/vendor/vagrant/plugins/providers/virtualbox/action/suspend.rb +20 -0
  321. data/vendor/vagrant/plugins/providers/virtualbox/config.rb +82 -0
  322. data/vendor/vagrant/plugins/providers/virtualbox/driver/base.rb +344 -0
  323. data/vendor/vagrant/plugins/providers/virtualbox/driver/meta.rb +141 -0
  324. data/vendor/vagrant/plugins/providers/virtualbox/driver/version_4_0.rb +481 -0
  325. data/vendor/vagrant/plugins/providers/virtualbox/driver/version_4_1.rb +481 -0
  326. data/vendor/vagrant/plugins/providers/virtualbox/driver/version_4_2.rb +471 -0
  327. data/vendor/vagrant/plugins/providers/virtualbox/model/forwarded_port.rb +58 -0
  328. data/vendor/vagrant/plugins/providers/virtualbox/plugin.rb +42 -0
  329. data/vendor/vagrant/plugins/providers/virtualbox/provider.rb +92 -0
  330. data/vendor/vagrant/plugins/providers/virtualbox/util/compile_forwarded_ports.rb +31 -0
  331. data/vendor/vagrant/plugins/provisioners/chef/config/base.rb +65 -0
  332. data/vendor/vagrant/plugins/provisioners/chef/config/chef_client.rb +39 -0
  333. data/vendor/vagrant/plugins/provisioners/chef/config/chef_solo.rb +87 -0
  334. data/vendor/vagrant/plugins/provisioners/chef/plugin.rb +33 -0
  335. data/vendor/vagrant/plugins/provisioners/chef/provisioner/base.rb +91 -0
  336. data/vendor/vagrant/plugins/provisioners/chef/provisioner/chef_client.rb +103 -0
  337. data/vendor/vagrant/plugins/provisioners/chef/provisioner/chef_solo.rb +182 -0
  338. data/vendor/vagrant/plugins/provisioners/puppet/config/puppet.rb +70 -0
  339. data/vendor/vagrant/plugins/provisioners/puppet/config/puppet_server.rb +16 -0
  340. data/vendor/vagrant/plugins/provisioners/puppet/plugin.rb +33 -0
  341. data/vendor/vagrant/plugins/provisioners/puppet/provisioner/puppet.rb +110 -0
  342. data/vendor/vagrant/plugins/provisioners/puppet/provisioner/puppet_server.rb +67 -0
  343. data/vendor/vagrant/plugins/provisioners/shell/config.rb +46 -0
  344. data/vendor/vagrant/plugins/provisioners/shell/plugin.rb +23 -0
  345. data/vendor/vagrant/plugins/provisioners/shell/provisioner.rb +66 -0
  346. data/vendor/vagrant/tasks/acceptance.rake +113 -0
  347. data/vendor/vagrant/tasks/bundler.rake +3 -0
  348. data/vendor/vagrant/tasks/test.rake +20 -0
  349. data/vendor/vagrant/templates/commands/init/Vagrantfile.erb +111 -0
  350. data/vendor/vagrant/templates/commands/ssh_config/config.erb +16 -0
  351. data/vendor/vagrant/templates/config/messages.erb +14 -0
  352. data/vendor/vagrant/templates/config/validation_failed.erb +7 -0
  353. data/vendor/vagrant/templates/guests/arch/network_dhcp.erb +4 -0
  354. data/vendor/vagrant/templates/guests/arch/network_static.erb +6 -0
  355. data/vendor/vagrant/templates/guests/debian/network_dhcp.erb +11 -0
  356. data/vendor/vagrant/templates/guests/debian/network_static.erb +7 -0
  357. data/vendor/vagrant/templates/guests/fedora/network_dhcp.erb +6 -0
  358. data/vendor/vagrant/templates/guests/fedora/network_static.erb +13 -0
  359. data/vendor/vagrant/templates/guests/freebsd/network_dhcp.erb +3 -0
  360. data/vendor/vagrant/templates/guests/freebsd/network_static.erb +3 -0
  361. data/vendor/vagrant/templates/guests/gentoo/network_dhcp.erb +4 -0
  362. data/vendor/vagrant/templates/guests/gentoo/network_static.erb +4 -0
  363. data/vendor/vagrant/templates/guests/redhat/network_dhcp.erb +6 -0
  364. data/vendor/vagrant/templates/guests/redhat/network_static.erb +7 -0
  365. data/vendor/vagrant/templates/locales/en.yml +993 -0
  366. data/vendor/vagrant/templates/nfs/exports.erb +5 -0
  367. data/vendor/vagrant/templates/nfs/exports_freebsd.erb +5 -0
  368. data/vendor/vagrant/templates/nfs/exports_linux.erb +5 -0
  369. data/vendor/vagrant/templates/package_Vagrantfile.erb +11 -0
  370. data/vendor/vagrant/templates/provisioners/chef_client/client.erb +32 -0
  371. data/vendor/vagrant/templates/provisioners/chef_solo/solo.erb +25 -0
  372. data/vendor/vagrant/templates/rgloader.rb +9 -0
  373. data/vendor/vagrant/test/acceptance/base.rb +48 -0
  374. data/vendor/vagrant/test/acceptance/box_test.rb +99 -0
  375. data/vendor/vagrant/test/acceptance/destroy_test.rb +37 -0
  376. data/vendor/vagrant/test/acceptance/halt_test.rb +72 -0
  377. data/vendor/vagrant/test/acceptance/init_test.rb +33 -0
  378. data/vendor/vagrant/test/acceptance/networking/host_only_test.rb +37 -0
  379. data/vendor/vagrant/test/acceptance/networking/port_forward_test.rb +125 -0
  380. data/vendor/vagrant/test/acceptance/package_test.rb +46 -0
  381. data/vendor/vagrant/test/acceptance/provisioning/basic_test.rb +61 -0
  382. data/vendor/vagrant/test/acceptance/provisioning/chef_solo_test.rb +37 -0
  383. data/vendor/vagrant/test/acceptance/provisioning/shell_test.rb +53 -0
  384. data/vendor/vagrant/test/acceptance/resume_test.rb +17 -0
  385. data/vendor/vagrant/test/acceptance/shared_folders_test.rb +84 -0
  386. data/vendor/vagrant/test/acceptance/skeletons/chef_solo_basic/README.md +3 -0
  387. data/vendor/vagrant/test/acceptance/skeletons/chef_solo_basic/cookbooks/basic/recipes/default.rb +5 -0
  388. data/vendor/vagrant/test/acceptance/skeletons/chef_solo_json/README.md +3 -0
  389. data/vendor/vagrant/test/acceptance/skeletons/chef_solo_json/cookbooks/basic/recipes/default.rb +6 -0
  390. data/vendor/vagrant/test/acceptance/skeletons/provisioner_multi/README.md +3 -0
  391. data/vendor/vagrant/test/acceptance/skeletons/provisioner_multi/cookbooks/basic/recipes/default.rb +5 -0
  392. data/vendor/vagrant/test/acceptance/ssh_test.rb +46 -0
  393. data/vendor/vagrant/test/acceptance/support/config.rb +42 -0
  394. data/vendor/vagrant/test/acceptance/support/isolated_environment.rb +118 -0
  395. data/vendor/vagrant/test/acceptance/support/matchers/have_color.rb +9 -0
  396. data/vendor/vagrant/test/acceptance/support/matchers/match_output.rb +14 -0
  397. data/vendor/vagrant/test/acceptance/support/matchers/succeed.rb +14 -0
  398. data/vendor/vagrant/test/acceptance/support/network_tests.rb +29 -0
  399. data/vendor/vagrant/test/acceptance/support/output.rb +95 -0
  400. data/vendor/vagrant/test/acceptance/support/shared/base_context.rb +72 -0
  401. data/vendor/vagrant/test/acceptance/support/shared/command_examples.rb +33 -0
  402. data/vendor/vagrant/test/acceptance/support/virtualbox.rb +36 -0
  403. data/vendor/vagrant/test/acceptance/suspend_test.rb +56 -0
  404. data/vendor/vagrant/test/acceptance/up_basic_test.rb +33 -0
  405. data/vendor/vagrant/test/acceptance/up_with_box_url.rb +40 -0
  406. data/vendor/vagrant/test/acceptance/vagrant_test.rb +47 -0
  407. data/vendor/vagrant/test/acceptance/version_test.rb +15 -0
  408. data/vendor/vagrant/test/config/acceptance_boxes.yml +7 -0
  409. data/vendor/vagrant/test/support/isolated_environment.rb +46 -0
  410. data/vendor/vagrant/test/support/tempdir.rb +43 -0
  411. data/vendor/vagrant/test/unit/base.rb +27 -0
  412. data/vendor/vagrant/test/unit/support/dummy_provider.rb +16 -0
  413. data/vendor/vagrant/test/unit/support/isolated_environment.rb +177 -0
  414. data/vendor/vagrant/test/unit/support/shared/base_context.rb +104 -0
  415. data/vendor/vagrant/test/unit/vagrant/action/builder_test.rb +196 -0
  416. data/vendor/vagrant/test/unit/vagrant/action/builtin/call_test.rb +145 -0
  417. data/vendor/vagrant/test/unit/vagrant/action/builtin/confirm_test.rb +36 -0
  418. data/vendor/vagrant/test/unit/vagrant/action/builtin/env_set_test.rb +20 -0
  419. data/vendor/vagrant/test/unit/vagrant/action/builtin/graceful_halt_test.rb +61 -0
  420. data/vendor/vagrant/test/unit/vagrant/action/builtin/lock_test.rb +98 -0
  421. data/vendor/vagrant/test/unit/vagrant/action/builtin/ssh_exec_test.rb +57 -0
  422. data/vendor/vagrant/test/unit/vagrant/action/hook_test.rb +101 -0
  423. data/vendor/vagrant/test/unit/vagrant/action/runner_test.rb +71 -0
  424. data/vendor/vagrant/test/unit/vagrant/action/warden_test.rb +92 -0
  425. data/vendor/vagrant/test/unit/vagrant/box_collection_test.rb +224 -0
  426. data/vendor/vagrant/test/unit/vagrant/box_test.rb +109 -0
  427. data/vendor/vagrant/test/unit/vagrant/cli_test.rb +27 -0
  428. data/vendor/vagrant/test/unit/vagrant/config/loader_test.rb +184 -0
  429. data/vendor/vagrant/test/unit/vagrant/config/v1/dummy_config_test.rb +24 -0
  430. data/vendor/vagrant/test/unit/vagrant/config/v1/loader_test.rb +145 -0
  431. data/vendor/vagrant/test/unit/vagrant/config/v1/root_test.rb +40 -0
  432. data/vendor/vagrant/test/unit/vagrant/config/v2/dummy_config_test.rb +24 -0
  433. data/vendor/vagrant/test/unit/vagrant/config/v2/loader_test.rb +151 -0
  434. data/vendor/vagrant/test/unit/vagrant/config/v2/root_test.rb +97 -0
  435. data/vendor/vagrant/test/unit/vagrant/config/v2/util_test.rb +21 -0
  436. data/vendor/vagrant/test/unit/vagrant/config_test.rb +66 -0
  437. data/vendor/vagrant/test/unit/vagrant/downloaders/base_test.rb +14 -0
  438. data/vendor/vagrant/test/unit/vagrant/downloaders/file_test.rb +87 -0
  439. data/vendor/vagrant/test/unit/vagrant/downloaders/http_test.rb +23 -0
  440. data/vendor/vagrant/test/unit/vagrant/environment_test.rb +571 -0
  441. data/vendor/vagrant/test/unit/vagrant/hosts_test.rb +37 -0
  442. data/vendor/vagrant/test/unit/vagrant/machine_state_test.rb +26 -0
  443. data/vendor/vagrant/test/unit/vagrant/machine_test.rb +418 -0
  444. data/vendor/vagrant/test/unit/vagrant/plugin/v1/command_test.rb +143 -0
  445. data/vendor/vagrant/test/unit/vagrant/plugin/v1/communicator_test.rb +9 -0
  446. data/vendor/vagrant/test/unit/vagrant/plugin/v1/config_test.rb +50 -0
  447. data/vendor/vagrant/test/unit/vagrant/plugin/v1/host_test.rb +5 -0
  448. data/vendor/vagrant/test/unit/vagrant/plugin/v1/manager_test.rb +114 -0
  449. data/vendor/vagrant/test/unit/vagrant/plugin/v1/plugin_test.rb +267 -0
  450. data/vendor/vagrant/test/unit/vagrant/plugin/v1/provider_test.rb +18 -0
  451. data/vendor/vagrant/test/unit/vagrant/plugin/v2/command_test.rb +238 -0
  452. data/vendor/vagrant/test/unit/vagrant/plugin/v2/communicator_test.rb +9 -0
  453. data/vendor/vagrant/test/unit/vagrant/plugin/v2/components_test.rb +17 -0
  454. data/vendor/vagrant/test/unit/vagrant/plugin/v2/config_test.rb +60 -0
  455. data/vendor/vagrant/test/unit/vagrant/plugin/v2/host_test.rb +5 -0
  456. data/vendor/vagrant/test/unit/vagrant/plugin/v2/manager_test.rb +157 -0
  457. data/vendor/vagrant/test/unit/vagrant/plugin/v2/plugin_test.rb +287 -0
  458. data/vendor/vagrant/test/unit/vagrant/plugin/v2/provider_test.rb +18 -0
  459. data/vendor/vagrant/test/unit/vagrant/registry_test.rb +128 -0
  460. data/vendor/vagrant/test/unit/vagrant/util/ansi_escape_code_remover_test.rb +16 -0
  461. data/vendor/vagrant/test/unit/vagrant/util/file_checksum_test.rb +23 -0
  462. data/vendor/vagrant/test/unit/vagrant/util/hash_with_indifferent_access_test.rb +38 -0
  463. data/vendor/vagrant/test/unit/vagrant/util/is_port_open_test.rb +53 -0
  464. data/vendor/vagrant/test/unit/vagrant/util/line_endings_helper_test.rb +16 -0
  465. data/vendor/vagrant/test/unit/vagrant/util/network_ip_test.rb +17 -0
  466. data/vendor/vagrant/test/unit/vagrant/util/retryable_test.rb +106 -0
  467. data/vendor/vagrant/test/unit/vagrant/util/scoped_hash_override_test.rb +48 -0
  468. data/vendor/vagrant/test/unit/vagrant/util/ssh_test.rb +30 -0
  469. data/vendor/vagrant/test/unit/vagrant/util/string_block_editor_test.rb +98 -0
  470. data/vendor/vagrant/test/unit/vagrant/util/which_test.rb +43 -0
  471. data/vendor/vagrant/test/unit/vagrant_test.rb +56 -0
  472. data/vendor/vagrant/vagrant.gemspec +69 -0
  473. metadata +642 -0
@@ -0,0 +1,729 @@
1
+ require 'fileutils'
2
+ require 'json'
3
+ require 'pathname'
4
+ require 'set'
5
+
6
+ require 'log4r'
7
+
8
+ require 'vagrant/util/file_mode'
9
+ require 'vagrant/util/platform'
10
+
11
+ module Vagrant
12
+ # Represents a single Vagrant environment. A "Vagrant environment" is
13
+ # defined as basically a folder with a "Vagrantfile." This class allows
14
+ # access to the VMs, CLI, etc. all in the scope of this environment.
15
+ class Environment
16
+ DEFAULT_HOME = "~/.vagrant.d"
17
+ DEFAULT_LOCAL_DATA = ".vagrant"
18
+
19
+ # The `cwd` that this environment represents
20
+ attr_reader :cwd
21
+
22
+ # The persistent data directory where global data can be stored. It
23
+ # is up to the creator of the data in this directory to properly
24
+ # remove it when it is no longer needed.
25
+ #
26
+ # @return [Pathname]
27
+ attr_reader :data_dir
28
+
29
+ # The valid name for a Vagrantfile for this environment.
30
+ attr_reader :vagrantfile_name
31
+
32
+ # The {UI} object to communicate with the outside world.
33
+ attr_reader :ui
34
+
35
+ # This is the UI class to use when creating new UIs.
36
+ attr_reader :ui_class
37
+
38
+ # The directory to the "home" folder that Vagrant will use to store
39
+ # global state.
40
+ attr_reader :home_path
41
+
42
+ # The directory to the directory where local, environment-specific
43
+ # data is stored.
44
+ attr_reader :local_data_path
45
+
46
+ # The directory where temporary files for Vagrant go.
47
+ attr_reader :tmp_path
48
+
49
+ # The directory where boxes are stored.
50
+ attr_reader :boxes_path
51
+
52
+ # The path where the plugins are stored (gems)
53
+ attr_reader :gems_path
54
+
55
+ # The path to the default private key
56
+ attr_reader :default_private_key_path
57
+
58
+ # Initializes a new environment with the given options. The options
59
+ # is a hash where the main available key is `cwd`, which defines where
60
+ # the environment represents. There are other options available but
61
+ # they shouldn't be used in general. If `cwd` is nil, then it defaults
62
+ # to the `Dir.pwd` (which is the cwd of the executing process).
63
+ def initialize(opts=nil)
64
+ opts = {
65
+ :cwd => nil,
66
+ :home_path => nil,
67
+ :local_data_path => nil,
68
+ :lock_path => nil,
69
+ :ui_class => nil,
70
+ :vagrantfile_name => nil
71
+ }.merge(opts || {})
72
+
73
+ # Set the default working directory to look for the vagrantfile
74
+ opts[:cwd] ||= ENV["VAGRANT_CWD"] if ENV.has_key?("VAGRANT_CWD")
75
+ opts[:cwd] ||= Dir.pwd
76
+ opts[:cwd] = Pathname.new(opts[:cwd])
77
+ raise Errors::EnvironmentNonExistentCWD if !opts[:cwd].directory?
78
+
79
+ # Set the default ui class
80
+ opts[:ui_class] ||= UI::Silent
81
+
82
+ # Set the Vagrantfile name up. We append "Vagrantfile" and "vagrantfile" so that
83
+ # those continue to work as well, but anything custom will take precedence.
84
+ opts[:vagrantfile_name] ||= ENV["VAGRANT_VAGRANTFILE"] if \
85
+ ENV.has_key?("VAGRANT_VAGRANTFILE")
86
+ opts[:vagrantfile_name] ||= ["Vagrantfile", "vagrantfile"]
87
+ opts[:vagrantfile_name] = [opts[:vagrantfile_name]] if \
88
+ !opts[:vagrantfile_name].is_a?(Array)
89
+
90
+ # Set instance variables for all the configuration parameters.
91
+ @cwd = opts[:cwd]
92
+ @home_path = opts[:home_path]
93
+ @lock_path = opts[:lock_path]
94
+ @vagrantfile_name = opts[:vagrantfile_name]
95
+ @ui = opts[:ui_class].new
96
+ @ui_class = opts[:ui_class]
97
+
98
+ @lock_acquired = false
99
+
100
+ @logger = Log4r::Logger.new("vagrant::environment")
101
+ @logger.info("Environment initialized (#{self})")
102
+ @logger.info(" - cwd: #{cwd}")
103
+
104
+ # Setup the home directory
105
+ setup_home_path
106
+ @boxes_path = @home_path.join("boxes")
107
+ @data_dir = @home_path.join("data")
108
+ @gems_path = @home_path.join("gems")
109
+ @tmp_path = @home_path.join("tmp")
110
+
111
+ # Setup the local data directory. If a configuration path is given,
112
+ # then it is expanded relative to the working directory. Otherwise,
113
+ # we use the default which is expanded relative to the root path.
114
+ @local_data_path = nil
115
+ if opts[:local_data_path]
116
+ @local_data_path = Pathname.new(File.expand_path(opts[:local_data_path], @cwd))
117
+ elsif !root_path.nil?
118
+ @local_data_path = root_path.join(DEFAULT_LOCAL_DATA)
119
+ end
120
+
121
+ setup_local_data_path
122
+
123
+ # Setup the default private key
124
+ @default_private_key_path = @home_path.join("insecure_private_key")
125
+ copy_insecure_private_key
126
+
127
+ # Load the plugins
128
+ load_plugins
129
+
130
+ # Call the environment load hooks
131
+ hook(:environment_load)
132
+ end
133
+
134
+ # Return a human-friendly string for pretty printed or inspected
135
+ # instances.
136
+ #
137
+ # @return [String]
138
+ def inspect
139
+ "#<#{self.class}: #{@cwd}>"
140
+ end
141
+
142
+ #---------------------------------------------------------------
143
+ # Helpers
144
+ #---------------------------------------------------------------
145
+
146
+ # Returns a list of machines that this environment is currently
147
+ # managing that physically have been created.
148
+ #
149
+ # An "active" machine is a machine that Vagrant manages that has
150
+ # been created. The machine itself may be in any state such as running,
151
+ # suspended, etc. but if a machine is "active" then it exists.
152
+ #
153
+ # Note that the machines in this array may no longer be present in
154
+ # the Vagrantfile of this environment. In this case the machine can
155
+ # be considered an "orphan." Determining which machines are orphan
156
+ # and which aren't is not currently a supported feature, but will
157
+ # be in a future version.
158
+ #
159
+ # @return [Array<String, Symbol>]
160
+ def active_machines
161
+ machine_folder = @local_data_path.join("machines")
162
+
163
+ # If the machine folder is not a directory then we just return
164
+ # an empty array since no active machines exist.
165
+ return [] if !machine_folder.directory?
166
+
167
+ # Traverse the machines folder accumulate a result
168
+ result = []
169
+
170
+ machine_folder.children(true).each do |name_folder|
171
+ # If this isn't a directory then it isn't a machine
172
+ next if !name_folder.directory?
173
+
174
+ name = name_folder.basename.to_s.to_sym
175
+ name_folder.children(true).each do |provider_folder|
176
+ # If this isn't a directory then it isn't a provider
177
+ next if !provider_folder.directory?
178
+
179
+ # If this machine doesn't have an ID, then ignore
180
+ next if !provider_folder.join("id").file?
181
+
182
+ provider = provider_folder.basename.to_s.to_sym
183
+ result << [name, provider]
184
+ end
185
+ end
186
+
187
+ # Return the results
188
+ result
189
+ end
190
+
191
+ # This returns the provider name for the default provider for this
192
+ # environment. The provider returned is currently hardcoded to "virtualbox"
193
+ # but one day should be a detected valid, best-case provider for this
194
+ # environment.
195
+ #
196
+ # @return [Symbol] Name of the default provider.
197
+ def default_provider
198
+ :virtualbox
199
+ end
200
+
201
+ # Returns the collection of boxes for the environment.
202
+ #
203
+ # @return [BoxCollection]
204
+ def boxes
205
+ @_boxes ||= BoxCollection.new(boxes_path)
206
+ end
207
+
208
+ # This is the global config, comprised of loading configuration from
209
+ # the default, home, and root Vagrantfiles. This configuration is only
210
+ # really useful for reading the list of virtual machines, since each
211
+ # individual VM can override _most_ settings.
212
+ #
213
+ # This is lazy-loaded upon first use.
214
+ #
215
+ # @return [Object]
216
+ def config_global
217
+ return @config_global if @config_global
218
+
219
+ @logger.info("Initializing config...")
220
+
221
+ home_vagrantfile = nil
222
+ root_vagrantfile = nil
223
+ home_vagrantfile = find_vagrantfile(home_path) if home_path
224
+ root_vagrantfile = find_vagrantfile(root_path) if root_path
225
+
226
+ # Create the configuration loader and set the sources that are global.
227
+ # We use this to load the configuration, and the list of machines we are
228
+ # managing. Then, the actual individual configuration is loaded for
229
+ # each {#machine} call.
230
+ @config_loader = Config::Loader.new(Config::VERSIONS, Config::VERSIONS_ORDER)
231
+ @config_loader.set(:default, File.expand_path("config/default.rb", Vagrant.source_root))
232
+ @config_loader.set(:home, home_vagrantfile) if home_vagrantfile
233
+ @config_loader.set(:root, root_vagrantfile) if root_vagrantfile
234
+
235
+ # Make the initial call to get the "global" config. This is mostly
236
+ # only useful to get the list of machines that we are managing.
237
+ # Because of this, we ignore any warnings or errors.
238
+ @config_global, _ = @config_loader.load([:default, :home, :root])
239
+
240
+ # Return the config
241
+ @config_global
242
+ end
243
+
244
+ # This defines a hook point where plugin action hooks that are registered
245
+ # against the given name will be run in the context of this environment.
246
+ #
247
+ # @param [Symbol] name Name of the hook.
248
+ def hook(name)
249
+ @logger.info("Running hook: #{name}")
250
+ callable = Action::Builder.new
251
+ action_runner.run(
252
+ callable,
253
+ :action_name => name,
254
+ :env => self)
255
+ end
256
+
257
+ # This returns a machine with the proper provider for this environment.
258
+ # The machine named by `name` must be in this environment.
259
+ #
260
+ # @param [Symbol] name Name of the machine (as configured in the
261
+ # Vagrantfile).
262
+ # @param [Symbol] provider The provider that this machine should be
263
+ # backed by.
264
+ # @param [Boolean] refresh If true, then if there is a cached version
265
+ # it is reloaded.
266
+ # @return [Machine]
267
+ def machine(name, provider, refresh=false)
268
+ @logger.info("Getting machine: #{name} (#{provider})")
269
+
270
+ # Compose the cache key of the name and provider, and return from
271
+ # the cache if we have that.
272
+ cache_key = [name, provider]
273
+ @machines ||= {}
274
+ if refresh
275
+ @logger.info("Refreshing machine (busting cache): #{name} (#{provider})")
276
+ @machines.delete(cache_key)
277
+ end
278
+
279
+ if @machines.has_key?(cache_key)
280
+ @logger.info("Returning cached machine: #{name} (#{provider})")
281
+ return @machines[cache_key]
282
+ end
283
+
284
+ @logger.info("Uncached load of machine.")
285
+ sub_vm = config_global.vm.defined_vms[name]
286
+ if !sub_vm
287
+ raise Errors::MachineNotFound, :name => name, :provider => provider
288
+ end
289
+
290
+ provider_cls = Vagrant.plugin("2").manager.providers[provider]
291
+ if !provider_cls
292
+ raise Errors::ProviderNotFound, :machine => name, :provider => provider
293
+ end
294
+
295
+ # Build the machine configuration. This requires two passes: The first pass
296
+ # loads in the machine sub-configuration. Since this can potentially
297
+ # define a new box to base the machine from, we then make a second pass
298
+ # with the box Vagrantfile (if it has one).
299
+ vm_config_key = "vm_#{name}".to_sym
300
+ @config_loader.set(vm_config_key, sub_vm.config_procs)
301
+ config, config_warnings, config_errors = \
302
+ @config_loader.load([:default, :home, :root, vm_config_key])
303
+
304
+ box = nil
305
+ begin
306
+ box = boxes.find(config.vm.box, provider)
307
+ rescue Errors::BoxUpgradeRequired
308
+ # Upgrade the box if we must
309
+ @logger.info("Upgrading box during config load: #{config.vm.box}")
310
+ boxes.upgrade(config.vm.box)
311
+ retry
312
+ end
313
+
314
+ # If a box was found, then we attempt to load the Vagrantfile for
315
+ # that box. We don't require a box since we allow providers to download
316
+ # boxes and so on.
317
+ if box
318
+ box_vagrantfile = find_vagrantfile(box.directory)
319
+ if box_vagrantfile
320
+ # The box has a custom Vagrantfile, so we load that into the config
321
+ # as well.
322
+ @logger.info("Box exists with Vagrantfile. Reloading machine config.")
323
+ box_config_key = "box_#{box.name}_#{box.provider}".to_sym
324
+ @config_loader.set(box_config_key, box_vagrantfile)
325
+ config, config_warnings, config_errors = \
326
+ @config_loader.load([:default, box_config_key, :home, :root, vm_config_key])
327
+ end
328
+ end
329
+
330
+ # Get the provider configuration from the final loaded configuration
331
+ provider_config = config.vm.get_provider_config(provider)
332
+
333
+ # Determine the machine data directory and pass it to the machine.
334
+ # XXX: Permissions error here.
335
+ machine_data_path = @local_data_path.join("machines/#{name}/#{provider}")
336
+ FileUtils.mkdir_p(machine_data_path)
337
+
338
+ # If there were warnings or errors we want to output them
339
+ if !config_warnings.empty? || !config_errors.empty?
340
+ # The color of the output depends on whether we have warnings
341
+ # or errors...
342
+ level = config_errors.empty? ? :warn : :error
343
+ output = Util::TemplateRenderer.render(
344
+ "config/messages",
345
+ :warnings => config_warnings,
346
+ :errors => config_errors).chomp
347
+ @ui.send(level, I18n.t("vagrant.general.config_upgrade_messages",
348
+ :output => output))
349
+
350
+ # If we had errors, then we bail
351
+ raise Errors::ConfigUpgradeErrors if !config_errors.empty?
352
+ end
353
+
354
+ # Create the machine and cache it for future calls. This will also
355
+ # return the machine from this method.
356
+ @machines[cache_key] = Machine.new(name, provider, provider_cls, provider_config,
357
+ config, machine_data_path, box, self)
358
+ end
359
+
360
+ # This returns a list of the configured machines for this environment.
361
+ # Each of the names returned by this method is valid to be used with
362
+ # the {#machine} method.
363
+ #
364
+ # @return [Array<Symbol>] Configured machine names.
365
+ def machine_names
366
+ config_global.vm.defined_vm_keys.dup
367
+ end
368
+
369
+ # This returns the name of the machine that is the "primary." In the
370
+ # case of a single-machine environment, this is just the single machine
371
+ # name. In the case of a multi-machine environment, then this can
372
+ # potentially be nil if no primary machine is specified.
373
+ #
374
+ # @return [Symbol]
375
+ def primary_machine_name
376
+ # If it is a single machine environment, then return the name
377
+ return machine_names.first if machine_names.length == 1
378
+
379
+ # If it is a multi-machine environment, then return the primary
380
+ config_global.vm.defined_vms.each do |name, subvm|
381
+ return name if subvm.options[:primary]
382
+ end
383
+
384
+ # If no primary was specified, nil it is
385
+ nil
386
+ end
387
+
388
+ # Unload the environment, running completion hooks. The environment
389
+ # should not be used after this (but CAN be, technically). It is
390
+ # recommended to always immediately set the variable to `nil` after
391
+ # running this so you can't accidentally run any more methods. Example:
392
+ #
393
+ # env.unload
394
+ # env = nil
395
+ #
396
+ def unload
397
+ hook(:environment_unload)
398
+ end
399
+
400
+ # Makes a call to the CLI with the given arguments as if they
401
+ # came from the real command line (sometimes they do!). An example:
402
+ #
403
+ # env.cli("package", "--vagrantfile", "Vagrantfile")
404
+ #
405
+ def cli(*args)
406
+ CLI.new(args.flatten, self).execute
407
+ end
408
+
409
+ # Returns the host object associated with this environment.
410
+ #
411
+ # @return [Class]
412
+ def host
413
+ return @host if defined?(@host)
414
+
415
+ # Attempt to figure out the host class. Note that the order
416
+ # matters here, so please don't touch. Specifically: The symbol
417
+ # check is done after the detect check because the symbol check
418
+ # will return nil, and we don't want to trigger a detect load.
419
+ host_klass = config_global.vagrant.host
420
+ if host_klass.nil? || host_klass == :detect
421
+ hosts = Vagrant.plugin("2").manager.hosts.to_hash
422
+
423
+ # Get the flattened list of available hosts
424
+ host_klass = Hosts.detect(hosts)
425
+ end
426
+
427
+ # If no host class is detected, we use the base class.
428
+ host_klass ||= Vagrant.plugin("2", :host)
429
+
430
+ @host ||= host_klass.new(@ui)
431
+ end
432
+
433
+ # Action runner for executing actions in the context of this environment.
434
+ #
435
+ # @return [Action::Runner]
436
+ def action_runner
437
+ @action_runner ||= Action::Runner.new do
438
+ {
439
+ :action_runner => action_runner,
440
+ :box_collection => boxes,
441
+ :global_config => config_global,
442
+ :host => host,
443
+ :gems_path => gems_path,
444
+ :home_path => home_path,
445
+ :root_path => root_path,
446
+ :tmp_path => tmp_path,
447
+ :ui => @ui
448
+ }
449
+ end
450
+ end
451
+
452
+ # The root path is the path where the top-most (loaded last)
453
+ # Vagrantfile resides. It can be considered the project root for
454
+ # this environment.
455
+ #
456
+ # @return [String]
457
+ def root_path
458
+ return @root_path if defined?(@root_path)
459
+
460
+ root_finder = lambda do |path|
461
+ # Note: To remain compatible with Ruby 1.8, we have to use
462
+ # a `find` here instead of an `each`.
463
+ found = vagrantfile_name.find do |rootfile|
464
+ File.exist?(File.join(path.to_s, rootfile))
465
+ end
466
+
467
+ return path if found
468
+ return nil if path.root? || !File.exist?(path)
469
+ root_finder.call(path.parent)
470
+ end
471
+
472
+ @root_path = root_finder.call(cwd)
473
+ end
474
+
475
+ # This returns the path which Vagrant uses to determine the location
476
+ # of the file lock. This is specific to each operating system.
477
+ def lock_path
478
+ @lock_path || tmp_path.join("vagrant.lock")
479
+ end
480
+
481
+ # This locks Vagrant for the duration of the block passed to this
482
+ # method. During this time, any other environment which attempts
483
+ # to lock which points to the same lock file will fail.
484
+ def lock
485
+ # This allows multiple locks in the same process to be nested
486
+ return yield if @lock_acquired
487
+
488
+ File.open(lock_path, "w+") do |f|
489
+ # The file locking fails only if it returns "false." If it
490
+ # succeeds it returns a 0, so we must explicitly check for
491
+ # the proper error case.
492
+ raise Errors::EnvironmentLockedError if f.flock(File::LOCK_EX | File::LOCK_NB) === false
493
+
494
+ begin
495
+ # Mark that we have a lock
496
+ @lock_acquired = true
497
+
498
+ yield
499
+ ensure
500
+ # We need to make sure that no matter what this is always
501
+ # reset to false so we don't think we have a lock when we
502
+ # actually don't.
503
+ @lock_acquired = false
504
+ end
505
+ end
506
+ end
507
+
508
+ #---------------------------------------------------------------
509
+ # Load Methods
510
+ #---------------------------------------------------------------
511
+
512
+ # This sets the `@home_path` variable properly.
513
+ #
514
+ # @return [Pathname]
515
+ def setup_home_path
516
+ @home_path = Pathname.new(File.expand_path(@home_path ||
517
+ ENV["VAGRANT_HOME"] ||
518
+ DEFAULT_HOME))
519
+ @logger.info("Home path: #{@home_path}")
520
+
521
+ # Setup the list of child directories that need to be created if they
522
+ # don't already exist.
523
+ dirs = [@home_path]
524
+ subdirs = ["boxes", "data", "gems", "rgloader", "tmp"]
525
+ dirs += subdirs.collect { |subdir| @home_path.join(subdir) }
526
+
527
+ # Go through each required directory, creating it if it doesn't exist
528
+ dirs.each do |dir|
529
+ next if File.directory?(dir)
530
+
531
+ begin
532
+ @logger.info("Creating: #{dir}")
533
+ FileUtils.mkdir_p(dir)
534
+ rescue Errno::EACCES
535
+ raise Errors::HomeDirectoryNotAccessible, :home_path => @home_path.to_s
536
+ end
537
+ end
538
+
539
+ # Create the version file to mark the version of the home directory
540
+ # we're using.
541
+ version_file = @home_path.join("setup_version")
542
+ if !version_file.file?
543
+ @logger.debug("Setting up the version file.")
544
+ version_file.open("w") do |f|
545
+ f.write("1.1")
546
+ end
547
+ end
548
+
549
+ # Create the rgloader/loader file so we can use encoded files.
550
+ loader_file = @home_path.join("rgloader", "loader.rb")
551
+ if !loader_file.file?
552
+ source_loader = Vagrant.source_root.join("templates/rgloader.rb")
553
+ FileUtils.cp(source_loader.to_s, loader_file.to_s)
554
+ end
555
+ end
556
+
557
+ # This creates the local data directory and show an error if it
558
+ # couldn't properly be created.
559
+ def setup_local_data_path
560
+ if @local_data_path.nil?
561
+ @logger.warn("No local data path is set. Local data cannot be stored.")
562
+ return
563
+ end
564
+
565
+ @logger.info("Local data path: #{@local_data_path}")
566
+
567
+ # If the local data path is a file, then we are probably seeing an
568
+ # old (V1) "dotfile." In this case, we upgrade it. The upgrade process
569
+ # will remove the old data file if it is successful.
570
+ if @local_data_path.file?
571
+ upgrade_v1_dotfile(@local_data_path)
572
+ end
573
+
574
+ begin
575
+ @logger.debug("Creating: #{@local_data_path}")
576
+ FileUtils.mkdir_p(@local_data_path)
577
+ rescue Errno::EACCES
578
+ raise Errors::LocalDataDirectoryNotAccessible,
579
+ :local_data_path => @local_data_path.to_s
580
+ end
581
+ end
582
+
583
+ protected
584
+
585
+ # This method copies the private key into the home directory if it
586
+ # doesn't already exist.
587
+ #
588
+ # This must be done because `ssh` requires that the key is chmod
589
+ # 0600, but if Vagrant is installed as a separate user, then the
590
+ # effective uid won't be able to read the key. So the key is copied
591
+ # to the home directory and chmod 0600.
592
+ def copy_insecure_private_key
593
+ if !@default_private_key_path.exist?
594
+ @logger.info("Copying private key to home directory")
595
+
596
+ source = File.expand_path("keys/vagrant", Vagrant.source_root)
597
+ destination = @default_private_key_path
598
+
599
+ begin
600
+ FileUtils.cp(source, destination)
601
+ rescue Errno::EACCES
602
+ raise Errors::CopyPrivateKeyFailed,
603
+ :source => source,
604
+ :destination => destination
605
+ end
606
+ end
607
+
608
+ if !Util::Platform.windows?
609
+ # On Windows, permissions don't matter as much, so don't worry
610
+ # about doing chmod.
611
+ if Util::FileMode.from_octal(@default_private_key_path.stat.mode) != "600"
612
+ @logger.info("Changing permissions on private key to 0600")
613
+ @default_private_key_path.chmod(0600)
614
+ end
615
+ end
616
+ end
617
+
618
+ # Finds the Vagrantfile in the given directory.
619
+ #
620
+ # @param [Pathname] path Path to search in.
621
+ # @return [Pathname]
622
+ def find_vagrantfile(search_path)
623
+ @vagrantfile_name.each do |vagrantfile|
624
+ current_path = search_path.join(vagrantfile)
625
+ return current_path if current_path.exist?
626
+ end
627
+
628
+ nil
629
+ end
630
+
631
+ # Loads the Vagrant plugins by properly setting up RubyGems so that
632
+ # our private gem repository is on the path.
633
+ def load_plugins
634
+ if ENV["VAGRANT_NO_PLUGINS"]
635
+ # If this key exists, then we don't load any plugins. It is a "safe
636
+ # mode" of sorts.
637
+ @logger.warn("VAGRANT_NO_PLUGINS is set. Not loading 3rd party plugins.")
638
+ return
639
+ end
640
+
641
+ # Add our private gem path to the gem path and reset the paths
642
+ # that Rubygems knows about.
643
+ ENV["GEM_PATH"] = "#{@gems_path}#{::File::PATH_SEPARATOR}#{ENV["GEM_PATH"]}"
644
+ ::Gem.clear_paths
645
+
646
+ # Load the plugins
647
+ plugins_json_file = @home_path.join("plugins.json")
648
+ @logger.debug("Loading plugins from: #{plugins_json_file}")
649
+ if plugins_json_file.file?
650
+ data = JSON.parse(plugins_json_file.read)
651
+ data["installed"].each do |plugin|
652
+ @logger.info("Loading plugin from JSON: #{plugin}")
653
+ begin
654
+ Vagrant.require_plugin(plugin)
655
+ rescue Errors::PluginLoadError => e
656
+ @ui.error(e.message + "\n")
657
+ rescue Errors::PluginLoadFailed => e
658
+ @ui.error(e.message + "\n")
659
+ end
660
+ end
661
+ end
662
+ end
663
+
664
+ # This upgrades a Vagrant 1.0.x "dotfile" to the new V2 format.
665
+ #
666
+ # This is a destructive process. Once the upgrade is complete, the
667
+ # old dotfile is removed, and the environment becomes incompatible for
668
+ # Vagrant 1.0 environments.
669
+ #
670
+ # @param [Pathname] path The path to the dotfile
671
+ def upgrade_v1_dotfile(path)
672
+ @logger.info("Upgrading V1 dotfile to V2 directory structure...")
673
+
674
+ # First, verify the file isn't empty. If it is an empty file, we
675
+ # just delete it and go on with life.
676
+ contents = path.read.strip
677
+ if contents.strip == ""
678
+ @logger.info("V1 dotfile was empty. Removing and moving on.")
679
+ path.delete
680
+ return
681
+ end
682
+
683
+ # Otherwise, verify there is valid JSON in here since a Vagrant
684
+ # environment would always ensure valid JSON. This is a sanity check
685
+ # to make sure we don't nuke a dotfile that is not ours...
686
+ @logger.debug("Attempting to parse JSON of V1 file")
687
+ json_data = nil
688
+ begin
689
+ json_data = JSON.parse(contents)
690
+ @logger.debug("JSON parsed successfully. Things are okay.")
691
+ rescue JSON::ParserError
692
+ # The file could've been tampered with since Vagrant 1.0.x is
693
+ # supposed to ensure that the contents are valid JSON. Show an error.
694
+ raise Errors::DotfileUpgradeJSONError,
695
+ :state_file => path.to_s
696
+ end
697
+
698
+ # Alright, let's upgrade this guy to the new structure. Start by
699
+ # backing up the old dotfile.
700
+ backup_file = path.dirname.join(".vagrant.v1.#{Time.now.to_i}")
701
+ @logger.info("Renaming old dotfile to: #{backup_file}")
702
+ path.rename(backup_file)
703
+
704
+ # Now, we create the actual local data directory. This should succeed
705
+ # this time since we renamed the old conflicting V1.
706
+ setup_local_data_path
707
+
708
+ if json_data["active"]
709
+ @logger.debug("Upgrading to V2 style for each active VM")
710
+ json_data["active"].each do |name, id|
711
+ @logger.info("Upgrading dotfile: #{name} (#{id})")
712
+
713
+ # Create the machine configuration directory
714
+ directory = @local_data_path.join("machines/#{name}/virtualbox")
715
+ FileUtils.mkdir_p(directory)
716
+
717
+ # Write the ID file
718
+ directory.join("id").open("w+") do |f|
719
+ f.write(id)
720
+ end
721
+ end
722
+ end
723
+
724
+ # Upgrade complete! Let the user know
725
+ @ui.info(I18n.t("vagrant.general.upgraded_v1_dotfile",
726
+ :backup_path => backup_file.to_s))
727
+ end
728
+ end
729
+ end