Fixed my own brainfart with converting string filter values to

datetimes: I'd converted the object property instead of the
filter value! :-P

Also, I fixed filter validation: it was checking for exact types
of the filter values and disallowing subtypes.  This library
includes a datetime subtype named STIXdatetime, and this type
should be usable as a filter value too.  So we need to allow
subtypes.
master
Michael Chisholm 2018-11-27 18:38:55 -05:00
parent f57b9c34ef
commit 3a2f247f68
1 changed files with 4 additions and 8 deletions

View File

@ -14,12 +14,8 @@ import stix2.utils
FILTER_OPS = ['=', '!=', 'in', '>', '<', '>=', '<=', 'contains'] FILTER_OPS = ['=', '!=', 'in', '>', '<', '>=', '<=', 'contains']
"""Supported filter value types""" """Supported filter value types"""
FILTER_VALUE_TYPES = [bool, dict, float, int, list, str, tuple, datetime] FILTER_VALUE_TYPES = (bool, dict, float, int, list, tuple, six.string_types,
try: datetime)
FILTER_VALUE_TYPES.append(unicode)
except NameError:
# Python 3 doesn't need to worry about unicode
pass
def _check_filter_components(prop, op, value): def _check_filter_components(prop, op, value):
@ -38,7 +34,7 @@ def _check_filter_components(prop, op, value):
# check filter operator is supported # check filter operator is supported
raise ValueError("Filter operator '%s' not supported for specified property: '%s'" % (op, prop)) raise ValueError("Filter operator '%s' not supported for specified property: '%s'" % (op, prop))
if type(value) not in FILTER_VALUE_TYPES: if not isinstance(value, FILTER_VALUE_TYPES):
# check filter value type is supported # check filter value type is supported
raise TypeError("Filter value of '%s' is not supported. The type must be a Python immutable type or dictionary" % type(value)) raise TypeError("Filter value of '%s' is not supported. The type must be a Python immutable type or dictionary" % type(value))
@ -90,7 +86,7 @@ class Filter(collections.namedtuple("Filter", ['property', 'op', 'value'])):
# try to convert the filter value to a datetime instance. # try to convert the filter value to a datetime instance.
if isinstance(stix_obj_property, datetime) and \ if isinstance(stix_obj_property, datetime) and \
isinstance(self.value, six.string_types): isinstance(self.value, six.string_types):
filter_value = stix2.utils.parse_into_datetime(stix_obj_property) filter_value = stix2.utils.parse_into_datetime(self.value)
else: else:
filter_value = self.value filter_value = self.value