-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrunproxy.sh
executable file
·90 lines (84 loc) · 3.1 KB
/
runproxy.sh
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
#!/bin/bash
# If you want to adjust the image name or the network name,
# change these two lines.
imageName="nginxproxy"
networkName="httpproxy"
datestr=`date '+%Y%m%d-%H%M%S'`
start_nginx () {
docker run -d --restart unless-stopped -p 80:80 -p 443:443 -v `pwd`/logs:/var/log/nginx --network $networkName --name $imageName $imageName
}
while getopts "bhrc" arg
do
case $arg in
b)
echo "Building the $imageName image..."
if [ ! -e config/ssl/cert.pem ]
then
echo "No SSL certificate found, so generating empty files and then will build one of those too."
touch config/ssl/cert.pem
touch config/ssl/cert.key
fi
docker build -t $imageName .
if [ ! -s config/ssl/cert.pem ]
then
echo "Build done, so now creating a self-signed cert"
docker run --rm -v `pwd`/config/ssl:/etc/nginx/ssl $imageName openssl req -x509 -newkey rsa:2048 -nodes -keyout /etc/nginx/ssl/cert.key -days 365 -out /etc/nginx/ssl/cert.pem -config /etc/nginx/ssl/openssl.cnf
fi
echo "Creating a logs directory... (this will generate an error if one exists, ignore it)"
mkdir logs
echo "Build Complete"
exit
;;
r)
echo "Stopping and removing existing $imageName container (probably be some errors here)"
docker stop $imageName
docker rm $imageName
echo "Rebuilding container"
docker build -t $imageName .
echo "Rotating tires"
sudo chown -R jkachel:jkachel logs
sudo chmod -R a+rw logs
cp logs/access.log logs/access-$datestr.log
cp logs/error.log logs/error-$datestr.log
gzip logs/*-$datestr.log
echo -n "" > logs/access.log
echo -n "" > logs/error.log
echo "Running new copy"
start_nginx
exit
;;
c)
echo -e "Removing newcert.* from the SSL folder..."
rm config/ssl/newcert.*
echo -e "Cleaning up and copying the OpenSSL config over..."
docker cp config/ssl/openssl.cnf $imageName:/etc/nginx/ssl/openssl.cnf
docker exec $imageName /bin/sh -c "rm /etc/nginx/ssl/newcert.*"
echo -e "Generating new certificate request and key..."
docker exec $imageName openssl req -new -keyout /etc/nginx/ssl/newcert.key -out /etc/nginx/ssl/newcert.csr -nodes -config /etc/nginx/ssl/openssl.cnf
docker cp $imageName:/etc/nginx/ssl/newcert.key config/ssl/newcert.key
docker cp $imageName:/etc/nginx/ssl/newcert.csr config/ssl/newcert.csr
echo -e "Your new CSR and key should be in config/ssl/newcert.csr and newcert.key."
echo -e "Once you've issued the new cert, the cert and key need to replace the cert.key and cert.pem files respectivey."
echo -e "Then, rebuild the container and your new cert should be active."
exit
;;
h)
echo -e "Stops, cleans up, rebuilds, and reruns the $imageName container.\n"
echo -e "$0 -r"
echo -e "\tRebuilds and re-runs the proxy container"
echo -e "$0 -h"
echo -e "\tDisplays this help"
echo -e "$0 -c"
echo -e "\tGenerate a CSR based on config/ssl/openssl.cnf (for issuing later)"
echo -e "\tProxy will need to be running for this"
echo -e "\n"
exit
;;
*)
;;
esac
done
echo -e "Stopping/removing $imageName and restarting....\n"
docker stop $imageName
docker rm $imageName
start_nginx