-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathVagrantfile
37 lines (32 loc) · 1.74 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
# -*- mode: ruby -*-
# vi: set ft=ruby :
Vagrant.configure("2") do |config|
config.vm.box = "bento/ubuntu-22.04"
config.vm.provider "virtualbox" do |v|
v.memory = 2048
v.cpus = 2
end
# Forward postgres to 5433 on the host so you can access it with QGIS and the
# like at ubuntu@localhost:5433
config.vm.network "forwarded_port", guest: 5432, host: 5433
# Modifications to postgres security to allow port forwarding to the host.
# Obviously this is insecure and only meant to be used in a local setting
postgresql_conf_access_for_host = "listen_addresses='*'"
pgsql_mods = "grep -q -F \"#{postgresql_conf_access_for_host}\" /etc/postgresql/14/main/postgresql.conf || echo \"#{postgresql_conf_access_for_host}\" >> /etc/postgresql/14/main/postgresql.conf\n"
%w(vagrant ubuntu underfoot).each do |user|
pgsql_mods << "sudo -u postgres psql -c \"DROP ROLE IF EXISTS #{user}; CREATE ROLE #{user} INHERIT LOGIN SUPERUSER PASSWORD '#{user}'\"\n"
pg_hba_access_for_local_ipv4 = "host all #{user} 127.0.0.1/32 trust # Trust all local connections"
pg_hba_access_for_host = "host all #{user} 10.0.2.2/32 trust # Support connections from the vagrant host"
[pg_hba_access_for_local_ipv4, pg_hba_access_for_host].each do |pattern|
pgsql_mods << "grep -q -F '#{pattern}' /etc/postgresql/14/main/pg_hba.conf || echo '#{pattern}' >> /etc/postgresql/14/main/pg_hba.conf\n"
end
end
# Provision the vm with the relevant dependencies, modify postgres settings
# and create an ubuntu superuser
config.vm.provision "file", source: "./.github/dependencies.sh", destination: "dependencies.sh"
config.vm.provision "shell", inline: <<-SHELL
./dependencies.sh
#{pgsql_mods}
service postgresql restart
SHELL
end