Etherpad: Difference between revisions
Initial |
formatted Tag: 2017 source edit |
||
Line 1: | Line 1: | ||
= Why Etherpad = | |||
Return to [[server-guides|Server Guides]] | |||
Etherpad is a highly customizable open-source online editor providing real-time collaborative editing. While it is not end-to-end encrypted, owning the infrastructure provides a great solution for everyday collaboration and is an excellent alternative to common services. | |||
For a more advanced and secure option, [https://cryptpad.org/ Cryptpad] offers additional features and more than just a Wordpad-style service. | |||
< | == Install Code == | ||
The following code sets up Etherpad: | |||
# Setting up the environment | |||
# Installing Etherpad | |||
# Configuring a read database (MariaDB) instead of the development db | |||
# Establishing SSL | |||
''' Read Me''': | |||
The script will prompt for the domain, subdomain, and SQL password. For security purposes, the SQL password will not display as you type. | |||
<pre> | |||
#!/bin/bash | |||
# source: https://hub.docker.com/r/etherpad/etherpad | |||
user_prompts(){ | user_prompts(){ | ||
echo "domain: " | echo "domain: " | ||
read -r domain | read -r domain | ||
echo "sub-domain: " | echo "sub-domain: " | ||
Line 41: | Line 52: | ||
} | } | ||
setup_git(){ | setup_git(){ | ||
#assume location is /opt/etherpad | # assume location is /opt/etherpad | ||
#running install commands as newly created etherpad user | # running install commands as newly created etherpad user | ||
sudo -H -u etherpad bash -c cd /opt/etherpad || exit | sudo -H -u etherpad bash -c "cd /opt/etherpad || exit" | ||
sudo -H -u etherpad bash -c curl -sL https://deb.nodesource.com/setup_14.x | sudo -E bash - | sudo -H -u etherpad bash -c "curl -sL https://deb.nodesource.com/setup_14.x | sudo -E bash -" | ||
sudo -H -u etherpad bash -c git clone --branch master https://github.com/ether/etherpad-lite.git | sudo -H -u etherpad bash -c "git clone --branch master https://github.com/ether/etherpad-lite.git" | ||
sudo -H -u etherpad bash -c cd etherpad-lite || exit | sudo -H -u etherpad bash -c "cd etherpad-lite || exit" | ||
sudo -H -u etherpad bash -c src/bin/run.sh | sudo -H -u etherpad bash -c "src/bin/run.sh" | ||
# create etherpad as a service | # create etherpad as a service | ||
echo "[Unit] | echo "[Unit] | ||
Line 73: | Line 84: | ||
sudo mariadb -e "CREATE DATABASE $sql_db_name DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;" | sudo mariadb -e "CREATE DATABASE $sql_db_name DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;" | ||
sudo mariadb -e "CREATE USER '$sql_user'@'localhost' identified by '$sql_password';" | sudo mariadb -e "CREATE USER '$sql_user'@'localhost' identified by '$sql_password';" | ||
sudo mariadb -e "GRANT ALL PRIVILEGES ON $sql_db_name. | sudo mariadb -e "GRANT ALL PRIVILEGES ON $sql_db_name.* TO '$sql_user'@'localhost' IDENTIFIED BY '$sql_password';" | ||
##FIXME remove dirty db | ##FIXME: remove dirty db | ||
#sed -i '/"dbType"/i \/ | #sed -i '/"dbType"/i \/' settings.json | ||
##FIXME: configure settings | |||
##FIXME configure settings | |||
# "dbType" : "mysql", | # "dbType" : "mysql", | ||
# "dbSettings" : { | # "dbSettings" : { | ||
Line 83: | Line 93: | ||
# "host": "localhost", | # "host": "localhost", | ||
# "port": 3306, | # "port": 3306, | ||
# "password": " | # "password": "$sql_password", | ||
# "database": " | # "database": "$sql_db_name", | ||
# "charset": "utf8mb4" | # "charset": "utf8mb4" | ||
# }, | # }, | ||
Line 113: | Line 123: | ||
systemctl start etherpad | systemctl start etherpad | ||
} | } | ||
main</ | main | ||
</pre> | |||
For further information, visit the official [https://etherpad.org/ Etherpad site] or [https://hub.docker.com/r/etherpad/etherpad Docker Hub for Etherpad]. | |||
[[Category:Server Guides]] | |||
[[Category:Collaboration Tools]] | |||
[[Category:Open Source]] | |||
[[Category:Etherpad]] |
Latest revision as of 00:59, 6 October 2024
Why Etherpad
Return to Server Guides
Etherpad is a highly customizable open-source online editor providing real-time collaborative editing. While it is not end-to-end encrypted, owning the infrastructure provides a great solution for everyday collaboration and is an excellent alternative to common services.
For a more advanced and secure option, Cryptpad offers additional features and more than just a Wordpad-style service.
Install Code
The following code sets up Etherpad:
- Setting up the environment
- Installing Etherpad
- Configuring a read database (MariaDB) instead of the development db
- Establishing SSL
Read Me: The script will prompt for the domain, subdomain, and SQL password. For security purposes, the SQL password will not display as you type.
#!/bin/bash # source: https://hub.docker.com/r/etherpad/etherpad user_prompts(){ echo "domain: " read -r domain echo "sub-domain: " read -r subdomain echo "SQL Password: " read -s -r sql_password } dependencies="certbot openssl nano nodejs" etherpad_user_setup(){ #source: https://www.howtoforge.com/how-to-install-the-etherpad-collaborative-web-editor-on-rocky-linux-8/#step-3---install-mariadb sudo adduser --system --home /opt/etherpad --create-home etherpad cd /opt/etherpad || exit } system_setup(){ apt update # update system and make sure sudo is installed apt install -y sudo sudo apt update sudo apt upgrade # loop through all the required dependencies if [ -n "$dependencies" ];then for pkg in $dependencies;do echo "Installing $pkg" #install but don't spit out all the noise sudo apt install -y "$pkg" 2&>/dev/null done fi etherpad_user_setup } setup_git(){ # assume location is /opt/etherpad # running install commands as newly created etherpad user sudo -H -u etherpad bash -c "cd /opt/etherpad || exit" sudo -H -u etherpad bash -c "curl -sL https://deb.nodesource.com/setup_14.x | sudo -E bash -" sudo -H -u etherpad bash -c "git clone --branch master https://github.com/ether/etherpad-lite.git" sudo -H -u etherpad bash -c "cd etherpad-lite || exit" sudo -H -u etherpad bash -c "src/bin/run.sh" # create etherpad as a service echo "[Unit] Description=Etherpad, a collaborative web editor. After=syslog.target network.target [Service] Type=simple User=etherpad Group=etherpad WorkingDirectory=/opt/etherpad Environment=NODE_ENV=production ExecStart=/usr/bin/node --experimental-worker /opt/etherpad/etherpad-lite/node_modules/ep_etherpad-lite/node/server.js Restart=always [Install] WantedBy=multi-user.target" | sudo tee -a /etc/systemd/system/etherpad.service sudo systemctl daemon-reload sudo systemctl enable etherpad --now } setup-mariadb(){ sql_db_name="etherpad_lite_db" sql_user="etherpaduser" sudo apt install -y mariadb-server sudo systemctl enable mariadb --now sudo mariadb -e "CREATE DATABASE $sql_db_name DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;" sudo mariadb -e "CREATE USER '$sql_user'@'localhost' identified by '$sql_password';" sudo mariadb -e "GRANT ALL PRIVILEGES ON $sql_db_name.* TO '$sql_user'@'localhost' IDENTIFIED BY '$sql_password';" ##FIXME: remove dirty db #sed -i '/"dbType"/i \/' settings.json ##FIXME: configure settings # "dbType" : "mysql", # "dbSettings" : { # "user": "etherpaduser", # "host": "localhost", # "port": 3306, # "password": "$sql_password", # "database": "$sql_db_name", # "charset": "utf8mb4" # }, #FIXME # "trustProxy": true, #sed -i '/"trustProxy"/s/false/true' settings.json } setup_ssl(){ sudo mkdir -p /var/lib/letsencrypt sudo certbot certonly --standalone --agree-tos --preferred-challenges http -m ssl@"$domain" -d "$subdomain"."$domain" # cert is saved to /etc/letsencrypt/live/$domain sudo openssl dhparam -out /etc/ssl/certs/dhparam.pem 2048 #create a renew cron echo "#!/bin/sh certbot renew --cert-name $domain --webroot -w /var/lib/letsencrypt/ --post-hook systemctl reload nginx "| sudo tee -a /etc/cron.daily/certbot-renew sudo chmod +x /etc/cron.daily/certbot-renew } main(){ user_prompts system_setup setup_git setup-mariadb setup_ssl #set node to production export NODE_ENV=production systemctl start etherpad } main
For further information, visit the official Etherpad site or Docker Hub for Etherpad.