Added first version of the script
This commit is contained in:
Executable
+58
@@ -0,0 +1,58 @@
|
||||
#!/bin/bash
|
||||
|
||||
set -e
|
||||
|
||||
# Ensure script is run as root
|
||||
if [[ "$EUID" -ne 0 ]]; then
|
||||
echo "Please run as root"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "=== Let's Encrypt + Cloudflare setup ==="
|
||||
|
||||
# Ask for domain
|
||||
read -p "Enter the FQDN (e.g. example.com or sub.example.com): " DOMAIN
|
||||
|
||||
if [[ -z "$DOMAIN" ]]; then
|
||||
echo "Domain cannot be empty"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Ask for Cloudflare API token/key
|
||||
read -p "Enter your Cloudflare API Token/Key: " CF_API_KEY
|
||||
|
||||
if [[ -z "$CF_API_KEY" ]]; then
|
||||
echo "API key cannot be empty"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "Installing dependencies..."
|
||||
apt update
|
||||
apt install -y python3 python3-dev python3-venv libaugeas-dev gcc
|
||||
|
||||
echo "Setting up virtual environment..."
|
||||
python3 -m venv /opt/certbot/
|
||||
/opt/certbot/bin/pip install --upgrade pip
|
||||
/opt/certbot/bin/pip install certbot
|
||||
/opt/certbot/bin/pip install certbot-dns-cloudflare
|
||||
|
||||
# Symlink certbot
|
||||
ln -sf /opt/certbot/bin/certbot /usr/bin/certbot
|
||||
|
||||
echo "Creating Cloudflare credentials file..."
|
||||
mkdir -p /root/certbot-cloudflare/
|
||||
|
||||
cat <<EOF > /root/certbot-cloudflare/cloudflare.ini
|
||||
dns_cloudflare_api_token = $CF_API_KEY
|
||||
EOF
|
||||
|
||||
# Secure the credentials file
|
||||
chmod 600 /root/certbot-cloudflare/cloudflare.ini
|
||||
|
||||
echo "Requesting certificate for $DOMAIN ..."
|
||||
certbot certonly \
|
||||
--dns-cloudflare \
|
||||
--dns-cloudflare-credentials /root/certbot-cloudflare/cloudflare.ini \
|
||||
-d "$DOMAIN"
|
||||
|
||||
echo "Done! Certificate setup completed for $DOMAIN"
|
||||
Reference in New Issue
Block a user