mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00
52 lines
1.3 KiB
Bash
Executable File
52 lines
1.3 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
set -euo pipefail
|
|
|
|
if ! [[ "$0" =~ "./gencerts.sh" ]]; then
|
|
echo "must be run from 'fixtures'"
|
|
exit 255
|
|
fi
|
|
|
|
if ! command -v cfssl; then
|
|
echo "cfssl is not installed"
|
|
echo 'use: bash -c "cd ../../../tools/mod; go install github.com/cloudflare/cfssl/cmd/cfssl"'
|
|
exit 255
|
|
fi
|
|
|
|
if ! command -v cfssljson; then
|
|
echo "cfssljson is not installed"
|
|
echo 'use: bash -c "cd ../../../tools/mod; go install github.com/cloudflare/cfssl/cmd/cfssljson"'
|
|
exit 255
|
|
fi
|
|
|
|
cfssl gencert --initca=true ./ca-csr.json | cfssljson --bare ./ca
|
|
mv ca.pem ca.crt
|
|
if which openssl >/dev/null; then
|
|
openssl x509 -in ca.crt -noout -text
|
|
fi
|
|
|
|
# generate DNS: localhost, IP: 127.0.0.1, CN: example.com certificates
|
|
cfssl gencert \
|
|
--ca ./ca.crt \
|
|
--ca-key ./ca-key.pem \
|
|
--config ./gencert.json \
|
|
./server-ca-csr.json | cfssljson --bare ./server
|
|
mv server.pem server.crt
|
|
mv server-key.pem server.key.insecure
|
|
|
|
# generate IP: 127.0.0.1, CN: example.com certificates
|
|
cfssl gencert \
|
|
--ca ./ca.crt \
|
|
--ca-key ./ca-key.pem \
|
|
--config ./gencert.json \
|
|
./server-ca-csr-ip.json | cfssljson --bare ./server-ip
|
|
mv server-ip.pem server-ip.crt
|
|
mv server-ip-key.pem server-ip.key.insecure
|
|
|
|
if which openssl >/dev/null; then
|
|
openssl x509 -in ./server.crt -text -noout
|
|
openssl x509 -in ./server-ip.crt -text -noout
|
|
fi
|
|
|
|
rm -f *.csr *.pem *.stderr *.txt
|