#! /bin/sh
#
# $Id: mkimapdcert.in,v 1.5 2005/06/29 18:01:17 mrsam Exp $
#
# Copyright 2000-2005 Double Precision, Inc.  See COPYING for
# distribution information.
#
# This is a short script to quickly generate a self-signed X.509 key for
# IMAP over SSL.  Normally this script would get called by an automatic
# package installation routine.

test -x /usr/local/sbin/openssl || exit 0

prefix="/usr"

if test -f @sysconfig@/courier-imap/imapd.pem
then
	echo "@sysconfig@/courier-imap/imapd.pem already exists."
	exit 1
fi

umask 077
cp /dev/null @sysconfig@/courier-imap/imapd.pem
chmod 600 @sysconfig@/courier-imap/imapd.pem
chown root @sysconfig@/courier-imap/imapd.pem

cleanup() {
	rm -f @sysconfig@/courier-imap/imapd.pem
	rm -f @sysconfig@/courier-imap/imapd.rand
	exit 1
}

cd /usr/share/courier-imap
dd if=/dev/urandom of=@sysconfig@/courier-imap/imapd.rand count=1 2>/dev/null
/usr/local/sbin/openssl req -new -x509 -days 365 -nodes \
	-config /etc/courier/imapd.cnf -out @sysconfig@/courier-imap/imapd.pem -keyout @sysconfig@/courier-imap/imapd.pem || cleanup
/usr/local/sbin/openssl gendh -rand @sysconfig@/courier-imap/imapd.rand 512 >>@sysconfig@/courier-imap/imapd.pem || cleanup
/usr/local/sbin/openssl x509 -subject -dates -fingerprint -noout -in @sysconfig@/courier-imap/imapd.pem || cleanup
rm -f @sysconfig@/courier-imap/imapd.rand
