Find a file
2024-07-18 04:38:50 -07:00
http_only_nginx_templates initial public commit 2024-07-03 23:40:30 -07:00
nginx_templates enable ipv6 for docker to retain proper source addresses for SPF 2024-07-12 05:30:22 -07:00
templates switch to upstream docker -- hopefully fixes ipv6 source address issues 2024-07-14 03:27:19 -07:00
test initial public commit 2024-07-03 23:40:30 -07:00
.gitignore initial public commit 2024-07-03 23:40:30 -07:00
backup.sh add btrfs snapshot encrypted backup script 2024-07-07 23:38:38 -07:00
docker-compose.yml upgrade mail server to v0.8.5 2024-07-18 04:38:50 -07:00
LICENSE.md initial public commit 2024-07-03 23:40:30 -07:00
options-ssl-nginx.conf initial public commit 2024-07-03 23:40:30 -07:00
production.env initial public commit 2024-07-03 23:40:30 -07:00
README.md initial public commit 2024-07-03 23:40:30 -07:00
setup.sh switch to upstream docker -- hopefully fixes ipv6 source address issues 2024-07-14 03:27:19 -07:00
test-in-vm.sh initial public commit 2024-07-03 23:40:30 -07:00
test.env initial public commit 2024-07-03 23:40:30 -07:00
website_git_post_receive_hook.sh extract config files out of setup.sh 2024-07-04 22:03:06 -07:00

Libre-Chip server setup scripts

Testing Locally

  • Using libvirt (you can use the virt-manager gui frontend), create a VM with 6GB RAM and 4 CPUs and at least 30GB of disk space running Debian 12 with a btrfs root filesystem. The VM should be named libre-chip.test. Do NOT create a non-root user yet, that comes later.

  • Install some packages in the VM:

apt install openssh-server sudo
  • Copy your ssh public key from your user on the host (e.g. ~/.ssh/id_rsa.pub) and put it in the VM's /root/.ssh/authorized_keys and make sure both that file and the parent .ssh directory have been chmod-ed to 600.

  • Get the IPv4 address of the VM:

ip addr
  • Add the following lines to your host's /etc/hosts:
<public-IP-address-of-your-host> pebble
<IP-address-of-your-VM> libre-chip.test
<IP-address-of-your-VM> librechip.test
<IP-address-of-your-VM> mail.libre-chip.test
<IP-address-of-your-VM> mail.librechip.test
<IP-address-of-your-VM> git.libre-chip.test
<IP-address-of-your-VM> git.librechip.test
<IP-address-of-your-VM> forum.libre-chip.test
<IP-address-of-your-VM> forum.librechip.test
  • (Optional) Create a non-root user with UID 1001, being careful to not use UID 1000 or GID 1000:
adduser --uid 1001 your-user-name
adduser your-user-name sudo
  • logout from the VM but leave it running.

Create a snapshot of the VM while its running but no users are logged in, and name the snapshot start.

Now you're ready to test! Just run ./test-in-vm.sh on the host, it will automatically reset the VM and login over ssh and run the setup script.

Installing on the public server

Not Tested Yet!

Make sure the VM has no users with UID 1000, and that the VM has a btrfs root filesystem.

Run the setup script on the VM:

sudo ./setup.sh --production