diff --git a/ct/simplelogin.sh b/ct/simplelogin.sh new file mode 100644 index 000000000..7c2831834 --- /dev/null +++ b/ct/simplelogin.sh @@ -0,0 +1,84 @@ +#!/usr/bin/env bash +COMMUNITY_SCRIPTS_URL="${COMMUNITY_SCRIPTS_URL:-https://git.community-scripts.org/community-scripts/ProxmoxVED/raw/branch/main}" +source <(curl -fsSL "$COMMUNITY_SCRIPTS_URL/misc/build.func") +# Copyright (c) 2021-2026 community-scripts ORG +# Author: MickLesk (CanbiZ) +# License: MIT | https://github.com/community-scripts/ProxmoxVED/raw/main/LICENSE +# Source: https://github.com/simple-login/app + +APP="SimpleLogin" +var_tags="${var_tags:-email;privacy;alias}" +var_cpu="${var_cpu:-2}" +var_ram="${var_ram:-2048}" +var_disk="${var_disk:-10}" +var_os="${var_os:-debian}" +var_version="${var_version:-13}" +var_unprivileged="${var_unprivileged:-1}" + +header_info "$APP" +variables +color +catch_errors + +function update_script() { + header_info + check_container_storage + check_container_resources + + if [[ ! -d /opt/simplelogin ]]; then + msg_error "No ${APP} Installation Found!" + exit + fi + + if check_for_gh_release "simplelogin" "simple-login/app"; then + msg_info "Stopping Services" + systemctl stop simplelogin-webapp simplelogin-email simplelogin-job + msg_ok "Stopped Services" + + msg_info "Backing up Data" + cp /opt/simplelogin/.env /opt/simplelogin_env.bak + cp -r /opt/simplelogin/uploads /opt/simplelogin_uploads.bak 2>/dev/null || true + cp -r /opt/simplelogin/dkim /opt/simplelogin_dkim.bak 2>/dev/null || true + cp /opt/simplelogin/openid-rsa.key /opt/simplelogin_openid-rsa.key.bak 2>/dev/null || true + cp /opt/simplelogin/openid-rsa.pub /opt/simplelogin_openid-rsa.pub.bak 2>/dev/null || true + msg_ok "Backed up Data" + + CLEAN_INSTALL=1 fetch_and_deploy_gh_release "simplelogin" "simple-login/app" + + msg_info "Installing Dependencies" + cd /opt/simplelogin + $STD uv sync --locked --no-dev + msg_ok "Installed Dependencies" + + msg_info "Running Database Migrations" + cd /opt/simplelogin + cp /opt/simplelogin_env.bak /opt/simplelogin/.env + $STD .venv/bin/flask db upgrade + msg_ok "Ran Database Migrations" + + msg_info "Restoring Data" + mkdir -p /opt/simplelogin/uploads + cp -r /opt/simplelogin_uploads.bak/. /opt/simplelogin/uploads 2>/dev/null || true + cp -r /opt/simplelogin_dkim.bak/. /opt/simplelogin/dkim 2>/dev/null || true + cp /opt/simplelogin_openid-rsa.key.bak /opt/simplelogin/openid-rsa.key 2>/dev/null || true + cp /opt/simplelogin_openid-rsa.pub.bak /opt/simplelogin/openid-rsa.pub 2>/dev/null || true + rm -f /opt/simplelogin_env.bak /opt/simplelogin_openid-rsa.key.bak /opt/simplelogin_openid-rsa.pub.bak + rm -rf /opt/simplelogin_uploads.bak /opt/simplelogin_dkim.bak + msg_ok "Restored Data" + + msg_info "Starting Services" + systemctl start simplelogin-webapp simplelogin-email simplelogin-job + msg_ok "Started Services" + msg_ok "Updated successfully!" + fi + exit +} + +start +build_container +description + +msg_ok "Completed Successfully!\n" +echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}" +echo -e "${INFO}${YW} Access it using the following URL:${CL}" +echo -e "${TAB}${GATEWAY}${BGN}http://${IP}${CL}" diff --git a/frontend/public/json/simplelogin.json b/frontend/public/json/simplelogin.json new file mode 100644 index 000000000..6713bbd9d --- /dev/null +++ b/frontend/public/json/simplelogin.json @@ -0,0 +1,48 @@ +{ + "name": "SimpleLogin", + "slug": "simplelogin", + "categories": [ + 6 + ], + "date_created": "2026-02-22", + "type": "ct", + "updateable": true, + "privileged": false, + "interface_port": 80, + "documentation": "https://github.com/simple-login/app/blob/master/docs/", + "website": "https://simplelogin.io/", + "logo": "https://cdn.jsdelivr.net/gh/selfhst/icons@main/webp/simplelogin.webp", + "config_path": "/opt/simplelogin/.env", + "description": "SimpleLogin is an open-source email alias solution that lets you create anonymous email aliases to protect your real email address from spam, trackers and data breaches.", + "install_methods": [ + { + "type": "default", + "script": "ct/simplelogin.sh", + "resources": { + "cpu": 2, + "ram": 2048, + "hdd": 10, + "os": "Debian", + "version": "13" + } + } + ], + "default_credentials": { + "username": null, + "password": null + }, + "notes": [ + { + "text": "After installation, update EMAIL_DOMAIN in /opt/simplelogin/.env with your actual domain and configure DNS (MX, SPF, DKIM) accordingly.", + "type": "warning" + }, + { + "text": "DKIM keys are generated at /opt/simplelogin/dkim/. Add the public key as a TXT record: dkim._domainkey.yourdomain.com", + "type": "info" + }, + { + "text": "Create your first admin account by visiting the web interface and registering.", + "type": "info" + } + ] +} \ No newline at end of file diff --git a/install/simplelogin-install.sh b/install/simplelogin-install.sh new file mode 100644 index 000000000..d10524ad9 --- /dev/null +++ b/install/simplelogin-install.sh @@ -0,0 +1,197 @@ +#!/usr/bin/env bash + +# Copyright (c) 2021-2026 community-scripts ORG +# Author: MickLesk (CanbiZ) +# License: MIT | https://github.com/community-scripts/ProxmoxVED/raw/main/LICENSE +# Source: https://github.com/simple-login/app + +source /dev/stdin <<<"$FUNCTIONS_FILE_PATH" +color +verb_ip6 +catch_errors +setting_up_container +network_check +update_os + +msg_info "Installing Dependencies" +echo "postfix postfix/mailname string $(hostname -f)" | debconf-set-selections +echo "postfix postfix/main_mailer_type string Internet Site" | debconf-set-selections +$STD apt install -y \ + build-essential \ + libre2-dev \ + libpq-dev \ + cmake \ + pkg-config \ + git \ + redis-server \ + nginx \ + postfix \ + postfix-pgsql \ + opendkim-tools +msg_ok "Installed Dependencies" + +PG_VERSION="16" setup_postgresql +APPLICATION="simplelogin" PG_DB_NAME="simplelogin" PG_DB_USER="simplelogin" setup_postgresql_db +PYTHON_VERSION="3.12" setup_uv +NODE_VERSION="22" setup_nodejs + +fetch_and_deploy_gh_release "simplelogin" "simple-login/app" + +msg_info "Installing SimpleLogin (Patience)" +cd /opt/simplelogin +$STD uv sync --locked --no-dev + +if [[ -f /opt/simplelogin/static/package.json ]]; then + cd /opt/simplelogin/static + $STD npm ci || $STD npm install +fi +msg_ok "Installed SimpleLogin" + +msg_info "Configuring SimpleLogin" +FLASK_SECRET=$(openssl rand -hex 32) + +mkdir -p /opt/simplelogin/dkim +$STD opendkim-genkey -b 2048 -d example.com -s dkim -D /opt/simplelogin/dkim +chmod 600 /opt/simplelogin/dkim/dkim.private + +$STD openssl genrsa -out /opt/simplelogin/openid-rsa.key 2048 +$STD openssl rsa -in /opt/simplelogin/openid-rsa.key -pubout -out /opt/simplelogin/openid-rsa.pub + +mkdir -p /opt/simplelogin/uploads /opt/simplelogin/.gnupg +chmod 700 /opt/simplelogin/.gnupg + +cat </opt/simplelogin/.env +URL=http://${LOCAL_IP} +EMAIL_DOMAIN=example.com +SUPPORT_EMAIL=support@example.com +DB_URI=postgresql://${PG_DB_USER}:${PG_DB_PASS}@localhost/${PG_DB_NAME} +FLASK_SECRET=${FLASK_SECRET} +DKIM_PRIVATE_KEY_PATH=/opt/simplelogin/dkim/dkim.private +GNUPGHOME=/opt/simplelogin/.gnupg +LOCAL_FILE_UPLOAD=true +UPLOAD_DIR=/opt/simplelogin/uploads +DISABLE_ALIAS_SUFFIX=1 +WORDS_FILE_PATH=/opt/simplelogin/local_data/words.txt +NAMESERVERS=1.1.1.1 +MEM_STORE_URI=redis://localhost:6379/1 +OPENID_PRIVATE_KEY_PATH=/opt/simplelogin/openid-rsa.key +OPENID_PUBLIC_KEY_PATH=/opt/simplelogin/openid-rsa.pub +EOF + +cd /opt/simplelogin +$STD .venv/bin/flask db upgrade +$STD .venv/bin/python init_app.py +msg_ok "Configured SimpleLogin" + +msg_info "Configuring Postfix" +cat </etc/postfix/pgsql-relay-domains.cf +hosts = localhost +dbname = ${PG_DB_NAME} +user = ${PG_DB_USER} +password = ${PG_DB_PASS} +query = SELECT domain FROM custom_domain WHERE domain='%s' AND verified=true +EOF + +cat </etc/postfix/pgsql-transport-maps.cf +hosts = localhost +dbname = ${PG_DB_NAME} +user = ${PG_DB_USER} +password = ${PG_DB_PASS} +query = SELECT 'smtp:[127.0.0.1]:20381' FROM custom_domain WHERE domain='%s' AND verified=true +EOF + +chmod 640 /etc/postfix/pgsql-*.cf + +cat </etc/postfix/transport +example.com smtp:[127.0.0.1]:20381 +EOF +$STD postmap /etc/postfix/transport + +postconf -e "relay_domains = example.com, pgsql:/etc/postfix/pgsql-relay-domains.cf" +postconf -e "transport_maps = hash:/etc/postfix/transport, pgsql:/etc/postfix/pgsql-transport-maps.cf" +postconf -e "smtpd_recipient_restrictions = permit_mynetworks, reject_unauth_destination" +$STD systemctl restart postfix +msg_ok "Configured Postfix" + +msg_info "Creating Services" +cat <<'EOF' >/etc/systemd/system/simplelogin-webapp.service +[Unit] +Description=SimpleLogin Web Application +After=network.target postgresql.service redis-server.service +Requires=postgresql.service redis-server.service + +[Service] +Type=simple +WorkingDirectory=/opt/simplelogin +ExecStart=/opt/simplelogin/.venv/bin/gunicorn wsgi:app -b 127.0.0.1:7777 -w 2 --timeout 120 +Restart=always +RestartSec=5 + +[Install] +WantedBy=multi-user.target +EOF + +cat <<'EOF' >/etc/systemd/system/simplelogin-email.service +[Unit] +Description=SimpleLogin Email Handler +After=network.target postgresql.service redis-server.service postfix.service +Requires=postgresql.service redis-server.service + +[Service] +Type=simple +WorkingDirectory=/opt/simplelogin +ExecStart=/opt/simplelogin/.venv/bin/python email_handler.py +Restart=always +RestartSec=5 + +[Install] +WantedBy=multi-user.target +EOF + +cat <<'EOF' >/etc/systemd/system/simplelogin-job.service +[Unit] +Description=SimpleLogin Job Runner +After=network.target postgresql.service redis-server.service +Requires=postgresql.service redis-server.service + +[Service] +Type=simple +WorkingDirectory=/opt/simplelogin +ExecStart=/opt/simplelogin/.venv/bin/python job_runner.py +Restart=always +RestartSec=5 + +[Install] +WantedBy=multi-user.target +EOF + +systemctl enable -q --now redis-server simplelogin-webapp simplelogin-email simplelogin-job +msg_ok "Created Services" + +msg_info "Configuring Nginx" +cat <<'EOF' >/etc/nginx/sites-available/simplelogin.conf +server { + listen 80 default_server; + server_name _; + + client_max_body_size 10M; + + location / { + proxy_pass http://127.0.0.1:7777; + proxy_http_version 1.1; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } +} +EOF +ln -sf /etc/nginx/sites-available/simplelogin.conf /etc/nginx/sites-enabled/ +rm -f /etc/nginx/sites-enabled/default +$STD nginx -t +$STD systemctl enable --now nginx +msg_ok "Configured Nginx" + +motd_ssh +customize +cleanup_lxc