X-Git-Url: https://git.stderr.nl/gitweb?p=matthijs%2Fupstream%2Fdjango-ldapdb.git;a=blobdiff_plain;f=ldapdb%2Fmodels%2Ffields.py;h=921923c052469ac826248bde9743b57d48c66ed6;hp=d21bbd0dc258c31bc05a35b8a1ee2d7a0b69eb07;hb=29c4b4ac0569ebb0877aa9b32211dc91afb248c5;hpb=685bca7c33547937fec1ecdb477df10ca9ef0572 diff --git a/ldapdb/models/fields.py b/ldapdb/models/fields.py index d21bbd0..921923c 100644 --- a/ldapdb/models/fields.py +++ b/ldapdb/models/fields.py @@ -28,6 +28,7 @@ class CharField(fields.CharField): super(CharField, self).__init__(*args, **kwargs) def get_db_prep_lookup(self, lookup_type, value): + "Returns field's value prepared for database lookup." if lookup_type == 'endswith': return ["*%s" % escape_ldap_filter(value)] elif lookup_type == 'startswith': @@ -42,8 +43,20 @@ class CharField(fields.CharField): raise TypeError("CharField has invalid lookup: %s" % lookup_type) def get_prep_lookup(self, lookup_type, value): - return escape_ldap_filter(value) - + "Perform preliminary non-db specific lookup checks and conversions" + if lookup_type == 'endswith': + return "*%s" % escape_ldap_filter(value) + elif lookup_type == 'startswith': + return "%s*" % escape_ldap_filter(value) + elif lookup_type == 'contains': + return "*%s*" % escape_ldap_filter(value) + elif lookup_type == 'exact': + return escape_ldap_filter(value) + elif lookup_type == 'in': + return [escape_ldap_filter(v) for v in value] + + raise TypeError("CharField has invalid lookup: %s" % lookup_type) + class ImageField(fields.Field): def get_db_prep_lookup(self, lookup_type, value): raise TypeError("ImageField has invalid lookup: %s" % lookup_type)