diff --git a/app/models.py b/app/models.py
index 7e87d08..dada209 100644
--- a/app/models.py
+++ b/app/models.py
@@ -12,6 +12,7 @@ import dns.reversename
import dns.inet
import dns.name
import logging as logger
+import pytimeparse
from ast import literal_eval
from datetime import datetime
@@ -165,7 +166,7 @@ class User(db.Model):
def ad_recursive_groups(self, groupDN):
"""
- Recursively list groups belonging to a group. It will allow checking deep in the Active Directory
+ Recursively list groups belonging to a group. It will allow checking deep in the Active Directory
whether a user is allowed to enter or not
"""
LDAP_BASE_DN = Setting().get('ldap_base_dn')
@@ -1424,7 +1425,7 @@ class Record(object):
r_name = r['record_name']
r_data = domain if r_type == 'CNAME' and r['record_data'] in ['@', ''] else r['record_data']
-
+
record = {
"name": r_name,
"type": r_type,
@@ -1889,6 +1890,7 @@ class Setting(db.Model):
'oidc_oauth_authorize_url': '',
'forward_records_allow_edit': {'A': True, 'AAAA': True, 'AFSDB': False, 'ALIAS': False, 'CAA': True, 'CERT': False, 'CDNSKEY': False, 'CDS': False, 'CNAME': True, 'DNSKEY': False, 'DNAME': False, 'DS': False, 'HINFO': False, 'KEY': False, 'LOC': True, 'MX': True, 'NAPTR': False, 'NS': True, 'NSEC': False, 'NSEC3': False, 'NSEC3PARAM': False, 'OPENPGPKEY': False, 'PTR': True, 'RP': False, 'RRSIG': False, 'SOA': False, 'SPF': True, 'SSHFP': False, 'SRV': True, 'TKEY': False, 'TSIG': False, 'TLSA': False, 'SMIMEA': False, 'TXT': True, 'URI': False},
'reverse_records_allow_edit': {'A': False, 'AAAA': False, 'AFSDB': False, 'ALIAS': False, 'CAA': False, 'CERT': False, 'CDNSKEY': False, 'CDS': False, 'CNAME': False, 'DNSKEY': False, 'DNAME': False, 'DS': False, 'HINFO': False, 'KEY': False, 'LOC': True, 'MX': False, 'NAPTR': False, 'NS': True, 'NSEC': False, 'NSEC3': False, 'NSEC3PARAM': False, 'OPENPGPKEY': False, 'PTR': True, 'RP': False, 'RRSIG': False, 'SOA': False, 'SPF': False, 'SSHFP': False, 'SRV': False, 'TKEY': False, 'TSIG': False, 'TLSA': False, 'SMIMEA': False, 'TXT': True, 'URI': False},
+ 'ttl_options': '1 minute,5 minutes,30 minutes,60 minutes,24 hours',
}
def __init__(self, id=None, name=None, value=None):
@@ -1994,6 +1996,9 @@ class Setting(db.Model):
r_name.sort()
return r_name
+ def get_ttl_options(self):
+ return [ (pytimeparse.parse(ttl),ttl) for ttl in self.get('ttl_options').split(',') ]
+
class DomainTemplate(db.Model):
__tablename__ = "domain_template"
diff --git a/app/static/custom/js/custom.js b/app/static/custom/js/custom.js
index 85e523d..4f295bb 100644
--- a/app/static/custom/js/custom.js
+++ b/app/static/custom/js/custom.js
@@ -112,19 +112,38 @@ function restoreRow(oTable, nRow) {
oTable.draw();
}
+function sec2str(t){
+ var d = Math.floor(t/86400),
+ h = Math.floor(t/3600) % 24,
+ m = Math.floor(t/60) % 60,
+ s = t % 60;
+ return (d>0?d+' days ':'')+(h>0?h+' hours ':'')+(m>0?m+' minutes ':'')+(s>0?s+' seconds':'');
+}
+
function editRow(oTable, nRow) {
var isDisabled = 'true';
var aData = oTable.row(nRow).data();
var jqTds = oTable.cells(nRow,'').nodes();
var record_types = "";
+ var ttl_opts = "";
+ var ttl_not_found = true;
for(var i = 0; i < records_allow_edit.length; i++) {
var record_type = records_allow_edit[i];
record_types += "";
}
+ for(var i = 0; i < ttl_options.length; i++) {
+ ttl_opts += "";
+ if (ttl_options[i][0] == aData[3]) {
+ ttl_not_found = false;
+ }
+ }
+ if (ttl_not_found) {
+ ttl_opts += "";
+ }
jqTds[0].innerHTML = '';
- jqTds[1].innerHTML = '';
- jqTds[2].innerHTML = '';
- jqTds[3].innerHTML = '';
+ jqTds[1].innerHTML = '';
+ jqTds[2].innerHTML = '';
+ jqTds[3].innerHTML = '';
jqTds[4].innerHTML = '';
jqTds[5].innerHTML = '';
jqTds[6].innerHTML = '';
diff --git a/app/templates/domain.html b/app/templates/domain.html
index 4f422b7..577afa2 100644
--- a/app/templates/domain.html
+++ b/app/templates/domain.html
@@ -106,6 +106,7 @@