Skip to content

Providing encrypted web access to Etherpad Lite using SSL certificates (HTTPS: )

Wikinaut edited this page Nov 25, 2012 · 36 revisions

under construction 24.11.2012 21:40 local time (20121124204010 UTC).

use with care

DO NOT COPY/PASTE THESE STEPS AS IT WONT WORK WITH THE CURRENT EPL VERSION

Disclaimer

The following information has been carefully collected but may contain errors or may be fully or partially outdated. Please use the description with care.
Familiarise yourself with the SSL concept and get a second opinion of SSL, server keys and encrypted transmission by studying also other web resources.
Only deploy SSL to your production system if you exactly know what you are doing.

By default, Etherpad Lite runs via http:// which is unsecure in many respects, for example regarding the transmission of admin or user passwords in plain text, and also regarding confidential pad contents. When using http.

But there is hope.

As a server admin using this patch you can now set up your Etherpad Lite to use the native https server part of Node and Express framework in a fully secure way and there is no need for using an Apache or Nginx server or proxy.

The following description for Linux assume that you want to

  • generate self-signed keys
  • which are valid for 9000 days.

If you want to have your key signed by approved Certificate Authority (CA), it's getting difficult and you usually need to pay yearly. There is at least one "Web of Trust" (WoT) community CA called "CAcert" (see reference section), which - once you became assured member - allows you to get CAcert-signed server keys which lasts for two years for free.

Some intermediate files will be generated but not explained here, too keep it concise. Read the page in "References" if you are curious what they are for.

  • uncomment the SSL section in the settings.json.template of your EPL installation
  • generate a file epl-server.key which does not require a password
# generate the server key
openssl genrsa -des3 -out epl-server.key 4096
openssl req -new -key epl-server.key -out epl-server.csr
openssl x509 -req -days 9000 -in epl-server.csr -signkey epl-server.key -out epl-server.crt
# make a version of the server key which does not require a password
openssl rsa -in epl-server.key -out epl-server.key.insecure
mv epl-server.key server.key.secure
mv epl-server.key.insecure epl-server.key
  • generate a second key as your own "Certificate Authority" (CA) with which you can self-sign the epl-server.key
# generate a second (temporary) key as the key of your own CA
openssl genrsa -des3 -out own-ca.key 4096
openssl req -new -x509 -days 9000 -key own-ca.key -out own-ca.crt
# sign your epl-server.key with the certificate of your own CA resulting in a self-signed epl-server.key
openssl x509 -req -days 9000 -in epl-server.csr -CA own-ca.crt -CAkey own-ca.key -set_serial 001 -out epl-server.crt
  • deploy the two files (epl-server.key and epl-sever.crt) on your server, so that only the etherpad (process, task, program) user can access this sensitive data
chmod 400 epl-server.key
chown etherpad epl-server.key
chmod 400 epl-server.crt
chown etherpad epl-server.crt
  • these files are no longer needed unless you want to create further keys as "own CA":
epl-server.key.secure
epl-server.csr
own-ca.key
own-ca.crt
  • restart your EPL server

general SSL risk: "man in the middle" (MITM) attack

An important thing is to tell users what a "fingerprint of the server key" is and how they can check whether the received fingerprint in the current browser connection matches the correct server fingerprint. (Details will be added later, I just wanted to mention it.)

references

General

Resources

For Developers

How to's

Set up

Advanced steps

Integrating Etherpad in your web app

for Developers

Clone this wiki locally