#!/bin/bash PUBLIC_INTERFACE="eth0" # Your host's public network interface # Configure firewall echo "[HOST] Configuring firewall..." sudo iptables -A FORWARD -i $PUBLIC_INTERFACE -o lxcbr0 -p tcp -m multiport --dports 25,80,110,143,465,587,993,995,4190 -j ACCEPT sudo iptables -A FORWARD -i lxcbr0 -o $PUBLIC_INTERFACE -m state --state RELATED,ESTABLISHED -j ACCEPT sudo iptables -t nat -A POSTROUTING -o $PUBLIC_INTERFACE -j MASQUERADE # IPv6 firewall sudo ip6tables -A FORWARD -i $PUBLIC_INTERFACE -o lxcbr0 -p tcp -m multiport --dports 25,80,110,143,465,587,993,995,4190 -j ACCEPT sudo ip6tables -A FORWARD -i lxcbr0 -o $PUBLIC_INTERFACE -m state --state RELATED,ESTABLISHED -j ACCEPT # Save iptables rules permanently (adjust based on your distro) if command -v iptables-persistent >/dev/null; then sudo iptables-save | sudo tee /etc/iptables/rules.v4 sudo ip6tables-save | sudo tee /etc/iptables/rules.v6 fi # ------------------------- CONTAINER SETUP ------------------------- # Create directory structure echo "[CONTAINER] Creating directories..." HOST_BASE="/opt/email" HOST_DATA="$HOST_BASE/data" HOST_CONF="$HOST_BASE/conf" HOST_LOGS="$HOST_BASE/logs" sudo mkdir -p "$HOST_DATA" "$HOST_CONF" "$HOST_LOGS" sudo chmod -R 750 "$HOST_BASE" # Launch container echo "[CONTAINER] Launching LXC container..." lxc launch images:debian/12 "$PARAM_TENANT"-email -c security.privileged=true sleep 15 echo "[CONTAINER] Installing Stalwart Mail..." lxc exec "$PARAM_TENANT"-email -- bash -c " echo "nameserver $PARAM_DNS_INTERNAL_IP" > /etc/resolv.conf apt install resolvconf -y apt-get update && apt-get install -y wget libcap2-bin wget -O /tmp/stalwart.tar.gz https://github.com/stalwartlabs/stalwart/releases/download/v0.13.1/stalwart-x86_64-unknown-linux-gnu.tar.gz tar -xzf /tmp/stalwart.tar.gz -C /tmp mkdir -p /opt/gbo/bin mv /tmp/stalwart /opt/gbo/bin/stalwart chmod +x /opt/gbo/bin/stalwart sudo setcap 'cap_net_bind_service=+ep' /opt/gbo/bin/stalwart rm /tmp/stalwart.tar.gz useradd --system --no-create-home --shell /bin/false email mkdir -p /opt/gbo/data /opt/gbo/conf /opt/gbo/logs chown -R email:email /opt/gbo/data /opt/gbo/conf /opt/gbo/logs /opt/gbo/bin " # Set permissions echo "[CONTAINER] Setting permissions..." EMAIL_UID=$(lxc exec "$PARAM_TENANT"-email -- id -u email) EMAIL_GID=$(lxc exec "$PARAM_TENANT"-email -- id -g email) HOST_EMAIL_UID=$((100000 + EMAIL_UID)) HOST_EMAIL_GID=$((100000 + EMAIL_GID)) sudo chown -R "$HOST_EMAIL_UID:$HOST_EMAIL_GID" "$HOST_BASE" # Mount directories echo "[CONTAINER] Mounting directories..." lxc config device add "$PARAM_TENANT"-email emaildata disk source="$HOST_DATA" path=/opt/gbo/data lxc config device add "$PARAM_TENANT"-email emailconf disk source="$HOST_CONF" path=/opt/gbo/conf lxc config device add "$PARAM_TENANT"-email emaillogs disk source="$HOST_LOGS" path=/opt/gbo/logs # Create systemd service echo "[CONTAINER] Creating email service..." lxc exec "$PARAM_TENANT"-email -- bash -c " chown -R email:email /opt/gbo/data /opt/gbo/conf /opt/gbo/logs /opt/gbo/bin cat > /etc/systemd/system/email.service </dev/null || true lxc config device add "$PARAM_TENANT"-email "port-$port" proxy \ listen=tcp:0.0.0.0:$port \ listen=tcp:[::]:$port \ connect=tcp:127.0.0.1:$port done