-
Notifications
You must be signed in to change notification settings - Fork 20
/
Copy pathVagrantfile
executable file
·74 lines (59 loc) · 3.33 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
# Read the README.md before using this.
Vagrant.configure("2") do |config|
$script = <<-SCRIPT
# Update and upgrade packages
sudo apt update -y && apt -y full-upgrade
sudo apt install -y git curl wget ansible python3-pip
# Create SSH key directory and add authorized keys file
chmod 700 /home/vagrant/.ssh
touch /home/vagrant/.ssh/authorized_keys && chmod 600 /home/vagrant/.ssh/authorized_keys
# Configure keypair and add pubkey to authorized keys
cd /vagrant && \
cp tests/vagrant-keys/vagrant_key /home/vagrant/.ssh/id_ed25519
cp tests/vagrant-keys/vagrant.pub /home/vagrant/.ssh/id_ed25519.pub
cat /home/vagrant/.ssh/id_ed25519.pub >> /home/vagrant/.ssh/authorized_keys
# Permissions for SSH keys
chown vagrant:vagrant /home/vagrant/.ssh/id_ed25519 && chmod 600 /home/vagrant/.ssh/id_ed25519
chown vagrant:vagrant /home/vagrant/.ssh/id_ed25519.pub && chmod 600 /home/vagrant/.ssh/id_ed25519.pub
ssh-keyscan -H bitbucket.org >> ~/.ssh/known_hosts
# install zsh
# git clone https://github.com/bruvv/ansible-role-zsh.git /tmp/zsh
# ansible-playbook -i "localhost," -c local -b /tmp/zsh/playbook.yml
# ansible-playbook -i "localhost," -c local -b /tmp/zsh/playbook.yml --extra-vars="zsh_user=$(whoami)"
cd /vagrant && ansible-galaxy install -r requirements/requirements.yml
SCRIPT
# Add IP's and hostnames to hosts files
$host_script = <<-SCRIPT
printf "172.23.18.20 test_server\n" >> /etc/hosts
SCRIPT
# Add commands to make the running of playbooks easier
$playbook_script = <<-SCRIPT
printf "alias test='cd /vagrant && ansible-playbook --connection=local --inventory 127.0.0.1, ansible-playbook.yml'\n" >> /home/vagrant/.bash_profile
SCRIPT
# Set the resources for every vagrant box we are going to describe
config.vm.provider "qemu" do |v|
v.memory = "4G"
# v.memory = 2048
# v.cpus = 4
v.extra_netdev_args = "net=172.23.18.0/24,dhcpstart=172.23.18.20"
v.gui = true
end
# Set synced folders. This way we don't have to install the roles, because the playbooks are in /vagrant and the roles in /vagrant/roles.
# Ansible will always look for a 'roles' folder when executing a playbook from a directory. This allows for easy development.
# vagrant vbguest --do install --no-cleanup
config.vm.synced_folder ".", "/vagrant", type: "rsync"
config.ssh.insert_key = false
# Actually 'calling' the scripts and run them either with elevated privileges or not.
config.vm.provision "shell", inline: $script, privileged: false
config.vm.provision "shell", inline: $host_script, privileged: true
config.vm.define "test_server" do |ansible_host_01|
ansible_host_01.vm.box = "perk/ubuntu-2204-arm64" # arm ubuntu for apple sillicon
# ansible_host_01.vbguest.installer_options = { allow_kernel_upgrade: true }
# ansible_host_01.vbguest.installer_hooks[:before_install] = ["dnf update -y kernel-*", "sleep 2"]
# ansible_host_01.vm.box = "ubuntu/jammy64" #ubuntu 22.04
ansible_host_01.vm.provision "shell", inline: $playbook_script, privileged: false
ansible_host_01.vm.provision :shell, inline: "hostnamectl set-hostname test_server"
# ansible_host_01.vm.network "private_network", ip: "172.23.18.20", nic_type: "virtio"
ansible_host_01.vm.provision "shell", inline: "echo rebooting", privileged: true, reboot: true
end
end