home · contact · privacy
7348a49feeeca2f87c3339731507107ed557a7c3
[config] / bookworm / setup_scripts / setup_status.plomlompom.com.sh
1 #!/bin/sh
2 set -e
3 . ./misc.sh
4
5 expect_setup_finished_file setup_web_has_been_run setup_web.sh
6
7 mirror_ip=""
8 mirror_state="not mirroring automatically"
9 domain="status.plomlompom.com"
10 mail="plom+status@plomlompom.com"
11 if [ "$#" -gt 0 ]; then
12     domain="$1"
13     if [ "$#" -gt 1 ]; then
14         mail="plom+testing@plomlompom.com"
15         if [ "$#" -gt 2 ]; then
16             mirror_ip="$3"
17             mirror_state="mirroring automatically from ${mirror_ip}"
18         fi
19     fi
20 fi
21 echo "Assuming domain ${domain} and letsencrypt support mail address ${mail} and ${mirror_state}, abort and provide as arguments in this order if other desired! (Otherwise just hit Return.)"
22 read _
23
24 # Install configs, set up firewall.
25 ./install_for_target.sh status.plomlompom.com
26 ./copy_dirtree.sh "${config_tree_prefix}/etc_files" "" status.plomlompom.com 
27 nft -f /etc/nftables.conf
28
29 # Set up letsencrypt certificate. TODO: Is it auto-renewed?
30 ln -sf /etc/nginx/sites-available/default /etc/nginx/sites-enabled/default
31 certbot --nginx --agree-tos --redirect --no-eff-email -m "${mail}" -d "${domain}"
32 rm /etc/nginx/sites-enabled/default
33
34 # Prepare NGINX for status.plomlompom.com.
35 sed -i "s/REPLACE_fqdn_ECALPER/${domain}/g" /etc/nginx/sites-available/status.plomlompom.com.nginx
36 ln -s /etc/nginx/sites-available/status.plomlompom.com.nginx /etc/nginx/sites-enabled/status.plomlompom.com.nginx
37
38 if [ ! -z "${mirror_ip}" ]; then
39     # Set up connection to old server.
40     cp "${setup_scripts_dir}/prepare_to_meet_server.sh" /home/plom/
41     chown plom:plom /home/plom/prepare_to_meet_server.sh
42     su -lc "./prepare_to_meet_server.sh ${old_server}" plom
43     read -p'Hit Enter when you are done.' ignore
44     rm /home/plom/prepare_to_meet_server.sh
45
46     # Mirror dirs.
47     su -lc "ln -s /home/plom/status.plomlompom.com /var/www-dump/status.plomlompom.com" plom
48     cp "${setup_scripts_dir}/mirror_dir.sh" /home/plom/
49     su -lc "./mirror_dir.sh ${mirror_ip} /var/www/status.plomlompom.com" plom
50     rm /home/plom/mirror_dir.sh
51 fi
52
53 service nginx restart
54