class Homestead def Homestead.configure(config, settings) # Set The VM Provider ENV['VAGRANT_DEFAULT_PROVIDER'] = settings["provider"] ||= "virtualbox" # Configure Local Variable To Access Scripts From Remote Location scriptDir = File.dirname(__FILE__) # Prevent TTY Errors config.ssh.shell = "bash -c 'BASH_ENV=/etc/profile exec bash'" # Allow SSH Agent Forward from The Box config.ssh.forward_agent = true # Configure The Box config.vm.box = settings["box"] ||= "status-im/nimbox" config.vm.box_version = settings["version"] ||= ">= 0.0.1" config.vm.hostname = settings["hostname"] ||= "homestead" # Configure A Private Network IP config.vm.network :private_network, ip: settings["ip"] ||= "192.168.10.10" # Configure Additional Networks if settings.has_key?("networks") settings["networks"].each do |network| config.vm.network network["type"], ip: network["ip"], bridge: network["bridge"] ||= nil end end # Configure A Few VirtualBox Settings config.vm.provider "virtualbox" do |vb| vb.customize ["modifyvm", :id, "--memory", settings["memory"] ||= "2048"] vb.customize ["modifyvm", :id, "--cpus", settings["cpus"] ||= "1"] vb.customize ["modifyvm", :id, "--natdnsproxy1", "on"] vb.customize ["modifyvm", :id, "--natdnshostresolver1", settings["natdnshostresolver"] ||= "on"] vb.customize ["modifyvm", :id, "--ostype", "Ubuntu_64"] vb.customize ['modifyvm', :id, '--cableconnected1', 'on'] if settings.has_key?("gui") && settings["gui"] vb.gui = true end end # Configure A Few VMware Settings ["vmware_fusion", "vmware_workstation"].each do |vmware| config.vm.provider vmware do |v| v.vmx["memsize"] = settings["memory"] ||= 2048 v.vmx["numvcpus"] = settings["cpus"] ||= 1 v.vmx["guestOS"] = "ubuntu-64" if settings.has_key?("gui") && settings["gui"] v.gui = true end end end # Configure A Few Parallels Settings config.vm.provider "parallels" do |v| v.name = settings["name"] ||= "homestead-7" v.update_guest_tools = true v.memory = settings["memory"] ||= 2048 v.cpus = settings["cpus"] ||= 1 end # Standardize Ports Naming Schema if (settings.has_key?("ports")) settings["ports"].each do |port| port["guest"] ||= port["to"] port["host"] ||= port["send"] port["protocol"] ||= "tcp" end else settings["ports"] = [] end # Default Port Forwarding default_ports = { 80 => 8000, 443 => 44300, 3306 => 33060, 5432 => 54320 } # Use Default Port Forwarding Unless Overridden unless settings.has_key?("default_ports") && settings["default_ports"] == false default_ports.each do |guest, host| unless settings["ports"].any? { |mapping| mapping["guest"] == guest } config.vm.network "forwarded_port", guest: guest, host: host, auto_correct: true end end end # Add Custom Ports From Configuration if settings.has_key?("ports") settings["ports"].each do |port| config.vm.network "forwarded_port", guest: port["guest"], host: port["host"], protocol: port["protocol"], auto_correct: true end end # Configure The Public Key For SSH Access if settings.include? 'authorize' if File.exists? File.expand_path(settings["authorize"]) config.vm.provision "shell" do |s| s.inline = "echo $1 | grep -xq \"$1\" /home/vagrant/.ssh/authorized_keys || echo \"\n$1\" | tee -a /home/vagrant/.ssh/authorized_keys" s.args = [File.read(File.expand_path(settings["authorize"]))] end end end # Copy The SSH Private Keys To The Box if settings.include? 'keys' settings["keys"].each do |key| config.vm.provision "shell" do |s| s.privileged = false s.inline = "echo \"$1\" > /home/vagrant/.ssh/$2 && chmod 600 /home/vagrant/.ssh/$2" s.args = [File.read(File.expand_path(key)), key.split('/').last] end end end # Copy User Files Over to VM if settings.include? 'copy' settings["copy"].each do |file| config.vm.provision "file" do |f| f.source = File.expand_path(file["from"]) f.destination = file["to"].chomp('/') + "/" + file["from"].split('/').last end end end # Register All Of The Configured Shared Folders if settings.include? 'folders' settings["folders"].each do |folder| mount_opts = [] if (folder["type"] == "nfs") mount_opts = folder["mount_options"] ? folder["mount_options"] : ['actimeo=1', 'nolock'] elsif (folder["type"] == "smb") mount_opts = folder["mount_options"] ? folder["mount_options"] : ['vers=3.02', 'mfsymlinks'] elsif (folder["type"] == "sshfs") mount_opts = folder["mount_options"] ? folder["mount_options"] : ['nonempty'] end # For b/w compatibility keep separate 'mount_opts', but merge with options options = (folder["options"] || {}).merge({ mount_options: mount_opts }) # Double-splat (**) operator only works with symbol keys, so convert options.keys.each{|k| options[k.to_sym] = options.delete(k) } config.vm.synced_folder folder["map"], folder["to"], type: folder["type"] ||= nil, **options # Bindfs support to fix shared folder (NFS) permission issue on Mac if (folder["type"] == "nfs" && Vagrant.has_plugin?("vagrant-bindfs")) config.vm.synced_folder folder["map"], "/mnt/vagrant", id: "vagrant", type: 'nfs' config.bindfs.bind_folder "/mnt/vagrant", folder["to"], owner: "vagrant", group: "vagrant", perms: "u=rwX:g=rwX:o=rD", 'create-as-user': true, 'create-with-perms': "u=rwX:g=rwX:o=rD", 'chown-ignore': true, 'chgrp-ignore': true, 'chmod-ignore': true, 'o': "nonempty" end end end # Install All The Configured Nginx Sites config.vm.provision "shell" do |s| s.path = scriptDir + "/clear-nginx.sh" end if settings.include? 'sites' settings["sites"].each do |site| type = site["type"] ||= "laravel" if (site.has_key?("hhvm") && site["hhvm"]) type = "hhvm" end if (type == "symfony") type = "symfony2" end if (type == "symfony-sulu") type = "sulu" end config.vm.provision "shell" do |s| s.name = "Creating Site: " + site["map"] s.path = scriptDir + "/serve-#{type}.sh" s.args = [site["map"], site["to"], site["port"] ||= "80", site["ssl"] ||= "443"] end # Configure The Cron Schedule if (site.has_key?("schedule")) config.vm.provision "shell" do |s| s.name = "Creating Schedule" if (site["schedule"]) s.path = scriptDir + "/cron-schedule.sh" s.args = [site["map"].tr('^A-Za-z0-9', ''), site["to"]] else s.inline = "rm -f /etc/cron.d/$1" s.args = [site["map"].tr('^A-Za-z0-9', '')] end end end end end config.vm.provision "shell" do |s| s.name = "Restarting Nginx" s.inline = "sudo service nginx restart; sudo service php7.2-fpm restart" end # Install MariaDB If Necessary if settings.has_key?("mariadb") && settings["mariadb"] config.vm.provision "shell" do |s| s.path = scriptDir + "/install-maria.sh" end end # Configure All Of The Configured Databases if settings.has_key?("databases") settings["databases"].each do |db| config.vm.provision "shell" do |s| s.name = "Creating MySQL Database: " + db s.path = scriptDir + "/create-mysql.sh" s.args = [db] end config.vm.provision "shell" do |s| s.name = "Creating Postgres Database: " + db s.path = scriptDir + "/create-postgres.sh" s.args = [db] end end end # Configure All Of The Server Environment Variables config.vm.provision "shell" do |s| s.name = "Clear Variables" s.path = scriptDir + "/clear-variables.sh" end if settings.has_key?("variables") settings["variables"].each do |var| config.vm.provision "shell" do |s| s.inline = "echo \"\nenv[$1] = '$2'\" >> /etc/php/7.2/fpm/php-fpm.conf" s.args = [var["key"], var["value"]] end config.vm.provision "shell" do |s| s.inline = "echo \"\n# Set Homestead Environment Variable\nexport $1=$2\" >> /home/vagrant/.profile" s.args = [var["key"], var["value"]] end end config.vm.provision "shell" do |s| s.inline = "service php7.2-fpm restart" end end # Update Composer On Every Provision config.vm.provision "shell" do |s| s.name = "Update Composer" s.inline = "sudo /usr/local/bin/composer self-update && sudo chown -R vagrant:vagrant /home/vagrant/.composer/" s.privileged = false end # Configure Blackfire.io if settings.has_key?("blackfire") config.vm.provision "shell" do |s| s.path = scriptDir + "/blackfire.sh" s.args = [ settings["blackfire"][0]["id"], settings["blackfire"][0]["token"], settings["blackfire"][0]["client-id"], settings["blackfire"][0]["client-token"] ] end end end end