# -*- mode: ruby -*- # vi: set ft=ruby : # Default user # ---------------------- # login: vagrant # pass: vagrant Vagrant.configure("2") do |config| # Basic configuration config.vm.provider "virtualbox" config.vm.box = "generic/centos9s" config.ssh.forward_agent = true # 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" # 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 "../../..", "/home/vagrant/Rublon-Linux" config.vm.provider "virtualbox" do |vb| # Display the VirtualBox GUI when booting the machine vb.gui = true # Fix for 'SSH auth method: Private key' stuck vb.customize ["modifyvm", :id, "--cableconnected1", "on"] end # Enable provisioning with a shell script. Additional provisioners such as # Ansible, Chef, Docker, Puppet and Salt are also available. Please see the # documentation for more information about their specific syntax and use. config.vm.provision "shell", inline: <<-SHELL yum update yum install -y gcc openssl-devel curl-devel pam-devel rapidjson-devel cmake # Building project cd /home/vagrant/Rublon-Linux cmake -B build && cmake --build build sudo cmake --install build sed -i 's/UsePAM .*/UsePAM yes/' /etc/ssh/sshd_config sed -i 's/ChallengeResponseAuthentication .*/ChallengeResponseAuthentication yes/' /etc/ssh/sshd_config grep -q -e 'auth required pam_rublon.so' /etc/pam.d/sshd || sed -i '\$aauth required pam_rublon.so' /etc/pam.d/sshd grep -q -e 'account required pam_rublon.so' /etc/pam.d/sshd || sed -i '\$aaccount required pam_rublon.so' /etc/pam.d/sshd systemctl restart sshd.service SHELL end