Allow IDNA in SOA

* Previously having characters like "ü" in the SOA wouldnt allow to push
updates to the domain
* Also use the new method to_idna to support characters like "ß"
This commit is contained in:
AdvanticGmbH 2022-04-06 17:01:28 +02:00
parent 40deb3c145
commit 191e919626
2 changed files with 5 additions and 4 deletions

View File

@ -169,12 +169,12 @@ class Record(object):
record['record_data'] = record['record_data'].replace('[ZONE]', domain_name) record['record_data'] = record['record_data'].replace('[ZONE]', domain_name)
# Translate record name into punycode (IDN) as that's the only way # Translate record name into punycode (IDN) as that's the only way
# to convey non-ascii records to the dns server # to convey non-ascii records to the dns server
record['record_name'] = record['record_name'].encode('idna').decode() record['record_name'] = utils.to_idna(record["record_name"], "encode")
#TODO: error handling #TODO: error handling
# If the record is an alias (CNAME), we will also make sure that # If the record is an alias (CNAME), we will also make sure that
# the target domain is properly converted to punycode (IDN) # the target domain is properly converted to punycode (IDN)
if record["record_type"] == 'CNAME': if record['record_type'] == 'CNAME' or record['record_type'] == 'SOA':
record['record_data'] = record['record_data'].encode('idna').decode() record['record_data'] = utils.to_idna(record['record_data'], 'encode')
#TODO: error handling #TODO: error handling
# If it is ipv6 reverse zone and PRETTY_IPV6_PTR is enabled, # If it is ipv6 reverse zone and PRETTY_IPV6_PTR is enabled,
# We convert ipv6 address back to reverse record format # We convert ipv6 address back to reverse record format

View File

@ -10,6 +10,7 @@ from flask_login import login_required, current_user, login_manager
from ..lib.utils import pretty_domain_name from ..lib.utils import pretty_domain_name
from ..lib.utils import pretty_json from ..lib.utils import pretty_json
from ..lib.utils import to_idna
from ..decorators import can_create_domain, operator_role_required, can_access_domain, can_configure_dnssec, can_remove_domain from ..decorators import can_create_domain, operator_role_required, can_access_domain, can_configure_dnssec, can_remove_domain
from ..models.user import User, Anonymous from ..models.user import User, Anonymous
from ..models.account import Account from ..models.account import Account
@ -379,7 +380,7 @@ def add():
# Encode domain name into punycode (IDN) # Encode domain name into punycode (IDN)
try: try:
domain_name = domain_name.encode('idna').decode() domain_name = to_idna(domain_name, 'encode')
except: except:
current_app.logger.error("Cannot encode the domain name {}".format(domain_name)) current_app.logger.error("Cannot encode the domain name {}".format(domain_name))
current_app.logger.debug(traceback.format_exc()) current_app.logger.debug(traceback.format_exc())