-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathAutoCA-0.0.1.sh
54 lines (44 loc) · 1.66 KB
/
AutoCA-0.0.1.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
#!/bin/sh
# create self-signed server certificate:
read -p "Enter your domain [www.example.com]: " DOMAIN
if [[ ! -f ca.crt ]]; then
mkdir -p /etc/pki/CA/
rm -rf /etc/pki/CA/index.txt
rm -rf /etc/pki/CA/serial
touch /etc/pki/CA/{index.txt,serial}
echo "01" > /etc/pki/CA/serial
echo "Create CA key..."
SUBJECT="/C=BJ/ST=BJ/L=OMP/O=OMP/OU=OMP/CN=OMPSSL"
openssl genrsa -des3 -out ca.key 2048
openssl req -new -subj $SUBJECT -x509 -days 3650 -key ca.key -out ca.crt
fi
echo "Create server key..."
SUBJECT="/C=BJ/ST=BJ/L=OMP/O=OMP/OU=OMP/CN=$DOMAIN"
openssl genrsa -des3 -out $DOMAIN.key 1024
echo "Create server certificate signing request..."
openssl req -new -subj $SUBJECT -key $DOMAIN.key -out $DOMAIN.csr
echo "Remove password..."
mv $DOMAIN.key $DOMAIN.origin.key
openssl rsa -in $DOMAIN.origin.key -out $DOMAIN.key
echo "Sign SSL certificate..."
#openssl x509 -req -days 3650 -in $DOMAIN.csr -signkey $DOMAIN.key -out $DOMAIN.crt
openssl ca -policy policy_anything -days 3650 -cert ca.crt -keyfile ca.key -in $DOMAIN.csr -out $DOMAIN.crt
cat ca.crt >> $DOMAIN.crt
#openssl s_client -connect wap.com.cn:443
#yum install ca-certificates
#update-ca-trust force-enable
#cp ca.crt /etc/pki/ca-trust/source/anchors/
#update-ca-trust extract
echo ""
echo ""
echo "TODO:"
echo "Copy $DOMAIN.crt to /etc/nginx/ssl/$DOMAIN.crt"
echo "Copy $DOMAIN.key to /etc/nginx/ssl/$DOMAIN.key"
echo "Add configuration in nginx:"
echo "server {"
echo " ..."
echo " listen 443 ssl;"
echo " ssl_certificate /etc/nginx/ssl/$DOMAIN.crt;"
echo " ssl_certificate_key /etc/nginx/ssl/$DOMAIN.key;"
echo " ssl_client_certificate /etc/nginx/ssl/ca.crt;"
echo "}"