mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2025-01-11 16:51:55 -06:00
Add autmount-specific location and default entries
This commit is contained in:
parent
f8f4058014
commit
c513743e7c
@ -117,7 +117,7 @@ class ldap(CrudBackend):
|
|||||||
|
|
||||||
return object_type
|
return object_type
|
||||||
|
|
||||||
def find_entry_dn(self, key_attribute, primary_key, object_type=None):
|
def find_entry_dn(self, key_attribute, primary_key, object_type=None, base=None):
|
||||||
"""
|
"""
|
||||||
Find an existing entry's dn from an attribute
|
Find an existing entry's dn from an attribute
|
||||||
"""
|
"""
|
||||||
@ -133,7 +133,10 @@ class ldap(CrudBackend):
|
|||||||
self.dn.escape_dn_chars(primary_key)
|
self.dn.escape_dn_chars(primary_key)
|
||||||
)
|
)
|
||||||
|
|
||||||
search_base = "%s, %s" % (self.api.env.container_accounts, self.api.env.basedn)
|
if not base:
|
||||||
|
base = self.api.env.container_accounts
|
||||||
|
|
||||||
|
search_base = "%s, %s" % (base, self.api.env.basedn)
|
||||||
|
|
||||||
entry = servercore.get_sub_entry(search_base, search_filter, ['dn', 'objectclass'])
|
entry = servercore.get_sub_entry(search_base, search_filter, ['dn', 'objectclass'])
|
||||||
|
|
||||||
|
@ -33,3 +33,22 @@ add:objectClasses:
|
|||||||
DESC 'Automount information' SUP top STRUCTURAL
|
DESC 'Automount information' SUP top STRUCTURAL
|
||||||
MUST ( automountKey $ automountInformation ) MAY description
|
MUST ( automountKey $ automountInformation ) MAY description
|
||||||
X-ORIGIN 'RFC 2307bis' )
|
X-ORIGIN 'RFC 2307bis' )
|
||||||
|
|
||||||
|
# Add the default automount entries
|
||||||
|
|
||||||
|
dn: cn=automount,$SUFFIX
|
||||||
|
add:objectClass: nsContainer
|
||||||
|
add:cn: automount
|
||||||
|
|
||||||
|
dn: automountmapname=auto.master,cn=automount,$SUFFIX
|
||||||
|
add:objectClass: automountMap
|
||||||
|
add:automountMapName: auto.master
|
||||||
|
|
||||||
|
dn: automountkey=/-,automountmapname=auto.master,cn=automount,$SUFFIX
|
||||||
|
add:objectClass: automount
|
||||||
|
add:automountKey: '/-'
|
||||||
|
add:automountInformation: auto.direct
|
||||||
|
|
||||||
|
dn: automountmapname=auto.direct,cn=automount,$SUFFIX
|
||||||
|
add:objectClass: automountMap
|
||||||
|
add:automountMapName: auto.direct
|
||||||
|
@ -72,6 +72,7 @@ DEFAULT_CONFIG = (
|
|||||||
('container_service', 'cn=services,cn=accounts'),
|
('container_service', 'cn=services,cn=accounts'),
|
||||||
('container_host', 'cn=computers,cn=accounts'),
|
('container_host', 'cn=computers,cn=accounts'),
|
||||||
('container_hostgroup', 'cn=hostgroups,cn=accounts'),
|
('container_hostgroup', 'cn=hostgroups,cn=accounts'),
|
||||||
|
('container_automount', 'cn=automount'),
|
||||||
|
|
||||||
# Ports, hosts, and URIs:
|
# Ports, hosts, and URIs:
|
||||||
('lite_xmlrpc_port', 8888),
|
('lite_xmlrpc_port', 8888),
|
||||||
|
@ -53,7 +53,7 @@ def make_automount_dn(mapname):
|
|||||||
import ldap
|
import ldap
|
||||||
return 'automountmapname=%s,%s,%s' % (
|
return 'automountmapname=%s,%s,%s' % (
|
||||||
ldap.dn.escape_dn_chars(mapname),
|
ldap.dn.escape_dn_chars(mapname),
|
||||||
api.env.container_accounts,
|
api.env.container_automount,
|
||||||
api.env.basedn,
|
api.env.basedn,
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -133,7 +133,7 @@ class automount_addkey(crud.Add):
|
|||||||
ldap = self.api.Backend.ldap
|
ldap = self.api.Backend.ldap
|
||||||
# use find_entry_dn instead of make_automap_dn so we can confirm that
|
# use find_entry_dn instead of make_automap_dn so we can confirm that
|
||||||
# the map exists
|
# the map exists
|
||||||
map_dn = ldap.find_entry_dn("automountmapname", mapname, "automountmap")
|
map_dn = ldap.find_entry_dn("automountmapname", mapname, "automountmap", api.env.container_automount)
|
||||||
kw['dn'] = "automountkey=%s,%s" % (kw['automountkey'], map_dn)
|
kw['dn'] = "automountkey=%s,%s" % (kw['automountkey'], map_dn)
|
||||||
|
|
||||||
kw['objectClass'] = ['automount']
|
kw['objectClass'] = ['automount']
|
||||||
@ -193,7 +193,7 @@ class automount_delkey(crud.Del):
|
|||||||
:param kw: "key" the key to be removed
|
:param kw: "key" the key to be removed
|
||||||
"""
|
"""
|
||||||
ldap = self.api.Backend.ldap
|
ldap = self.api.Backend.ldap
|
||||||
dn = ldap.find_entry_dn("automountmapname", mapname, "automountmap")
|
dn = ldap.find_entry_dn("automountmapname", mapname, "automountmap", api.env.container_automount)
|
||||||
keys = api.Command['automount_getkeys'](mapname)
|
keys = api.Command['automount_getkeys'](mapname)
|
||||||
keydn = None
|
keydn = None
|
||||||
keyname = kw.get('automountkey').lower()
|
keyname = kw.get('automountkey').lower()
|
||||||
@ -235,7 +235,7 @@ class automount_modmap(crud.Mod):
|
|||||||
assert 'automountmapname' not in kw
|
assert 'automountmapname' not in kw
|
||||||
assert 'dn' not in kw
|
assert 'dn' not in kw
|
||||||
ldap = self.api.Backend.ldap
|
ldap = self.api.Backend.ldap
|
||||||
dn = ldap.find_entry_dn("automountmapname", mapname, "automountmap")
|
dn = ldap.find_entry_dn("automountmapname", mapname, "automountmap", api.env.container_automount)
|
||||||
return ldap.update(dn, **kw)
|
return ldap.update(dn, **kw)
|
||||||
|
|
||||||
def output_for_cli(self, ret):
|
def output_for_cli(self, ret):
|
||||||
@ -274,7 +274,7 @@ class automount_modkey(crud.Mod):
|
|||||||
keyname = kw.get('automountkey').lower()
|
keyname = kw.get('automountkey').lower()
|
||||||
del kw['automountkey']
|
del kw['automountkey']
|
||||||
ldap = self.api.Backend.ldap
|
ldap = self.api.Backend.ldap
|
||||||
dn = ldap.find_entry_dn("automountmapname", mapname, "automountmap")
|
dn = ldap.find_entry_dn("automountmapname", mapname, "automountmap", api.env.container_automount)
|
||||||
keys = api.Command['automount_getkeys'](mapname)
|
keys = api.Command['automount_getkeys'](mapname)
|
||||||
keydn = None
|
keydn = None
|
||||||
if keys:
|
if keys:
|
||||||
@ -388,7 +388,7 @@ class automount_showmap(crud.Get):
|
|||||||
:param kw: "all" set to True = return all attributes
|
:param kw: "all" set to True = return all attributes
|
||||||
"""
|
"""
|
||||||
ldap = self.api.Backend.ldap
|
ldap = self.api.Backend.ldap
|
||||||
dn = ldap.find_entry_dn("automountmapname", mapname, "automountmap")
|
dn = ldap.find_entry_dn("automountmapname", mapname, "automountmap", api.env.container_automount)
|
||||||
# FIXME: should kw contain the list of attributes to display?
|
# FIXME: should kw contain the list of attributes to display?
|
||||||
if kw.get('all', False):
|
if kw.get('all', False):
|
||||||
return ldap.retrieve(dn)
|
return ldap.retrieve(dn)
|
||||||
@ -420,7 +420,7 @@ class automount_showkey(crud.Get):
|
|||||||
:param kw: "all" set to True = return all attributes
|
:param kw: "all" set to True = return all attributes
|
||||||
"""
|
"""
|
||||||
ldap = self.api.Backend.ldap
|
ldap = self.api.Backend.ldap
|
||||||
dn = ldap.find_entry_dn("automountmapname", mapname, "automountmap")
|
dn = ldap.find_entry_dn("automountmapname", mapname, "automountmap", api.env.container_automount)
|
||||||
keys = api.Command['automount_getkeys'](mapname)
|
keys = api.Command['automount_getkeys'](mapname)
|
||||||
keyname = kw.get('automountkey').lower()
|
keyname = kw.get('automountkey').lower()
|
||||||
keydn = None
|
keydn = None
|
||||||
@ -468,7 +468,7 @@ class automount_getkeys(frontend.Command):
|
|||||||
:param mapname: Retrieve all keys for this mapname
|
:param mapname: Retrieve all keys for this mapname
|
||||||
"""
|
"""
|
||||||
ldap = self.api.Backend.ldap
|
ldap = self.api.Backend.ldap
|
||||||
dn = ldap.find_entry_dn("automountmapname", mapname, "automountmap")
|
dn = ldap.find_entry_dn("automountmapname", mapname, "automountmap", api.env.container_automount)
|
||||||
try:
|
try:
|
||||||
keys = ldap.get_one_entry(dn, 'objectclass=*', ['automountkey'])
|
keys = ldap.get_one_entry(dn, 'objectclass=*', ['automountkey'])
|
||||||
except errors.NotFound:
|
except errors.NotFound:
|
||||||
|
Loading…
Reference in New Issue
Block a user