4b2bec5
UTF8 := $(shell locale -c LC_CTYPE -k | grep -q charmap.*UTF-8 && echo -utf8)
4b2bec5
SERIAL=0
ff3f6f3
DAYS=365
ff3f6f3
KEYLEN=2048
ff3f6f3
TYPE=rsa:$(KEYLEN)
4b2bec5
4b2bec5
.PHONY: usage
4b2bec5
.SUFFIXES: .key .csr .crt .pem
4b2bec5
.PRECIOUS: %.key %.csr %.crt %.pem
4b2bec5
4b2bec5
usage:
4b2bec5
	@echo "This makefile allows you to create:"
4b2bec5
	@echo "  o public/private key pairs"
4b2bec5
	@echo "  o SSL certificate signing requests (CSRs)"
4b2bec5
	@echo "  o self-signed SSL test certificates"
4b2bec5
	@echo
4b2bec5
	@echo "To create a key pair, run \"make SOMETHING.key\"."
4b2bec5
	@echo "To create a CSR, run \"make SOMETHING.csr\"."
4b2bec5
	@echo "To create a test certificate, run \"make SOMETHING.crt\"."
4b2bec5
	@echo "To create a key and a test certificate in one file, run \"make SOMETHING.pem\"."
4b2bec5
	@echo
4b2bec5
	@echo "To create a key for use with Apache, run \"make genkey\"."
4b2bec5
	@echo "To create a CSR for use with Apache, run \"make certreq\"."
4b2bec5
	@echo "To create a test certificate for use with Apache, run \"make testcert\"."
4b2bec5
	@echo
4b2bec5
	@echo "To create a test certificate with serial number other than zero, add SERIAL=num"
ff3f6f3
	@echo "You can also specify key length with KEYLEN=n and expiration in days with DAYS=n"
4b2bec5
	@echo
4b2bec5
	@echo Examples:
4b2bec5
	@echo "  make server.key"
4b2bec5
	@echo "  make server.csr"
4b2bec5
	@echo "  make server.crt"
4b2bec5
	@echo "  make stunnel.pem"
4b2bec5
	@echo "  make genkey"
4b2bec5
	@echo "  make certreq"
4b2bec5
	@echo "  make testcert"
4b2bec5
	@echo "  make server.crt SERIAL=1"
4b2bec5
	@echo "  make stunnel.pem SERIAL=2"
4b2bec5
	@echo "  make testcert SERIAL=3"
4b2bec5
4b2bec5
%.pem:
4b2bec5
	umask 77 ; \
4b2bec5
	PEM1=`/bin/mktemp /tmp/openssl.XXXXXX` ; \
4b2bec5
	PEM2=`/bin/mktemp /tmp/openssl.XXXXXX` ; \
ff3f6f3
	/usr/bin/openssl req $(UTF8) -newkey $(TYPE) -keyout $$PEM1 -nodes -x509 -days $(DAYS) -out $$PEM2 -set_serial $(SERIAL) ; \
4b2bec5
	cat $$PEM1 >  $@ ; \
4b2bec5
	echo ""    >> $@ ; \
4b2bec5
	cat $$PEM2 >> $@ ; \
4b2bec5
	$(RM) $$PEM1 $$PEM2
4b2bec5
4b2bec5
%.key:
4b2bec5
	umask 77 ; \
ff3f6f3
	/usr/bin/openssl genrsa -aes128 $(KEYLEN) > $@
4b2bec5
4b2bec5
%.csr: %.key
4b2bec5
	umask 77 ; \
4b2bec5
	/usr/bin/openssl req $(UTF8) -new -key $^ -out $@
4b2bec5
4b2bec5
%.crt: %.key
4b2bec5
	umask 77 ; \
ff3f6f3
	/usr/bin/openssl req $(UTF8) -new -key $^ -x509 -days $(DAYS) -out $@ -set_serial $(SERIAL)
4b2bec5
4b2bec5
TLSROOT=/etc/pki/tls
4b2bec5
KEY=$(TLSROOT)/private/localhost.key
4b2bec5
CSR=$(TLSROOT)/certs/localhost.csr
4b2bec5
CRT=$(TLSROOT)/certs/localhost.crt
4b2bec5
4b2bec5
genkey: $(KEY)
4b2bec5
certreq: $(CSR)
4b2bec5
testcert: $(CRT)
4b2bec5
4b2bec5
$(CSR): $(KEY)
4b2bec5
	umask 77 ; \
4b2bec5
	/usr/bin/openssl req $(UTF8) -new -key $(KEY) -out $(CSR)
4b2bec5
4b2bec5
$(CRT): $(KEY)
4b2bec5
	umask 77 ; \
ff3f6f3
	/usr/bin/openssl req $(UTF8) -new -key $(KEY) -x509 -days $(DAYS) -out $(CRT) -set_serial $(SERIAL)