mirror of
https://github.com/mail-in-a-box/mailinabox.git
synced 2025-04-20 02:52:11 +00:00
Add download zonefile
This commit is contained in:
parent
0bd3977cde
commit
db676576ab
@ -743,6 +743,31 @@ paths:
|
|||||||
text/html:
|
text/html:
|
||||||
schema:
|
schema:
|
||||||
type: string
|
type: string
|
||||||
|
/dns/zonefile/{zone}:
|
||||||
|
get:
|
||||||
|
tags:
|
||||||
|
- DNS
|
||||||
|
summary: Get DNS zonefile
|
||||||
|
description: Returns an array of all managed top-level domains.
|
||||||
|
operationId: getDnsZonefile
|
||||||
|
x-codeSamples:
|
||||||
|
- lang: curl
|
||||||
|
source: |
|
||||||
|
curl -X GET "https://{host}/admin/dns/zonefile/<zone>" \
|
||||||
|
-u "<email>:<password>"
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
description: Successful operation
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/DNSZonefileResponse'
|
||||||
|
403:
|
||||||
|
description: Forbidden
|
||||||
|
content:
|
||||||
|
text/html:
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
/dns/update:
|
/dns/update:
|
||||||
post:
|
post:
|
||||||
tags:
|
tags:
|
||||||
@ -2050,6 +2075,8 @@ components:
|
|||||||
items:
|
items:
|
||||||
$ref: '#/components/schemas/Hostname'
|
$ref: '#/components/schemas/Hostname'
|
||||||
description: DNS zones response.
|
description: DNS zones response.
|
||||||
|
DNSZonefileResponse:
|
||||||
|
type: string
|
||||||
DNSSecondaryNameserverResponse:
|
DNSSecondaryNameserverResponse:
|
||||||
type: object
|
type: object
|
||||||
required:
|
required:
|
||||||
|
@ -338,6 +338,12 @@ def dns_get_dump():
|
|||||||
from dns_update import build_recommended_dns
|
from dns_update import build_recommended_dns
|
||||||
return json_response(build_recommended_dns(env))
|
return json_response(build_recommended_dns(env))
|
||||||
|
|
||||||
|
@app.route('/dns/zonefile/<zone>')
|
||||||
|
@authorized_personnel_only
|
||||||
|
def dns_get_zonefile(zone):
|
||||||
|
from dns_update import get_dns_zonefile
|
||||||
|
return json_response(get_dns_zonefile(zone, env))
|
||||||
|
|
||||||
# SSL
|
# SSL
|
||||||
|
|
||||||
@app.route('/ssl/status')
|
@app.route('/ssl/status')
|
||||||
|
@ -564,6 +564,17 @@ $TTL 1800 ; default time to live
|
|||||||
|
|
||||||
return True # file is updated
|
return True # file is updated
|
||||||
|
|
||||||
|
def get_dns_zonefile(zone, env):
|
||||||
|
for domain, fn in get_dns_zones(env):
|
||||||
|
if zone == domain:
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
raise ValueError("%s is not a domain name or a subdomain of a domain name managed by this box." % zone)
|
||||||
|
|
||||||
|
nsd_zonefile = "/etc/nsd/zones/" + zone + ".txt"
|
||||||
|
with open(nsd_zonefile, "r") as f:
|
||||||
|
return f.read()
|
||||||
|
|
||||||
########################################################################
|
########################################################################
|
||||||
|
|
||||||
def write_nsd_conf(zonefiles, additional_records, env):
|
def write_nsd_conf(zonefiles, additional_records, env):
|
||||||
|
@ -89,7 +89,7 @@
|
|||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<div class="col-sm-offset-1 col-sm-11">
|
<div class="col-sm-offset-1 col-sm-11">
|
||||||
<p class="small">
|
<p class="small">
|
||||||
Multiple secondary servers can be separated with commas or spaces (i.e., <code>ns2.hostingcompany.com ns3.hostingcompany.com</code>).
|
Multiple secondary servers can be separated with commas or spaces (i.e., <code>ns2.hostingcompany.com ns3.hostingcompany.com</code>).
|
||||||
To enable zone transfers to additional servers without listing them as secondary nameservers, add an IP address or subnet using <code>xfr:10.20.30.40</code> or <code>xfr:10.0.0.0/8</code>.
|
To enable zone transfers to additional servers without listing them as secondary nameservers, add an IP address or subnet using <code>xfr:10.20.30.40</code> or <code>xfr:10.0.0.0/8</code>.
|
||||||
</p>
|
</p>
|
||||||
<p id="secondarydns-clear-instructions" style="display: none" class="small">
|
<p id="secondarydns-clear-instructions" style="display: none" class="small">
|
||||||
@ -99,6 +99,23 @@
|
|||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
|
<h3>Download zonefile</h3>
|
||||||
|
|
||||||
|
<p>You can download your zonefiles here, for example if you want to host your DNS somewhere else.</p>
|
||||||
|
|
||||||
|
<form class="form-horizontal" role="form" onsubmit="do_download_zonefile(); return false;">
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="downloadZonefile" class="col-sm-1 control-label">Zone</label>
|
||||||
|
<div class="col-sm-10">
|
||||||
|
<select id="downloadZonefile" class="form-control"> </select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<div class="col-sm-offset-1 col-sm-11">
|
||||||
|
<button type="submit" class="btn btn-primary">Download</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
|
||||||
<h3>Custom DNS API</h3>
|
<h3>Custom DNS API</h3>
|
||||||
|
|
||||||
@ -172,10 +189,13 @@ function show_custom_dns() {
|
|||||||
"GET",
|
"GET",
|
||||||
{ },
|
{ },
|
||||||
function(data) {
|
function(data) {
|
||||||
$('#customdnsZone').text('');
|
var selects = ['#customdnsZone', '#downloadZonefile']
|
||||||
for (var i = 0; i < data.length; i++) {
|
for (var i = 0; i < selects.length; i++) {
|
||||||
$('#customdnsZone').append($('<option/>').text(data[i]));
|
$(selects[i]).text('');
|
||||||
}
|
for (var j = 0; j < data.length; j++) {
|
||||||
|
$(selects[i]).append($('<option/>').text(data[j]));
|
||||||
|
}
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
show_current_custom_dns();
|
show_current_custom_dns();
|
||||||
@ -192,7 +212,7 @@ function show_current_custom_dns() {
|
|||||||
$('#custom-dns-current').fadeIn();
|
$('#custom-dns-current').fadeIn();
|
||||||
else
|
else
|
||||||
$('#custom-dns-current').fadeOut();
|
$('#custom-dns-current').fadeOut();
|
||||||
|
|
||||||
var reverse_fqdn = function(el) {
|
var reverse_fqdn = function(el) {
|
||||||
el.qname = el.qname.split('.').reverse().join('.');
|
el.qname = el.qname.split('.').reverse().join('.');
|
||||||
return el;
|
return el;
|
||||||
@ -274,6 +294,22 @@ function do_set_custom_dns(qname, rtype, value, method) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function do_download_zonefile() {
|
||||||
|
var zone = $('#downloadZonefile').val();
|
||||||
|
|
||||||
|
api(
|
||||||
|
"/dns/zonefile/"+ zone,
|
||||||
|
"GET",
|
||||||
|
{},
|
||||||
|
function(data) {
|
||||||
|
if (data == "") return; // nothing updated
|
||||||
|
show_modal_error("Download Zonefile", $("<pre/>").text(data));
|
||||||
|
},
|
||||||
|
function(err) {
|
||||||
|
show_modal_error("Download Zonefile (Error)", $("<pre/>").text(err));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
function show_customdns_rtype_hint() {
|
function show_customdns_rtype_hint() {
|
||||||
$('#customdnsTypeHint').text($("#customdnsType").find('option:selected').attr('data-hint'));
|
$('#customdnsTypeHint').text($("#customdnsType").find('option:selected').attr('data-hint'));
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user