projects
/
matthijs
/
upstream
/
django-ldapdb.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
fix collect_sub_objects
[matthijs/upstream/django-ldapdb.git]
/
ldapdb
/
models
/
base.py
diff --git
a/ldapdb/models/base.py
b/ldapdb/models/base.py
index e98133b58cc7f596f61c365cadfb8b12a27df6a5..661c2eda2593ae45bb0f91960d7e9f398d0cf7a6 100644
(file)
--- a/
ldapdb/models/base.py
+++ b/
ldapdb/models/base.py
@@
-68,25
+68,28
@@
class Model(django.db.models.base.Model):
# meta-data
base_dn = None
# meta-data
base_dn = None
+ search_scope = ldap.SCOPE_SUBTREE
object_classes = ['top']
def __init__(self, *args, **kwargs):
super(Model, self).__init__(*args, **kwargs)
self.saved_pk = self.pk
object_classes = ['top']
def __init__(self, *args, **kwargs):
super(Model, self).__init__(*args, **kwargs)
self.saved_pk = self.pk
- def _collect_sub_objects(self,
collector
):
+ def _collect_sub_objects(self,
seen_objs, parent=None, nullable=False
):
"""
This private API seems to be called by the admin interface in django 1.2
"""
"""
This private API seems to be called by the admin interface in django 1.2
"""
- pass
+ pk_val = self._get_pk_val()
+ seen_objs.add(self.__class__, pk_val, self,
+ type(parent), parent, nullable)
def build_rdn(self):
"""
Build the Relative Distinguished Name for this entry.
"""
bits = []
def build_rdn(self):
"""
Build the Relative Distinguished Name for this entry.
"""
bits = []
- for field in self._meta.
local_
fields:
- if field.primary_key:
+ for field in self._meta.fields:
+ if field.
db_column and field.
primary_key:
bits.append("%s=%s" % (field.db_column, getattr(self, field.name)))
if not len(bits):
raise Exception("Could not build Distinguished Name")
bits.append("%s=%s" % (field.db_column, getattr(self, field.name)))
if not len(bits):
raise Exception("Could not build Distinguished Name")
@@
-114,7
+117,7
@@
class Model(django.db.models.base.Model):
entry = [('objectClass', self.object_classes)]
new_dn = self.build_dn()
entry = [('objectClass', self.object_classes)]
new_dn = self.build_dn()
- for field in self._meta.
local_
fields:
+ for field in self._meta.fields:
if not field.db_column:
continue
value = getattr(self, field.name)
if not field.db_column:
continue
value = getattr(self, field.name)
@@
-132,7
+135,7
@@
class Model(django.db.models.base.Model):
record_exists = True
modlist = []
orig = self.__class__.objects.get(pk=self.saved_pk)
record_exists = True
modlist = []
orig = self.__class__.objects.get(pk=self.saved_pk)
- for field in self._meta.
local_
fields:
+ for field in self._meta.fields:
if not field.db_column:
continue
old_value = getattr(orig, field.name, None)
if not field.db_column:
continue
old_value = getattr(orig, field.name, None)