Changelog¶
1.0.0¶
- Renamed - x690.types.Typeto- x690.types.X690Type
- Flagged as “stable” 
- Dropped support for Python 3.6 
0.5.0¶
- Flagged as “production” release 
- All changes from 0.5.0-alpha.0 - 0.5.0-alpha.6 
0.5.0-alpha.6¶
- Relaxed dev-dependencies a bit which caused issues in some installations 
0.5.0-alpha.5¶
- Allow ObjectIdentifier instances to be created for “relative” sub-trees by delaying the byte-conversion. - When converting ObjectIdentifiers to bytes, the first two objects are “folded” together. This is not possible for some values. Delaying this folding until the “is-needed” moment allows the use for such OIDs to be used for subtree modifications/concatenation. They will still raise errors if they are converted to bytes unmodified. 
- Internal typing improvment 
0.5.0-alpha.4¶
- Raise an exception when trying to decode data that is out-of-bounds of the processed blob. 
- Accessing a scalar index (not a slice) from an OID returns the integer value. 
0.5.0-alpha.3¶
- Housekeeping & typing improvments 
0.5.0-alpha.2¶
- Don’t conider “None/NULL” values as “uninitialised”. This prevents unnecessary/repetitive byte-conversions. 
0.5.0-alpha.1¶
- ObjectIdentifiers now “feel” more like strings. The constructor changed to reflect this: - ObjectIdentifier("1.2.3")
- Improve error message when creating custom typess without no-arg constructor 
- Fix “unsigned int” values 
- Fix handling of empty - Sequenceinstances
0.5.0-alpha.0¶
This release focussed on performance (both memory and CPU) in order to decode large x690 documents.
As it goes with performance, a fair amount of refactoring was needed and the external API could not be guaranteed easily. And as we’re still on the 0.x branch, the backwards-compatibility was dropped in favor of cleaner code.
It is flagged as “alpha” until I feel confident that the new changes have not introduced breaking bugs.
- Replaced - x690.pop_tlvhas been replaced by- x690.decode. This no longer copies data in-memory and therefore no longer returns the “remaining” data-bytes. Instead it returns the position of the next data-block.- decodealso takes an additional argument to define where to start decoding data from.
- changed - ObjectIdentifierhas been aligned to the existing types and no longer use- *argsto initialise instances. Instead of- ObjectIdentifier(1, 2, 3)you must now write- Sequence((1, 2, 3))
- changed - Sequencehas been aligned to the existing types and no longer use- *argsto initialise instances. Instead of- Sequence(a, b, c)you must now write- Sequence([a, b, c])
- changed - UnknownTypehas been aligned to the existing types. It now takes the value as first argument instead of second. Instead of- UnknownType(99, b"abc")you must now write- UnknownType(b"abc", 99).
- changed Subclasses of - x690.Typemust now override the- Type.decode_rawmethod if the data is needed in another type that- bytes.
- changed Subclasses of - x690.Typemust now override the- Type.encode_rawmethod if the python-value is a non-bytes object.
- dataclasses in have been replaced with named-tuples for increased performance. 
- An instance can now be creted from raw-bytes (excluding the type and length header bytes) by calling - Type.from_bytes(...)(by using the class of the appropriate type!).
- New function - x690.util.get_value_slicecan be used to find the location of the raw-bytes of a value at any given location. The location must however be the start of an x690 “TLV” block. This will return the slice of the value location (The “V” part excluding the “TL” part) and the location of the next value-block.
0.4.0¶
- Removed Decoding no longer raises a “ValueError” if a value contains junk-bytes after decoding. Use either “strict” mode or inspect the “remainder” after decoding yourself. This was a necessity to remove a duplication with length-decoding and was too impactful to re-introduce. 
- Removed Types no longer have a - from_bytesimplementation. This was the core of the code-duplication and is now gone in favor of the- decodefunction.
- Support for “indefinite length” values 
- Allow registering types with “non-constructed” nature 
- Improved prettyfication of unknown types 
- Support types which can be encoded as either “primitive” or “constructed” 
- Implement decoding of the GraphicString type 
- Removed duplication of length-decoding 
0.3.0¶
The most visible changes in this release are the additional arguments on
pop_tlv. Using enforce_type adds valuable typing information for IDEs.
As long as they are known in advance of course. By default, the type will be
Any. Using strict=True can be helpful for fail-fast programming.
Finally, some internals have been modified for more maintainable code. They
should only have an impact if you extended x690 with new types.
- Dropped Support for Python <3.6 
- Removed - x690.types.NonASN1Type
- Removed custom - to_bytesimplementation (use the builtin- bytes()instead). For example:- bytes(x690.types.Integer(10))
- Added - enforce_typeto- pop_tlvfor improved type-safety and -checking
- Added - strictto- pop_tlvfor quick & easy sanity checks
- Improved prettyfication of byte-values and unknown types 
- Improved prettyfication of nested sequences 
- Improved type-hints 
- Added default values to all types 
- Changed - x690.util.LengthValueand- x690.util.TypeInfoto dataclasses
- Use enums for internal “typeclass” and “primitive/constructed” values. 
- Stricter CI pipeline (including mypy and vulture) 
- Switch to - poetryfor packaging