This how to explains how to setup qpopper (pop3) with
ssl encryption to securely download emails from your pop3.
This howto strictly depends on you having a base knowledge of qpopper
and OpenSSL in general, it does not guide the install of either, only
the setup between the two. But lets be sure you've compiled qpopper
with ssl support? ;)
First create a place to store your openssl keys safely
mkdir -p -m665 /etc/mail/certs
chown root:mail /etc/mail/certs
chmod 660 /etc/mail/certs
Use openssl to create a public-private key pair and a certificate
signing request (csa).
openssl req -new -nodes -out req.pem -keyout /etc/mail/certs/cert.pem
(follow questions it asks after this command is used and fill the
options in completely)
next,
chmod 600 /etc/mail/certs/cert.pem
chown root:0 /etc/mail/certs/cert.pem
if you dont want to send your cert in, to pay for a real CA to sign it
do NOT do this step right now follow 1b. below this 1a.
1a.
send the certificate signing request (file req.pem) to your
Certificate Authority for signing. You will receive back a
signed request. Assuming this signed request is in a file called
signed_req.pem, concatenate it to the private key generated earlier:
cat signed-req.pem >> /etc/mail/certs/cert.pem
1b.
if you want to sign your own and be your own CA from above to
avoid sending it to a Certificate Authority do the following. AFTER
you have done the above up to the cat signed-req, which will be done
the following 3.
openssl genrsa -des3 -out ca.key 1024
openssl req -new -x509 -days 365 -key ca.key -out ca.crt
openssl x509 -req -CA ca.crt -CAkey ca.key -days 365 -in req.pem -out
signed-req.pem -CAcreateserial
now you can cat signed-req.pem >> /etc/mail/certs/cert.pem
--
next we configure qpopper.config , you may place this anywhere you like
in your system inside of it there are a few options to adjust inside.
they are as follows.
(set tls-support) can also be "stls".
set tls-support = alternate-port
set tls-version = default
set tls-server-cert-file = /etc/mail/certs/cert.pem
to wrap things up
Use the -f config-file-path command-line option to tell Qpopper to
read the configuration file. a sample inetd line is below:
pop3s stream tcp nowait root /usr/local/sbin/popper popper -s
-f /etc/mail/qpopper.config
(of course making sure pop3s is inside of your /etc/services
as --> pop3s 995/tcp
if using inetd, killall -HUP inetd, and you should be all set.
to test if this is truely encrypting email i'd suggest some sort of
sniffing software from your local freshmeat, or freebsd ports..
snort works nicely, with the examples:
snort -vde -i lo0 tcp port 995
snort -vde tcp port 995
You may watch the traffic on your pop3s port to determine its ssl awareness
p.s - as i state in all my articles i "may" leave something out accidently
because i think its trivial i do not mean nor intend to do this so if you
find this is the case in one please email me for a prompt article update
thank you.