diff --git a/app/dashboard/__init__.py b/app/dashboard/__init__.py index 2705063e..09eab975 100644 --- a/app/dashboard/__init__.py +++ b/app/dashboard/__init__.py @@ -7,4 +7,5 @@ from .views import ( alias_log, unsubscribe, api_key, + custom_domain, ) diff --git a/app/dashboard/templates/dashboard/custom_domain.html b/app/dashboard/templates/dashboard/custom_domain.html new file mode 100644 index 00000000..4b1dca2a --- /dev/null +++ b/app/dashboard/templates/dashboard/custom_domain.html @@ -0,0 +1,127 @@ +{% extends 'default.html' %} + +{% block title %} + Custom Domains +{% endblock %} + +{% block head %} +{% endblock %} + +{% block default_content %} +
+ {% for priority, email_server in EMAIL_SERVERS_WITH_PRIORITY %} + {{ custom_domain.domain }} IN MX {{ priority }} {{ email_server }} + {% endfor %} ++
redirect_uri must be HTTPS for security reason.
diff --git a/app/dns_utils.py b/app/dns_utils.py
new file mode 100644
index 00000000..3fe5512f
--- /dev/null
+++ b/app/dns_utils.py
@@ -0,0 +1,13 @@
+import dns.resolver
+
+
+def get_mx_domains(hostname) -> [str]:
+ answers = dns.resolver.query(hostname, "MX")
+ ret = []
+
+ for a in answers:
+ record = a.to_text() # for ex '20 alt2.aspmx.l.google.com.'
+ r = record.split(" ")[1] # alt2.aspmx.l.google.com.
+ ret.append(r)
+
+ return ret
diff --git a/app/models.py b/app/models.py
index e80cb36f..44ed2806 100644
--- a/app/models.py
+++ b/app/models.py
@@ -209,6 +209,9 @@ class User(db.Model, ModelMixin, UserMixin):
sub = Subscription.get_by(user_id=self.id)
return sub
+ def verified_custom_domains(self):
+ return CustomDomain.query.filter_by(user_id=self.id, verified=True).all()
+
def __repr__(self):
return f"