#
# Univention S4 Connector
# UDM module for MS GPOs
#
# SPDX-FileCopyrightText: 2012-2025 Univention GmbH
# SPDX-License-Identifier: AGPL-3.0-only
import univention.admin.handlers
import univention.admin.localization
import univention.admin.syntax
from univention.admin.layout import Group, Tab
translation = univention.admin.localization.translation('univention.admin.handlers.container.msgpo')
_ = translation.translate
module = 'container/msgpo'
operations = ['add', 'edit', 'remove', 'search', 'move', 'subtree_move']
childs = True
short_description = _('Container: MS Group Policy')
long_description = ''
options = {
'default': univention.admin.option(
short_description=short_description,
default=True,
objectClasses=['msGPOContainer', 'top'],
),
}
property_descriptions = {
'name': univention.admin.property(
short_description=_('Name'),
long_description='',
syntax=univention.admin.syntax.string,
required=True,
identifies=True,
),
'description': univention.admin.property(
short_description=_('Description'),
long_description='',
syntax=univention.admin.syntax.string,
),
'displayName': univention.admin.property(
short_description=_('Display name'),
long_description='',
syntax=univention.admin.syntax.string,
),
'msGPOFlags': univention.admin.property(
short_description=_('MS Group Policy Flags'),
long_description='',
syntax=univention.admin.syntax.string,
),
'msGPOVersionNumber': univention.admin.property(
short_description=_('MS Group Policy Version Number'),
long_description='',
syntax=univention.admin.syntax.string,
),
'msGPOSystemFlags': univention.admin.property(
short_description=_('MS Group Policy System Flags'),
long_description='',
syntax=univention.admin.syntax.string,
),
'msGPOFunctionalityVersion': univention.admin.property(
short_description=_('MS Group Policy Functionality Version'),
long_description='',
syntax=univention.admin.syntax.string,
),
'msGPOFileSysPath': univention.admin.property(
short_description=_('MS Group Policy File Sys Path'),
long_description='',
syntax=univention.admin.syntax.string,
),
'msGPOUserExtensionNames': univention.admin.property(
short_description=_('MS Group Policy User Extension Names'),
long_description='',
syntax=univention.admin.syntax.string,
),
'msGPOMachineExtensionNames': univention.admin.property(
short_description=_('MS Group Policy Machine Extension Names'),
long_description='',
syntax=univention.admin.syntax.string,
),
'msGPOWQLFilter': univention.admin.property(
short_description=_('MS Group Policy WQL Filter'),
long_description='',
syntax=univention.admin.syntax.string,
),
'msNTSecurityDescriptor': univention.admin.property(
short_description=_('MS NT Security Descriptor'),
long_description='',
syntax=univention.admin.syntax.string,
),
}
layout = [
Tab(_('General'), _('Basic settings'), layout=[
Group(_('General'), layout=[
["name", "description"],
["displayName"],
]),
]),
Tab(_('GPO settings'), _('MS GPO settings'), advanced=True, layout=[
Group(_('GPO settings'), layout=[
['msGPOFlags'],
['msGPOVersionNumber'],
['msGPOSystemFlags'],
['msGPOFunctionalityVersion'],
['msGPOFileSysPath'],
['msGPOWQLFilter'],
['msGPOUserExtensionNames'],
['msGPOMachineExtensionNames'],
]),
]),
]
mapping = univention.admin.mapping.mapping()
mapping.register('name', 'cn', None, univention.admin.mapping.ListToString)
mapping.register('description', 'description', None, univention.admin.mapping.ListToString)
mapping.register('displayName', 'displayName', None, univention.admin.mapping.ListToString)
mapping.register('msGPOFlags', 'msGPOFlags', None, univention.admin.mapping.ListToString)
mapping.register('msGPOVersionNumber', 'msGPOVersionNumber', None, univention.admin.mapping.ListToString)
mapping.register('msGPOSystemFlags', 'msGPOSystemFlags', None, univention.admin.mapping.ListToString)
mapping.register('msGPOFunctionalityVersion', 'msGPOFunctionalityVersion', None, univention.admin.mapping.ListToString)
mapping.register('msGPOFileSysPath', 'msGPOFileSysPath', None, univention.admin.mapping.ListToString)
mapping.register('msGPOWQLFilter', 'msGPOWQLFilter', None, univention.admin.mapping.ListToString)
mapping.register('msGPOUserExtensionNames', 'msGPOUserExtensionNames', None, univention.admin.mapping.ListToString)
mapping.register('msGPOMachineExtensionNames', 'msGPOMachineExtensionNames', None, univention.admin.mapping.ListToString)
mapping.register('msNTSecurityDescriptor', 'msNTSecurityDescriptor', None, univention.admin.mapping.ListToString)
[docs]
class object(univention.admin.handlers.simpleLdap):
module = module
def _ldap_pre_modify(self):
if self.hasChanged('name'):
self.move(self._ldap_dn())
identify = object.identify
lookup = object.lookup