mirror of https://github.com/zulip/zulip.git
tools: Add script apns/prep-cert.
This prepares server certificates for talking to APNs.
This commit is contained in:
parent
92251a7cf6
commit
214eec007a
|
@ -0,0 +1,9 @@
|
||||||
|
[req]
|
||||||
|
encrypt_key = no
|
||||||
|
|
||||||
|
prompt = no
|
||||||
|
distinguished_name = req_distinguished_name
|
||||||
|
|
||||||
|
[req_distinguished_name]
|
||||||
|
CN = APNs for Zulip
|
||||||
|
emailAddress = zulip-ops@zulip.com
|
|
@ -0,0 +1,48 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
this_dir=${BASH_SOURCE[0]%/*}
|
||||||
|
|
||||||
|
die() {
|
||||||
|
echo >&2 "$1"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
request() {
|
||||||
|
(($# == 2)) || die "usage: prep-cert request KEY_OUT CSR_OUT"
|
||||||
|
local key_out=$1
|
||||||
|
local csr_out=$2
|
||||||
|
|
||||||
|
openssl req -new \
|
||||||
|
-config "${this_dir}/csr.conf" \
|
||||||
|
-keyout "${key_out}" -out "${csr_out}"
|
||||||
|
}
|
||||||
|
|
||||||
|
combine() {
|
||||||
|
(($# == 3)) || die "usage: prep-cert combine KEY CERT OUT"
|
||||||
|
local key=$1
|
||||||
|
local cert=$2
|
||||||
|
local out=$3
|
||||||
|
|
||||||
|
local tmpdir
|
||||||
|
tmpdir=$(mktemp -d)
|
||||||
|
cleanup() {
|
||||||
|
rm -rf "${tmpdir}"
|
||||||
|
trap - RETURN EXIT
|
||||||
|
}
|
||||||
|
trap cleanup RETURN EXIT
|
||||||
|
|
||||||
|
local cert_pem="${tmpdir}/cert.pem"
|
||||||
|
local combined_p12="${tmpdir}/combined.p12"
|
||||||
|
openssl x509 -in "${cert}" -inform der -out "${cert_pem}"
|
||||||
|
openssl pkcs12 -export -passout pass: \
|
||||||
|
-inkey "${key}" -in "${cert_pem}" -out "${combined_p12}"
|
||||||
|
openssl pkcs12 -in "${combined_p12}" -passin pass: \
|
||||||
|
-out "${out}" -nodes
|
||||||
|
}
|
||||||
|
|
||||||
|
case "${1-}" in
|
||||||
|
request) shift && request "$@" ;;
|
||||||
|
combine) shift && combine "$@" ;;
|
||||||
|
*) die "usage: prep-cert {request|combine} ...ARGS" ;;
|
||||||
|
esac
|
Loading…
Reference in New Issue