Add functionality to _valid_refs to accept actual cyber observable objects instead of just strings with their types
parent
ddd4fa3e95
commit
f79b3c9876
|
@ -308,6 +308,9 @@ class _Observable(_STIXBase):
|
||||||
allowed_types = prop.valid_types
|
allowed_types = prop.valid_types
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
try:
|
||||||
|
ref_type = self._STIXBase__valid_refs[ref].type
|
||||||
|
except AttributeError:
|
||||||
ref_type = self._STIXBase__valid_refs[ref]
|
ref_type = self._STIXBase__valid_refs[ref]
|
||||||
except TypeError:
|
except TypeError:
|
||||||
raise ValueError("'%s' must be created with _valid_refs as a dict, not a list." % self.__class__.__name__)
|
raise ValueError("'%s' must be created with _valid_refs as a dict, not a list." % self.__class__.__name__)
|
||||||
|
|
|
@ -940,6 +940,24 @@ def test_ip4_address_example():
|
||||||
assert ip4.resolves_to_refs == ["4", "5"]
|
assert ip4.resolves_to_refs == ["4", "5"]
|
||||||
|
|
||||||
|
|
||||||
|
def test_ip4_address_valid_refs():
|
||||||
|
mac1 = stix2.v21.MACAddress(
|
||||||
|
value="a1:b2:c3:d4:e5:f6",
|
||||||
|
)
|
||||||
|
mac2 = stix2.v21.MACAddress(
|
||||||
|
value="a7:b8:c9:d0:e1:f2",
|
||||||
|
)
|
||||||
|
|
||||||
|
ip4 = stix2.v21.IPv4Address(
|
||||||
|
_valid_refs={"1": mac1, "2": mac2},
|
||||||
|
value="177.60.40.7",
|
||||||
|
resolves_to_refs=["1", "2"],
|
||||||
|
)
|
||||||
|
|
||||||
|
assert ip4.value == "177.60.40.7"
|
||||||
|
assert ip4.resolves_to_refs == ["1", "2"]
|
||||||
|
|
||||||
|
|
||||||
def test_ip4_address_example_cidr():
|
def test_ip4_address_example_cidr():
|
||||||
ip4 = stix2.v21.IPv4Address(value="198.51.100.0/24")
|
ip4 = stix2.v21.IPv4Address(value="198.51.100.0/24")
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue