diff options
author | Marti Raudsepp <marti@juffo.org> | 2018-07-09 16:11:18 +0300 |
---|---|---|
committer | Paul Kehrer <paul.l.kehrer@gmail.com> | 2018-07-09 18:41:18 +0530 |
commit | 9e1873af35a2b530e71e1579b2d62c233b75ba26 (patch) | |
tree | 52798039846ad61753859f64a68c2cfdeae0b747 /src | |
parent | dd6f4c2977ff03ba0e45e3528f49f126f587f123 (diff) | |
download | cryptography-9e1873af35a2b530e71e1579b2d62c233b75ba26.tar.gz cryptography-9e1873af35a2b530e71e1579b2d62c233b75ba26.tar.bz2 cryptography-9e1873af35a2b530e71e1579b2d62c233b75ba26.zip |
Make RelativeDistinguishedName preserve attribtue order (#4306)
Duplicate attributes now raise an error instead of silently discarding
duplicates.
Diffstat (limited to 'src')
-rw-r--r-- | src/cryptography/x509/name.py | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/src/cryptography/x509/name.py b/src/cryptography/x509/name.py index 0daa8bbd..5548eda8 100644 --- a/src/cryptography/x509/name.py +++ b/src/cryptography/x509/name.py @@ -101,13 +101,18 @@ class NameAttribute(object): class RelativeDistinguishedName(object): def __init__(self, attributes): - attributes = frozenset(attributes) + attributes = list(attributes) if not attributes: raise ValueError("a relative distinguished name cannot be empty") if not all(isinstance(x, NameAttribute) for x in attributes): raise TypeError("attributes must be an iterable of NameAttribute") + # Keep list and frozenset to preserve attribute order where it matters self._attributes = attributes + self._attribute_set = frozenset(attributes) + + if len(self._attribute_set) != len(attributes): + raise ValueError("duplicate attributes are not allowed") def get_attributes_for_oid(self, oid): return [i for i in self if i.oid == oid] @@ -116,13 +121,13 @@ class RelativeDistinguishedName(object): if not isinstance(other, RelativeDistinguishedName): return NotImplemented - return self._attributes == other._attributes + return self._attribute_set == other._attribute_set def __ne__(self, other): return not self == other def __hash__(self): - return hash(self._attributes) + return hash(self._attribute_set) def __iter__(self): return iter(self._attributes) |