Cryptpad

last edited Sat, 04 Jan 2025 08:22:23 GMT
backlinks: null


Dependencies direct link to this section

Installation with Docker direct link to this section

Essential scripts and templates are included in the repository. Clone the stable branch and build a docker img:

docker build -t cryptpad/cryptpad:version-2024.3.0 .

edit the following values in docker-compose.yml:

Make sure to copy the file in /config/exampleconfig.js and at the minimum, add your proper domains. Make sure that HTTPS is set to 0.0.0.0 or NGINX will throw a 502 error.

Set appropriate perms:

mkdir -p data customize onlyoffice-dist onlyoffice-conf
sudo chown -R 4001:4001 data customize onlyoffice-dist onlyoffice-conf

Now run docker compose up -d and docker compose logs cryptpad for the URL you will use to generate your admin key.

Customization direct link to this section

LetsEncrypt TLS certificates direct link to this section

make sure NGINX is stopped

systemctl stop nginx

systemctl start nginx
 acme.sh --issue --standalone -d example.com -k 4096

Generate DH parameter file as instructed in the docs:

sudo openssl dhparam -out /etc/ssl/dhparam.pem 4096
sudo systemctl restart nginx

NGINX setup direct link to this section

server {
    listen       80;
    listen       [::]:80;
    server_name main.domain.com sandbox.domain.com;

    location / {
        access_log off;
        return 301 https://$server_name$request_uri;
    }
}

server {
    listen 443 ssl http2;
    listen [::]:443 ssl http2;

    # Let's Encrypt webroot
    # CHRIS: Deactivated
    # include letsencrypt-webroot;

    # Include mime.types to be able to support .mjs files (see "types" below)
    include mime.types;

    # CryptPad serves static assets over these two domains.
    # `your-main-domain` is what users will enter in their address bar.
    # Privileged computation such as key management is handled in this scope
    # UI content is loaded via the `your-sandbox-domain`.
    # "Content Security Policy" headers prevent content loaded via the sandbox
    # from accessing privileged information.
    # This setup allows to take advantage of CryptPad's sandboxing techniques.
    # In the event of an XSS vulnerability in CryptPad's front-end code
    # this will limit the amount of information accessible to attackers.
    server_name main.domain.com sandbox.domain.com;

    # You'll need to Set the path to your certificates and keys here
    # IMPORTANT: this config is intended to serve assets for at least two domains
    # (your main domain and your sandbox domain). As such, you'll need to generate a single SSL certificate
    # that includes both domains in order for things to work as expected.
    ssl_certificate         /etc/letsencrypt/live/cryptpad.example.com/fullchain.pem;
    ssl_certificate_key     /etc/letsencrypt/live/main.example.com/privkey.pem;
 # diffie-hellman parameters are used to negotiate keys for your session
    # generate strong parameters using the following command
    # openssl dhparam -out /etc/nginx/dhparam.pem 4096
    ssl_dhparam /etc/ssl/dhparam.pem;

    # Speeds things up a little bit when resuming a session
    ssl_session_timeout 1d;
    ssl_session_cache shared:MozSSL:10m;
    ssl_session_tickets off;

    ssl_protocols TLSv1.2 TLSv1.3;
    ssl_ciphers ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-S>    ssl_prefer_server_ciphers off;

    # HSTS (ngx_http_headers_module is required) (63072000 seconds)
    add_header Strict-Transport-Security "max-age=63072000; includeSubDomains" always;

    # OCSP stapling
    ssl_stapling on;
    ssl_stapling_verify on;

    # verify chain of trust of OCSP response using Root CA and Intermediate certs
    ssl_trusted_certificate /etc/ssl/certs/ca-certificates.crt;

    # replace with the IP address of your resolver
    resolver 8.8.8.8 8.8.4.4 1.1.1.1 1.0.0.1 9.9.9.9 149.112.112.112 208.67.222.222 208.67.220.220;

    location / {
        proxy_pass            http://localhost:3000;
        proxy_set_header      X-Real-IP $remote_addr;
        proxy_set_header      Host $host;
        proxy_set_header      X-Forwarded-For $proxy_add_x_forwarded_for;
        client_max_body_size  150m;

        proxy_http_version    1.1;
        proxy_set_header      Upgrade $http_upgrade;
        proxy_set_header      Connection upgrade;
    }
}

Maintainance direct link to this section

Data is stored on filesystem rather than a database. Contents of documents are encrypted with a key so that the server cannot read data. Paths for data can be found at cryptpad/config/config.js.

Backup and Migration direct link to this section

Using the cloud is reasonably safe as all stored contents will be encrypted. Consider backing up the following directories:

For configurations and customization:

References direct link to this section