kwargs['max_length'] = 200
super(CharField, self).__init__(*args, **kwargs)
+ def get_db_prep_lookup(self, lookup_type, value):
+ 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)
+
def get_prep_lookup(self, lookup_type, value):
return escape_ldap_filter(value)
pass
class IntegerField(fields.IntegerField):
- pass
+ def get_db_prep_lookup(self, lookup_type, value):
+ if lookup_type == 'exact':
+ return [value]
+
+ raise TypeError("IntegerField has invalid lookup: %s" % lookup_type)
class ListField(fields.Field):
__metaclass__ = SubfieldBase
import ldapdb
-from ldapdb import escape_ldap_filter
+from ldapdb.models.fields import CharField
class Constraint(BaseConstraint):
"""
# Because of circular imports, we need to import this here.
from django.db.models.base import ObjectDoesNotExist
- if lookup_type == 'endswith':
- params = ["*%s" % escape_ldap_filter(value)]
- elif lookup_type == 'startswith':
- params = ["%s*" % escape_ldap_filter(value)]
- elif lookup_type == 'contains':
- params = ["*%s*" % escape_ldap_filter(value)]
- elif lookup_type == 'exact':
- params = [escape_ldap_filter(value)]
- elif lookup_type == 'in':
- params = [escape_ldap_filter(v) for v in value]
- else:
- raise TypeError("Field has invalid lookup: %s" % lookup_type)
-
try:
if self.field:
+ params = self.field.get_db_prep_lookup(lookup_type, value)
db_type = self.field.db_type()
else:
+ params = CharField().get_db_prep_lookup(lookup_type, value)
db_type = None
except ObjectDoesNotExist:
raise EmptyShortCircuit