mirror of
https://github.com/simple-login/app.git
synced 2024-09-16 15:11:30 +02:00
162 lines
6.2 KiB
HTML
162 lines
6.2 KiB
HTML
{% extends 'default.html' %}
|
|
|
|
{% block title %}
|
|
Custom Domains
|
|
{% endblock %}
|
|
|
|
{% block head %}
|
|
{% endblock %}
|
|
|
|
{% block default_content %}
|
|
<div class="row">
|
|
<div class="col-md-8 offset-md-2">
|
|
<h1 class="h3"> Custom Domains </h1>
|
|
|
|
{% for custom_domain in custom_domains %}
|
|
<div class="card" style="max-width: 50rem">
|
|
<div class="card-body">
|
|
<h5 class="card-title">
|
|
{{ custom_domain.domain }}
|
|
{% if custom_domain.verified %}
|
|
<i class="fe fe-check" style="color: green"></i>
|
|
{% endif %}
|
|
</h5>
|
|
<h6 class="card-subtitle mb-2 text-muted">
|
|
Created {{ custom_domain.created_at | dt }} <br>
|
|
<span class="font-weight-bold">{{ custom_domain.nb_alias() }}</span> aliases.
|
|
</h6>
|
|
|
|
{% if not custom_domain.verified %}
|
|
<hr>
|
|
<div class="mb-3">Please follow the following steps to set up your domain: </div>
|
|
|
|
<div class="row">
|
|
<div class="col-1">
|
|
<span class="badge badge-primary badge-pill">1</span>
|
|
</div>
|
|
|
|
<div class="col-11">
|
|
Add the following MX DNS record to your domain
|
|
{% for priority, email_server in EMAIL_SERVERS_WITH_PRIORITY %}
|
|
<div class="ml-2 mb-3 p-3" style="background-color: #eee">
|
|
Domain: <em>{{ custom_domain.domain }}</em> <br>
|
|
Priority: 10 <br>
|
|
Target: <em>{{ email_server }}</em> <br>
|
|
</div>
|
|
{% endfor %}
|
|
|
|
Or if you edit your DNS record in text format, use the following code: <br>
|
|
|
|
<pre class="ml-3">{% for priority, email_server in EMAIL_SERVERS_WITH_PRIORITY %}{{ custom_domain.domain }} IN MX {{ priority }} {{ email_server }}<br>{% endfor %}</pre>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="row">
|
|
<div class="col-1"><span class="badge badge-primary badge-pill">2</span></div>
|
|
<div class="col-11">
|
|
<span class="font-weight-bold">[Optional]</span>
|
|
Setup <a href="https://en.wikipedia.org/wiki/Sender_Policy_Framework" target="_blank">
|
|
SPF <i class="fe fe-external-link"></i></a> record.
|
|
This can avoid emails forwarded to your personal inbox classified as spam. <br>
|
|
Please note that some email providers can still classify these forwards as spam, in this case
|
|
do not hesitate to create rules to avoid these emails mistakenly gone into spam.
|
|
You can find how to whitelist a domain on
|
|
<a href="https://www.simplelogin.io/help" target="_blank">Whitelist domain<i class="fe fe-external-link"></i></a><br>
|
|
|
|
Please add the following TXT DNS record to your domain:
|
|
|
|
<div class="ml-3 mb-2 p-3" style="background-color: #eee">
|
|
Domain: <em>{{ custom_domain.domain }}</em> <br>
|
|
Value:
|
|
<em>
|
|
v=spf1
|
|
{% for priority, email_server in EMAIL_SERVERS_WITH_PRIORITY %}
|
|
include:{{ email_server[:-1] }}
|
|
{% endfor %} -all
|
|
</em>
|
|
</div>
|
|
|
|
Or if you edit your DNS record in text format, use the following code: <br>
|
|
|
|
<pre class="ml-3">{{ custom_domain.domain }} IN TXT "v=spf1 {% for priority, email_server in EMAIL_SERVERS_WITH_PRIORITY %}include:{{ email_server[:-1] }} {% endfor %}-all"</pre>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="row">
|
|
<div class="col-1">
|
|
<span class="badge badge-primary badge-pill mr-2">3</span>
|
|
</div>
|
|
|
|
<div class="col-11">
|
|
Verify 👇🏽
|
|
<form method="post">
|
|
<input type="hidden" name="form-name" value="check-domain">
|
|
<input type="hidden" name="custom-domain-id" value="{{ custom_domain.id }}">
|
|
<button type="submit" class="btn btn-primary">Verify</button>
|
|
</form>
|
|
|
|
{% if custom_domain.id in errors %}
|
|
<div class="text-danger">
|
|
{{ errors.get(custom_domain.id) }}
|
|
</div>
|
|
{% endif %}
|
|
|
|
As the change could take up to 24 hours, do not hesitate to come back to this page and verify again.
|
|
</div>
|
|
</div>
|
|
{% endif %}
|
|
</div>
|
|
|
|
<div class="card-footer">
|
|
<div class="row">
|
|
<div class="col">
|
|
<form method="post">
|
|
<input type="hidden" name="form-name" value="delete">
|
|
<input type="hidden" name="custom-domain-id" value="{{ custom_domain.id }}">
|
|
<span class="card-link btn btn-link float-right delete-custom-domain">
|
|
Delete
|
|
</span>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
{% endfor %}
|
|
|
|
<hr>
|
|
|
|
<form method="post">
|
|
{{ new_custom_domain_form.csrf_token }}
|
|
<input type="hidden" name="form-name" value="create">
|
|
|
|
<label class="form-label">Domain</label>
|
|
<small>Please use full path domain, for ex <em>my-subdomain.my-domain.com</em></small>
|
|
|
|
{{ new_custom_domain_form.domain(class="form-control", placeholder="my-domain.com") }}
|
|
{{ render_field_errors(new_custom_domain_form.domain) }}
|
|
<button class="btn btn-lg btn-success mt-2">Create</button>
|
|
</form>
|
|
|
|
|
|
</div>
|
|
|
|
</div>
|
|
{% endblock %}
|
|
|
|
{% block script %}
|
|
<script>
|
|
$(".delete-custom-domain").on("click", function (e) {
|
|
notie.confirm({
|
|
text: "All aliases associated with this domain will be also deleted, " +
|
|
" please confirm",
|
|
cancelCallback: () => {
|
|
// nothing to do
|
|
},
|
|
submitCallback: () => {
|
|
$(this).closest("form").submit();
|
|
}
|
|
});
|
|
});
|
|
</script>
|
|
{% endblock %} |