forked from dannyti/seedbox-from-scratch
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathcreateLetsEncryptUserInstall
executable file
·71 lines (58 loc) · 2.21 KB
/
createLetsEncryptUserInstall
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
#!/bin/bash
# Hellish Tech
# No commercial usage without authorization
exec 1> >(logger -s -t $(basename $0)) 2>&1
while [[ $# -gt 1 ]]
do
key="$1"
case $key in
-u|--username)
USERNAME="$2"
shift # past argument
;;
-e|--email)
USEREMAIL="$2"
shift # past argument
;;
-s|--subdomains)
SUBDOMAINSLIST="$2"
shift # past argument
;;
-d|--dhlevel)
DHLEVEL="$2"
shift # past argument
;;
*)
# unknown option
;;
esac
shift # past argument or value
done
WEBSERVERSSLPORT=$(/etc/seedbox-from-scratch/sfsgetAvailablePort -sp 8444 -ep 8543)
SYSTEMHOSTNAME=`cat /etc/seedbox-from-scratch/hostname.info`
USERUID=$(id -u ${USERNAME})
USERGID=$(id -g ${USERNAME})
SUBZONESONLYVAR=false
if [ ${SUBZONEONLY} = "true"]; then
SUBZONESONLYVAR=true
fi
docker pull linuxserver/letsencrypt
docker run --restart=always -d --name ${USERNAME}_letsencrypt -e LOCAL_USER_ID=${USERUID} -h ${SYSTEMHOSTNAME} -v /home/${USERNAME}/letsencrypt/config:/config -e PGID=${USERGID} -e URL=${SYSTEMHOSTNAME} -e SUBDOMAINS=${SUBDOMAINSLIST} -e EMAIL=${USEREMAIL} -e PUID=${USERUID} -p ${WEBSERVERSSLPORT}:443 -e DHLEVEL=${DHLEVEL} -v /etc/localtime:/etc/localtime:ro linuxserver/letsencrypt -e ONLY_SUBDOMAINS=${SUBZONESONLYVAR}
sleep 5
CHECKIFRUNNING=$(/etc/seedbox-from-scratch/sfsRunningUserDockerInfo -u ${USERNAME} -d letsencrypt | tr -cd '[[:alnum:]]._-' )
if [[ (${CHECKIFRUNNING} == "STOPPED") || (${CHECKIFRUNNING} == "RUNNING") ]]; then
if [ ! -d "/home/${USERNAME}/letsencrypt/config" ]; then
mkdir /home/${USERNAME}/letsencrypt
mkdir /home/${USERNAME}/letsencrypt/config
chown ${USERNAME}:${USERNAME} /home/${USERNAME}/letsencrypt/ -R
fi
echo "SERVICE: LETSENCRYPT" > /home/${USERNAME}/private/letsencrypt.serviceinfo
echo "USERNAME: $USERNAME" >> /home/${USERNAME}/private/letsencrypt.serviceinfo
echo "ACCESSURL: https://$SYSTEMHOSTNAME:$WEBSERVERSSLPORT" >> /home/${USERNAME}/private/letsencrypt.serviceinfo
echo "WEBSERVERSSLPORT: $WEBSERVERSSLPORT" >> /home/${USERNAME}/private/letsencrypt.serviceinfo
chown www-data:www-data /home/${USERNAME}/private/*.serviceinfo
fi
if [[ -n $1 ]]; then
echo "Last line of file specified as non-opt/last argument:"
tail -1 $1
fi