mirror of
https://github.com/simple-login/app.git
synced 2024-11-10 21:27:10 +01:00
122 lines
4.9 KiB
Python
122 lines
4.9 KiB
Python
from flask import render_template, request, redirect, url_for, flash
|
|
from flask_login import login_required, current_user
|
|
from flask_wtf import FlaskForm
|
|
from wtforms import StringField, validators
|
|
|
|
from app.config import EMAIL_SERVERS_WITH_PRIORITY
|
|
from app.dashboard.base import dashboard_bp
|
|
from app.db import Session
|
|
from app.email_utils import get_email_domain_part
|
|
from app.log import LOG
|
|
from app.models import CustomDomain, Mailbox, DomainMailbox, SLDomain
|
|
|
|
|
|
class NewCustomDomainForm(FlaskForm):
|
|
domain = StringField(
|
|
"domain", validators=[validators.DataRequired(), validators.Length(max=128)]
|
|
)
|
|
|
|
|
|
@dashboard_bp.route("/custom_domain", methods=["GET", "POST"])
|
|
@login_required
|
|
def custom_domain():
|
|
custom_domains = CustomDomain.filter_by(
|
|
user_id=current_user.id, is_sl_subdomain=False
|
|
).all()
|
|
mailboxes = current_user.mailboxes()
|
|
new_custom_domain_form = NewCustomDomainForm()
|
|
|
|
errors = {}
|
|
|
|
if request.method == "POST":
|
|
if request.form.get("form-name") == "create":
|
|
if not current_user.is_premium():
|
|
flash("Only premium plan can add custom domain", "warning")
|
|
return redirect(url_for("dashboard.custom_domain"))
|
|
|
|
if new_custom_domain_form.validate():
|
|
new_domain = new_custom_domain_form.domain.data.lower().strip()
|
|
|
|
if new_domain.startswith("http://"):
|
|
new_domain = new_domain[len("http://") :]
|
|
|
|
if new_domain.startswith("https://"):
|
|
new_domain = new_domain[len("https://") :]
|
|
|
|
if SLDomain.get_by(domain=new_domain):
|
|
flash("A custom domain cannot be a built-in domain.", "error")
|
|
elif CustomDomain.get_by(domain=new_domain):
|
|
flash(f"{new_domain} already used", "error")
|
|
elif get_email_domain_part(current_user.email) == new_domain:
|
|
flash(
|
|
"You cannot add a domain that you are currently using for your personal email. "
|
|
"Please change your personal email to your real email",
|
|
"error",
|
|
)
|
|
elif Mailbox.filter(
|
|
Mailbox.verified.is_(True), Mailbox.email.endswith(f"@{new_domain}")
|
|
).first():
|
|
flash(
|
|
f"{new_domain} already used in a SimpleLogin mailbox", "error"
|
|
)
|
|
else:
|
|
new_custom_domain = CustomDomain.create(
|
|
domain=new_domain, user_id=current_user.id
|
|
)
|
|
# new domain has ownership verified if its parent has the ownership verified
|
|
for root_cd in current_user.custom_domains:
|
|
if (
|
|
new_domain.endswith("." + root_cd.domain)
|
|
and root_cd.ownership_verified
|
|
):
|
|
LOG.i(
|
|
"%s ownership verified thanks to %s",
|
|
new_custom_domain,
|
|
root_cd,
|
|
)
|
|
new_custom_domain.ownership_verified = True
|
|
|
|
Session.commit()
|
|
|
|
mailbox_ids = request.form.getlist("mailbox_ids")
|
|
if mailbox_ids:
|
|
# check if mailbox is not tempered with
|
|
mailboxes = []
|
|
for mailbox_id in mailbox_ids:
|
|
mailbox = Mailbox.get(mailbox_id)
|
|
if (
|
|
not mailbox
|
|
or mailbox.user_id != current_user.id
|
|
or not mailbox.verified
|
|
):
|
|
flash("Something went wrong, please retry", "warning")
|
|
return redirect(url_for("dashboard.custom_domain"))
|
|
mailboxes.append(mailbox)
|
|
|
|
for mailbox in mailboxes:
|
|
DomainMailbox.create(
|
|
domain_id=new_custom_domain.id, mailbox_id=mailbox.id
|
|
)
|
|
|
|
Session.commit()
|
|
|
|
flash(
|
|
f"New domain {new_custom_domain.domain} is created", "success"
|
|
)
|
|
|
|
return redirect(
|
|
url_for(
|
|
"dashboard.domain_detail_dns",
|
|
custom_domain_id=new_custom_domain.id,
|
|
)
|
|
)
|
|
|
|
return render_template(
|
|
"dashboard/custom_domain.html",
|
|
custom_domains=custom_domains,
|
|
new_custom_domain_form=new_custom_domain_form,
|
|
EMAIL_SERVERS_WITH_PRIORITY=EMAIL_SERVERS_WITH_PRIORITY,
|
|
errors=errors,
|
|
mailboxes=mailboxes,
|
|
)
|