Source code for univention.admin.handlers.dns.dns
# SPDX-FileCopyrightText: 2004-2025 Univention GmbH
# SPDX-License-Identifier: AGPL-3.0-only
"""|UDM| module for all |DNS| objects"""
from __future__ import annotations
import univention.admin
import univention.admin.filter
import univention.admin.handlers
import univention.admin.localization
import univention.admin.uldap
from univention.admin.layout import Tab
translation = univention.admin.localization.translation('univention.admin.handlers.dns')
_ = translation.translate
module = 'dns/dns'
childs = False
short_description = _('All DNS zones')
object_name = _('DNS zone')
object_name_plural = _('DNS zones')
long_description = _('Manage the Domain Name System.')
operations = ['search']
childmodules = ['dns/forward_zone', 'dns/reverse_zone']
virtual = True
options: dict[str, univention.admin.option] = {}
property_descriptions = {
'name': univention.admin.property(
short_description=_('Name'),
long_description='',
syntax=univention.admin.syntax.dnsName,
include_in_default_search=True,
required=True,
identifies=True,
),
}
layout = [Tab(_('General'), _('Basic settings'), layout=['name'])]
mapping = univention.admin.mapping.mapping()
[docs]
class object(univention.admin.handlers.simpleLdap):
module = module
[docs]
def rewrite(filter_s: str, **args: str) -> str:
if not filter_s:
return filter_s
filter_p = univention.admin.filter.parse(filter_s)
mapping = univention.admin.mapping.mapping()
for key, value in args.items():
mapping.register(key, value)
univention.admin.filter.walk(filter_p, univention.admin.mapping.mapRewrite, arg=mapping)
return str(filter_p)
MAP_SEARCH = {
'dns/forward_zone': 'zone',
'dns/reverse_zone': 'subnet',
'dns/ptr_record.py': 'address',
}
[docs]
def lookup(
co: None,
lo: univention.admin.uldap.access,
filter_s: str,
base: str = '',
superordinate: univention.admin.handlers.simpleLdap | None = None,
scope: str = 'sub',
unique: bool = False,
required: bool = False,
timeout: int = -1,
sizelimit: int = 0,
) -> list[univention.admin.handlers.simpleLdap]:
sup = univention.admin.modules._get(superordinate.module) if superordinate else None
res: list[univention.admin.handlers.simpleLdap] = []
for childmodule in sup.childmodules if sup else childmodules:
mod = univention.admin.modules._get(childmodule)
try:
attr = MAP_SEARCH[childmodule]
except LookupError:
fltr = filter_s
else:
fltr = rewrite(filter_s, name=attr)
res += mod.lookup(co, lo, fltr, base, superordinate, scope, unique, required, timeout, sizelimit)
return res
[docs]
def identify(dn: str, attr: univention.admin.handlers._Attributes, canonical: bool = False) -> None:
pass