277 lines
15 KiB
HTML
277 lines
15 KiB
HTML
{% extends "base.html" %}
|
|
{% set active_page = "new_domain" %}
|
|
{% block title %}<title>Create Zone - {{ SITE_NAME }}</title>{% endblock %}
|
|
|
|
{% block dashboard_stat %}
|
|
<div class="content-header">
|
|
<div class="container-fluid">
|
|
<div class="row mb-2">
|
|
<div class="col-sm-6">
|
|
<h1 class="m-0 text-dark">
|
|
Create Zone
|
|
</h1>
|
|
</div>
|
|
<div class="col-sm-6">
|
|
<ol class="breadcrumb float-sm-right">
|
|
<li class="breadcrumb-item"><a href="{{ url_for('dashboard.dashboard') }}">Dashboard</a></li>
|
|
<li class="breadcrumb-item active">New Zone</li>
|
|
</ol>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endblock %}
|
|
|
|
{% block content %}
|
|
<section class="content">
|
|
<div class="container-fluid">
|
|
<div class="row">
|
|
<div class="col-12 col-sm-6 col-lg-4">
|
|
<form role="form" method="post" action="{{ url_for('domain.add') }}">
|
|
<input type="hidden" name="_csrf_token" value="{{ csrf_token() }}">
|
|
<div class="card card-outline card-primary shadow">
|
|
<div class="card-header">
|
|
<h3 class="card-title">Zone Editor</h3>
|
|
</div>
|
|
<!-- /.card-header -->
|
|
<div class="card-body">
|
|
<div class="form-group">
|
|
<label for="domain_name">Zone Name</label>
|
|
<input type="text" class="form-control" name="domain_name" id="domain_name"
|
|
placeholder="Enter a valid zone name (required)">
|
|
</div>
|
|
{% if domain_override_toggle == True %}
|
|
<div class="form-group">
|
|
<input type="checkbox" id="domain_override" name="domain_override"
|
|
class="checkbox">
|
|
|
|
<label for="domain_override">Zone Override Record</label>
|
|
</div>
|
|
{% endif %}
|
|
<div class="form-group">
|
|
<label for="selAccount">Account</label>
|
|
<select name="accountid" id="selAccount" class="form-control">
|
|
<option value="0">- No Account -</option>
|
|
{% for account in accounts %}
|
|
<option value="{{ account.id }}">{{ account.name }}</option>
|
|
{% endfor %}
|
|
</select>
|
|
</div>
|
|
<div class="form-group">
|
|
<label>Zone Type</label>
|
|
<div class="radio">
|
|
<label>
|
|
<input type="radio" name="radio_type" id="radio_type_native" value="native"
|
|
checked>
|
|
Native
|
|
</label>
|
|
</div>
|
|
<div class="radio">
|
|
<label>
|
|
<input type="radio" name="radio_type" id="radio_type_primary"
|
|
value="primary">
|
|
Primary
|
|
</label>
|
|
</div>
|
|
<div class="radio">
|
|
<label>
|
|
<input type="radio" name="radio_type" id="radio_type_secondary"
|
|
value="slave">
|
|
Secondary
|
|
</label>
|
|
</div>
|
|
</div>
|
|
<div class="form-group" style="display: none;" id="domain_master_address_div">
|
|
<input type="text" class="form-control" name="domain_master_address"
|
|
id="domain_master_address"
|
|
placeholder="Enter valid Primary Server IP addresses (separated by commas)">
|
|
</div>
|
|
<div class="form-group">
|
|
<label for="domain_template">Zone Template</label>
|
|
<select class="form-control" id="domain_template" name="domain_template">
|
|
<option value="0">No template</option>
|
|
{% for template in templates %}
|
|
<option value="{{ template.id }}">{{ template.name }}</option>
|
|
{% endfor %}
|
|
</select>
|
|
</div>
|
|
<div class="form-group">
|
|
<label>SOA-EDIT-API</label>
|
|
<div class="radio">
|
|
<label>
|
|
<input type="radio" name="radio_type_soa_edit_api" id="radio_default"
|
|
value="DEFAULT" checked>
|
|
DEFAULT
|
|
</label>
|
|
</div>
|
|
<div class="radio">
|
|
<label>
|
|
<input type="radio" name="radio_type_soa_edit_api" id="radio_increase"
|
|
value="INCREASE">
|
|
INCREASE
|
|
</label>
|
|
</div>
|
|
<div class="radio">
|
|
<label>
|
|
<input type="radio" name="radio_type_soa_edit_api" id="radio_epoch"
|
|
value="EPOCH">
|
|
EPOCH
|
|
</label>
|
|
</div>
|
|
<div class="radio">
|
|
<label>
|
|
<input type="radio" name="radio_type_soa_edit_api" id="radio_off"
|
|
value="OFF"> OFF
|
|
</label>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<!-- /.card-body -->
|
|
<div class="card-footer">
|
|
<button type="button" title="Cancel" class="btn btn-secondary"
|
|
onclick="window.location.href='{{ url_for('dashboard.dashboard') }}'">
|
|
<i class="fa-solid fa-window-close"></i> Cancel
|
|
</button>
|
|
<button type="submit" title="Create Zone" class="btn btn-primary float-right">
|
|
<i class="fa-solid fa-save"></i> Create Zone
|
|
</button>
|
|
</div>
|
|
<!-- /.card-footer -->
|
|
</div>
|
|
<!-- /.card -->
|
|
</form>
|
|
</div>
|
|
<!-- /.col -->
|
|
<div class="col-12 col-sm-6 col-lg-8">
|
|
<div class="card card-outline card-secondary shadow">
|
|
<div class="card-header">
|
|
<h3 class="card-title">Zone Editor Help</h3>
|
|
</div>
|
|
<!-- /.card-header -->
|
|
<div class="card-body">
|
|
<dl class="dl-horizontal">
|
|
<dt>Zone Name</dt>
|
|
<dd>Enter your zone name in the format of name.tld (eg. powerdns-admin.com). You can
|
|
also enter sublevel zones to create delegate zones (eg. sub.powerdns-admin.com)
|
|
which can be useful for delegating control to other users.
|
|
</dd>
|
|
<dt>Zone Override Record</dt>
|
|
<dd>When enabled, this will allow the user to by-pass validation errors if the user
|
|
doesn't have administration rights to a parent zone.
|
|
</dd>
|
|
<dt>Account</dt>
|
|
<dd>Specifies the PowerDNS account value to use for the zone.</dd>
|
|
<dt>Zone Type</dt>
|
|
<dd>The type decides how the zone will be replicated across multiple DNS servers.
|
|
<ul>
|
|
<li>
|
|
<strong>Native</strong> - The server will not perform any Primary or Secondary
|
|
zone functions.
|
|
</li>
|
|
<li>
|
|
<strong>Primary</strong> - The server will serve as the Primary and will send
|
|
zone transfers (AXFRs) to other servers configured as secondaries.
|
|
</li>
|
|
<li>
|
|
<strong>Secondary</strong> - The server will serve as the Secondary and will
|
|
request and receive zone transfers (AXFRs) from other servers configured as
|
|
Primaries.
|
|
</li>
|
|
</ul>
|
|
</dd>
|
|
<dt>Zone Template</dt>
|
|
<dd>Specifies the existing zone template which this zone should initially be replicated
|
|
from.
|
|
</dd>
|
|
<dt>SOA-EDIT-API</dt>
|
|
<dd>The SOA-EDIT-API setting defines how the SOA serial number will be updated after a
|
|
change is
|
|
made to the zone.
|
|
<ul>
|
|
<li>
|
|
<strong>DEFAULT</strong> - Generate a soa serial of YYYYMMDD01. If the current serial
|
|
is lower than
|
|
the generated serial, use the generated serial. If the current serial is
|
|
higher or
|
|
equal to the generated serial, increase the current serial by 1.
|
|
</li>
|
|
<li>
|
|
<strong>INCREASE</strong> - Increase the current serial by 1.
|
|
</li>
|
|
<li>
|
|
<strong>EPOCH</strong> - Change the serial to the number of seconds since the EPOCH,
|
|
AKA UNIX timestamps
|
|
</li>
|
|
<li>
|
|
<strong>OFF</strong> - Disable automatic updates of the SOA serial.
|
|
</li>
|
|
</ul>
|
|
</dd>
|
|
</dl>
|
|
<p>
|
|
Find more details at <a href="https://docs.powerdns.com/md/" target="_blank">https://docs.powerdns.com/md/</a>
|
|
</p>
|
|
</div>
|
|
<!-- /.card-body -->
|
|
</div>
|
|
<!-- /.card -->
|
|
</div>
|
|
<!-- /.col -->
|
|
</div>
|
|
<!-- /.row -->
|
|
</div>
|
|
<!-- /.container-fluid -->
|
|
</section>
|
|
{% endblock %}
|
|
|
|
{% block extrascripts %}
|
|
<script>
|
|
$("input[name=radio_type]").change(function () {
|
|
var type = $(this).val();
|
|
if (type == "slave") {
|
|
$("#domain_master_address_div").show();
|
|
} else {
|
|
$("#domain_master_address_div").hide();
|
|
}
|
|
});
|
|
</script>
|
|
{% endblock %}
|
|
|
|
{% block modals %}
|
|
<script>
|
|
{% if domain_override_message %}
|
|
$(document.body).ready(function () {
|
|
var modal = $("#modal_warning");
|
|
var info = "{{ domain_override_message }}";
|
|
modal.find('.modal-body p').text(info);
|
|
modal.modal('show');
|
|
});
|
|
{% endif %}
|
|
</script>
|
|
|
|
<div class="modal fade" id="modal_warning">
|
|
<div class="modal-dialog">
|
|
<div class="modal-content modal-sm">
|
|
<div class="modal-header alert-danger">
|
|
<h4 class="modal-title">
|
|
WARNING
|
|
</h4>
|
|
<button type="button" class="close" data-dismiss="modal" aria-label="Close"
|
|
id="button_close_warn_modal">
|
|
<span aria-hidden="true">×</span>
|
|
</button>
|
|
</div>
|
|
<div class="modal-body">
|
|
<p></p>
|
|
</div>
|
|
<div class="modal-footer">
|
|
<button type="button" class="btn btn-primary center-block" data-dismiss="modal"
|
|
id="button_confirm_warn_modal">
|
|
CLOSE
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endblock %}
|