Skip to content

Latest commit

 

History

History
837 lines (712 loc) · 36.6 KB

CHANGELOG.md

File metadata and controls

837 lines (712 loc) · 36.6 KB

Changelog

0.25.0 - 2024-12-17

Breaking changes

  • Renamed VersionUpgradePolicy::Upgrade to UpgradeToV2 in preparation for a future DBN version 3

Enhancements

  • Added v1 and v2 modules to allow unambiguously referring to the record types for a given DBN version regardless of whether the record type has changed. Previously versioned aliases only existed for record types that have changed between DBN versions
    • Added identical namespaces to databento_dbn Python package
  • Changed dataset() method on MetadataBuilder to accept an impl ToString so now Dataset and &str can be passed directly
  • Added type aliases for TBBOMsg, BBO1SMsg, BBO1MMsg, TCBBOMsg, CBBO1SMsg, CBBO1MMsg in Python

Deprecations

  • Deprecated dataset module. The top-level Dataset enum and its const as_str() method provide the same functionality for all datasets. This module will be removed in a future version

0.24.0 - 2024-12-10

Enhancements

  • Upgraded async-compression version to 0.4.18
  • Upgraded proc-macro2 version to 1.0.92

Breaking changes

  • Changed async DBN decoding to return Ok(None) when an incomplete record remains in the stream. This matches the existing behavior of sync DBN decoding

Bug fixes

  • Added handling for UNDEF_TIMESTAMP in pretty_ timestamp getters for Python. They now return None in the case of UNDEF_TIMESTAMP

0.23.1 - 2024-11-12

Enhancements

  • Added floating-point getters for price fields
  • Added new IntelligentCross venues ASPN, ASMT, and ASPI
  • Upgraded thiserror version to 2.0
  • Upgraded pyo3 version to 0.22.6

Bug fixes

  • Fixed pretty_activation getter in databento_dbn returning expiration instead of activation
  • Fixed some pretty_ getters in databento_dbn didn't correctly handle UNDEF_PRICE

0.23.0 - 2024-10-22

Enhancements

  • Added new None Action variant that will be gradually rolled out to historical and live GLBX.MDP3 data
  • Added consistent escaping of non-printable and non-ASCII values when text encoding c_char fields
  • Implemented Default for Action and Side
  • Added support for Python 3.13 to databento_dbn
  • Implemented missing Serialize for (with serde feature enabled) for Venue, Dataset, Publisher, Compression, SType, Schema, and Encoding

0.22.1 - 2024-10-08

Enhancements

  • Removed support for Python 3.8 in databento-dbn due to end of life

Bug fixes

  • Fixed buffer overrun in c_chars_to_str on non-null terminated input

0.22.0 - 2024-10-01

Enhancements

  • Added Python type stubs for Record __init__ methods

Breaking changes

  • Combined _reserved3 and _reserved4 fields in CbboMsg
  • Changed setters for char Record fields to accept a single-character strings
  • Changed rtype and length to no longer be settable from Python. Users should use the Record type __init__ methods to initialize records

Bug fixes

  • Added missing Python type stub for CMBP_1 variant in Schema

0.21.0 - 2024-09-24

Enhancements

  • Added --omit-header option to dbn CLI to skip encoding the header row when encoding CSVs
  • Added Python setter for ts_event on all records
  • Upgraded pyo3 version to 0.22.3
  • Added new consolidated publishers for XNAS.BASIC and DBEQ.MAX

Breaking changes

  • Changed handling of write_header parameter for CsvEncoder and DynEncoder. It now determines whether a header is written automatically in general, not only during instantiation of the encoder. This makes it possible to use encode_records and encode_decoded without writing a header
  • CsvEncoder::new creates an encoder that will always try to write a header. Use the builder with write_header(false) to create an encoder that won't write a header row
  • schema is now always optional for the CsvEncoder builder and no longer returns a Result
  • Changed the layout of CbboMsg to better match BboMsg
  • Renamed Schema::Cbbo to Schema::Cmbp1

Bug fixes

  • Removed debug_assert! on rtype in RecordRef::get_unchecked that was too strict. The method is already marked unsafe and it's okay to interpret one record type as another type as long as latter type's size is not greater than the former's

0.20.1 - 2024-08-26

Enhancements

  • Added DynAsyncBufWriter for buffering compressed or uncompressed async output
  • Added new publisher values for XCIS.BBOTRADES and XNYS.BBOTRADES

Bug fixes

  • Added missing Python type stub for pretty_ts_ref in StatMsg

0.20.0 - 2024-07-30

Enhancements

  • Added new SType variants for reference data: Isin, UsCode, BbgCompId, BbgCompTicker, Figi, FigiTicker
  • Added new publisher value for DBEQ.SUMMARY

Breaking changes

  • Renamed SType::Nasdaq variant to SType::NasdaqSymbol
  • Renamed SType::Cms variant to SType::CmsSymbol

0.19.2 - 2024-07-23

Bug fixes

  • Fixed issue where AsyncDynReader would only decode the first frame of multi-frame Zstandard files

0.19.1 - 2024-07-16

Bug fixes

  • Update rtype_dispatch and schema_dispatch macros for BboMsg
  • Update RecordEnum and RecordRefEnum for BboMsg

0.19.0 - 2024-07-09

Enhancements

  • Added BboMsg record struct for future bbo-1m and bbo-1s schemas
  • Upgraded pyo3 version to 0.22.1
  • Upgraded json-writer to 0.4

Breaking changes

  • Added Default trait implementation for Mbp1Msg due to it no longer needing to support multiple rtype values. The default_for_schema function has been removed
  • Changed Bbo1sMsg and Bbo1mMsg to be aliases for BboMsg
  • Changed the default value of the side fields to Side::None
  • Reordered parameters and added defaults to Python Metadata initializer to match required arguments in Rust

0.18.3 - 2024-07-02

Bug fixes

  • Fixed issue where DBN encoders would permit symbols in the metadata that left no space for a null terminator
  • Updated metadata length calculation to respect symbol_cstr_len field rather than inferring the length from version

0.18.2 - 2024-06-18

Enhancements

  • Added new shutdown method to async encoders to more easily ensure the end of output is written and I/O cleaned up. Previously this required a call to .get_mut().shutdown().await
  • Changed AsyncDynWriter and AsyncDbnEncoder::with_zstd to use a zstd checksum like the sync equivalents
  • Added new publisher values for XNAS.BASIC and XNAS.NLS

Bug fixes

  • Fixed bug where DBN metadata would still be upgraded after passing AsIs to DbnDecoder::set_upgrade_policy and AsyncDbnDecoder::set_upgrade_policy

0.18.1 - 2024-06-04

Enhancements

  • Added new stat_type for UncrossingPrice
  • Added new publisher values for XNAS.BASIC
  • Added new off-market publisher values for IFEU.IMPACT and NDEX.IMPACT

Bug fixes

  • Fixed descriptions for FINN and FINY publishers

0.18.0 - 2024-05-21

Enhancements

  • Added links to example usage in documentation
  • Added new predicate methods InstrumentClass::is_option, is_future, and is_spread to make it easier to work with multiple instrument class variants
  • Implemented DecodeRecord for DbnRecordDecoder
  • Added new_inferred, with_buffer, inferred_with_buffer, from_file, get_mut, and get_ref methods to AsyncDynReader for parity with the sync DynReader
  • Improved documentation enumerating errors returned by functions
  • Added new DBNError Python exception that's now the primary exception raised by databento_dbn
  • Improved async performance of decoding DBN files
  • Added StatMsg::ts_in_delta() method that returns a time::Duration for consistency with other records with a ts_in_delta field

Breaking changes

  • Changed type of flags in MboMsg, TradeMsg, Mbp1Msg, Mbp10Msg, and CbboMsg from u8 to a new FlagSet type with predicate methods for the various bit flags as well as setters. The u8 value can still be obtained by calling the raw() method.
    • Improved Debug formatting
    • Python and encodings are unaffected
  • Removed write_dbn_file function deprecated in version 0.14.0 from Python interface. Please use Transcoder instead
  • Switched DecodeStream from streaming_iterator crate to fallible_streaming_iterator to allow better notification of errors
  • Switched EncodeDbn::encode_stream from accepting an impl StreamingIterator to accepting an FallibleStreamingIterator to allow bubbling up of decoding errors
  • Changed default value for stype_in and stype_out in SymbolMappingMsg to u8::MAX to match C++ client and to reflect an unknown value. This also changes the value of these fields when upgrading a SymbolMappingMsgV1 to DBNv2
  • Renamed CbboMsg to CBBOMsg in Python for consistency with other schemas
  • Changed text serialization of display_factor to be affected by pretty_px. While it's not a price, it uses the same fixed-price decimal format as other prices
  • Changed text serialization of unit_of_measure_qty in InstrumentDefMsgV1 to be affected by pretty_px to match behavior of InstrumentDefMsgV2

0.17.1 - 2024-04-04

Bug fixes

  • Added missing Python type stub for StatusMsg

0.17.0 - 2024-04-01

Enhancements

  • Added new record type CbboMsg, new rtypes and schema types for Cbbo, Cbbo1S, Cbbo1M, Tcbbo, Bbo1S, and Bbo1M
  • Added Volatility and Delta StatType variants
  • Added Undefined and TimeProRata MatchAlgorithm variants
  • Exported more enums to Python:
    • Action
    • InstrumentClass
    • MatchAlgorithm
    • SecurityUpdateAction
    • Side
    • StatType
    • StatUpdateAction
    • StatusAction
    • StatusReason
    • TradingEvent
    • TriState
    • UserDefinedInstrument

Breaking changes

  • Removed Default trait implementation for Mbp1Msg due to it now having multiple permissible rtype values. Users should use default_for_schema instead
  • Changed the default match_algorithm for InstrumentDefMsg and InstrumentDefMsgV1 from Fifo to Undefined
  • Made Dataset, Venue, and Publisher non-exhaustive to allow future additions without breaking changes
  • Renamed publishers from deprecated datasets to their respective sources (XNAS.NLS and XNYS.TRADES respectively)

Deprecations

  • Deprecated dataset values FINN.NLS and FINY.TRADES

Bug fixes

  • Fixed an issue where the Python MappingIntervalDict was not exported
  • Fixed Python type stubs for VersionUpgradePolicy and SType

0.16.0 - 2024-03-01

Enhancements

  • Updated StatusMsg and made it public in preparation for releasing a status schema
  • Added StatusAction, StatusReason, TradingEvent, and TriState enums for use in the status schema
  • Added -t and --tsv flags to DBN CLI to encode tab-separated values (TSV)
  • Added delimiter method to builders for DynEncoder and CsvEncoder to customize the field delimiter character, allowing DBN to be encoded as tab-separated values (TSV)
  • Documented cancellation safety for AsyncRecordDecoder::decode_ref (credit: @yongqli)
  • Added new publisher values for consolidated DBEQ.MAX
  • Added C FFI conversion functions from ErrorMsgV1 to ErrorMsg and SystemMsgV1 to SystemMsg
  • Improved documentation for side field and Side enum
  • Upgraded async-compression to 0.4.6
  • Upgraded strum to 0.26

Breaking changes

  • Changed default for VersionUpgradePolicy to Upgrade
  • Changed default upgrade_policy for DbnDecoder, AsyncDbnDecoder, and Python DBNDecoder to Upgrade so by default the primary record types can always be used
  • Changed fields of previously-hidden StatusMsg record type
  • Updated text serialization order of status schema to match other schemas
  • Changed text serialization of unit_of_measure_qty to be affected by pretty_px. While it's not a price, it uses the same fixed-price decimal format as other prices
  • Made StatType and VersionUpgradePolicy non-exhaustive to allow future additions without breaking changes
  • Renamed _dummy field in ImbalanceMsg and StatMsg to _reserved
  • Added ts_out parameter to RecordDecoder and AsyncRecordDecoder with_upgrade_policy methods

Bug fixes

  • Fixed handling of ts_out when upgrading DBNv1 records to version 2
  • Added missing StatType::Vwap variant used in the ICE datasets
  • Fixed an issue with Python stub file distribution
  • Fixed missing handling of ErrorMsgV1 and SystemMsgV1 in rtype dispatch macros

0.15.1 - 2024-01-23

Bug fixes

  • Fixed an import error in the Python type stub file

0.15.0 - 2024-01-16

Enhancements

  • Improved Debug implementation for all record types
    • Prices are formatted as decimals
    • Fixed-length strings are formatted as strings
    • Bit flag fields are formatted as binary
    • Several fields are formatted as enums instead of their raw representations
  • Improved Debug implementation for RecordRef to show RecordHeader
  • Added --schema option to dbn CLI tool to filter a DBN to a particular schema. This allows outputting saved live data to CSV
  • Allowed passing --limit option to dbn CLI tool with --metadata flag
  • Improved performance of decoding uncompressed DBN fragments with the dbn CLI tool
  • Added builders to CsvEncoder, DynEncoder, and JsonEncoder to assist with the growing number of customizations
    • Added option to write CSV header as part of creating CsvEncoder to make it harder to forget
  • Added -s/--map-symbols flag to CLI to create a symbol field in the output with the text symbol mapped from the instrument ID
  • Added version param to Python Metadata constructor choose between DBNv1 and DBNv2
  • Implemented EncodeRecordTextExt for DynEncoder
  • Implemented Deserialize and Serialize for all records and enums (with serde feature enabled). This allows serializing records with additional encodings not supported by the DBN crate
  • Implemented Hash for all record types
  • Added new publisher value for OPRA MIAX Sapphire
  • Added Python type definition for Metadata.__init__
  • Added metadata_mut method to decoders to get a mutable reference to the decoded metadata
  • Improved panic message on RecordRef::get when length doesn't match expected to be actionable
  • Added encode::ZSTD_COMPRESSION_LEVEL constant

Breaking changes

  • Increased size of SystemMsg and ErrorMsg to provide better messages from Live gateway
    • Increased length of err and msg fields for more detailed messages
    • Added is_last field to ErrorMsg to indicate the last error in a chain
    • Added code field to SystemMsg and ErrorMsg, although currently unused
    • Added new is_last parameter to ErrorMsg::new
    • Decoding these is backwards-compatible and records with longer messages won't be sent during the DBN version 2 migration period
    • Renamed previous records to compat::ErrorMsgV1 and compat::SystemMsgV1
  • Split DecodeDbn trait into DecodeRecord and DbnMetadata traits for more flexibility. DecodeDbn continues to exist as a trait alias
  • Moved decode_stream out of DecodeDbn to its own separate trait DecodeStream
  • Changed trait bounds of EncodeDbn::encode_decoded and encode_decoded_with_limit to DecodeRecordRef + DbnMetadata

Bug fixes

  • Fixed panic in TsSymbolMap when start_date == end_date
  • Added missing Python __eq__ and __ne__ implementations for BidAskPair
  • Fixed Python size_hint return value for InstrumentDefMsgV1 and SymbolMappingMsgV1
  • Fixed cases where dbn CLI tool would write a broken pipe error to standard error such as when piping to head
  • Fixed bug in sync and async MetadataEncoders where version was used to determine the encoded length of fixed-length symbols instead of the symbol_cstr_len field

0.14.2 - 2023-11-17

Enhancements

  • Added set_upgrade_policy setters to DbnDecoder, DbnRecordDecoder, AsyncDbnDecoder, and AsyncDbnRecordDecoder
  • Added from_schema classmethod for Python RType enum

Breaking changes

  • Renamed parameter for Python Enum classmethod constructors to value from data.

0.14.1 - 2023-11-17

Enhancements

  • Added new trait compat::SymbolMappingRec for code reuse when working with both versions of SymbolMappingMsg
  • Changed PitSymbolMap::on_symbol_mapping to accept either version of SymbolMappingMsg

Bug fixes

  • Fixed missing DBNv1 compatibility in PitSymbolMap::on_record
  • Fixed missing Python export for VersionUpgradePolicy
  • Fixed missing Python export and methods for InstrumentDefMsgV1 and SymbolMappingMsgV1
  • Fixed bug where Python DbnDecoder and Transcoder would throw exceptions when attempting to decode partial metadata

0.14.0 - 2023-11-15

Enhancements

  • This version begins the transition to DBN version 2 (DBNv2). In this version, the decoders support decoding both versions of DBN and the DBN encoders default to keeping version of the input. However, in a future version, decoders will by default convert DBNv1 to DBNv2 and support will be dropped for encoding DBNv1.
    • Affects SymbolMappingMsg, InstrumentDefMsg, and Metadata. All other record types and market data schemas are unchanged
    • Version 1 structs can be converted to version 2 structs with the From trait
  • Added symbol_cstr_len field to Metadata to indicate the length of fixed symbol strings
  • Added stype_in and stype_out fields to SymbolMappingMsg to provide more context with live symbology updates
  • Added smart wrapping to dbn CLI help output
  • Updated rtype_dispatch family of macros to check record length to handle both versions of records. This is temporary during the transition period
  • Added VersionUpgradePolicy enum and associated methods to the decoders to allow specifying how to handle decoding records from prior DBN versions
  • Added Metadata::upgrade() method to update Metadata from a prior DBN version to the latest version
  • Added -u/--upgrade flags to dbn CLI that when passed upgrades DBN data from previous versions. By default data is decoded as-is
  • Made AsyncDbnDecoder::decode_record, AsyncDbnDecoder::decode_record_ref, dbn::AsyncRecordDecoder::decode, and dbn::AsyncRecordDecoder::decode_ref cancellation safe. This makes them safe to use within a tokio::select!(https://docs.rs/tokio/latest/tokio/macro.select.html) statement
  • Added documentation around cancellation safety for async APIs
  • Improved error messages for conversion errors
  • Added TOB flag to denote top-of-book messages
  • Added new publisher values in preparation for IFEU.IMPACT and NDEX.IMPACT datasets
  • Added new publisher values for consolidated DBEQ.BASIC and DBEQ.PLUS
  • Added MAX_RECORD_LEN constant for the length of the largest record type
  • Exposed record flag constants in databento_dbn with F_ prefix
  • Added export to Python for RType

Breaking changes

  • The old InstrumentDefMsg is now compat::InstrumentDefMsgV1
  • compat::InstrumentDefMsgV2 is now an alias for InstrumentDefMsg
  • The old SymbolMappingMsg is now compat::SymbolMappingMsgV1
  • compat::SymbolMappingMsgV2 is now an alias for SymbolMappingMsg
  • Changed SYMBOL_CSTR_LEN constant to 71. Previous value is now in compat::SYMBOL_CSTR_V1
  • Changed DBN_VERSION constant to 2
  • security_update_action was converted to a raw c_char to safely support adding variants in the future
  • Renamed _dummy in InstrumentDefMsg to _reserved
  • Removed _reserved2, _reserved3, and _reserved5 from InstrumentDefMsg
  • Removed _dummy from SymbolMappingMsg
  • Moved position of strike_price within InstrumentDefMsg but left text serialization order unchanged
  • Made Error non-exhaustive, meaning it can no longer be exhaustively matched against. This allows adding additional error variants in the future without a breaking change
  • Added upgrade_policy parameter to RecordDecoder::with_version constructor to control whether records of previous versions will be upgraded
  • Added upgrade_policy parameter to DynDecoder constructors to control whether records of previous versions will be upgraded
  • Renamed symbol_map parameter for Python Transcoder to symbol_interval_map to better reflect the date intervals it contains

Deprecations

  • Deprecated unused write_dbn_file function from Python interface. Please use Transcoder instead

Bug fixes

  • Fixed typo in Python type definition for InstrumentDefMsg.pretty_high_limit_price
  • Fixed type signature for Metadata.stype_in and Metadata.stype_out Python methods
  • Fixed incorrect version in pyproject.toml

0.13.0 - 2023-10-20

Enhancements

  • Added SymbolMappingMsgV2::new method
  • Added Record trait for all types beginning with a RecordHeader
    • Added new index_ts and raw_index_ts methods to Record trait, which returns the primary timestamp for a record
  • Added RecordMut trait for accessing a mutable reference to a RecordHeader
  • Implemented PartialOrd for all record types, based on raw_index_ts
  • Loosened DbnEncodable from requiring HasRType to only requiring Record. This means RecordRefs and concrete records can be encoded with the same methods

Breaking changes

  • Split part of HasRType into new Record and RecordMut traits, which are object- safe: they can be used in Box<dyn>. RecordRef also implements Record, so it's easier to write code that works for both concrete records as well as RecordRef
  • Removed RecordRef methods made redundant by it implementing Record
  • Removed input_compression parameter from Python Transcoder

Deprecations

  • Deprecated SymbolIndex::get_for_rec_ref, which was made redundant by loosening the trait bound on SymbolIndex::get_for_rec to accept RecordRefs

Bug fixes

  • Fixed TsSymbolMap not always using the correct timestamp for getting the mapped symbol

0.12.0 - 2023-10-16

Enhancements

  • Added map_symbols support to Python Transcoder
  • Added new publisher variants in preparation for DBEQ.PLUS dataset
  • Added from_dataset_venue function to Publisher to facilitate destructuring
  • Implemented Default for most records to make testing easier
  • Added from_zstd function to AsyncDbnEncoder to match synchronous encoder
  • Added re-exports for enums::flags, enums::rtype, record::BidAskPair, record::RecordHeader, and record::WithTsOut to simplify imports
  • Added --fragment CLI flag for writing DBN without the metadata header
  • Added --input-dbn-version CLI option for specifying the DBN version of a DBN fragment
  • Added serde::Deserialize implementations for Dataset, Venue, and Publisher
  • Added support for Python 3.12 to databento_dbn
  • Added RecordDecoder::with_version for future use when dealing with compatibility between different DBN versions
  • Added new dispatch macros: rtype_ts_out_method_dispatch, rtype_ts_out_async_method_dispatch, rtype_method_dispatch, and schema_ts_out_method_dispatch
  • Added InstrumentDefMsgV2 and SymbolMappingMsgV2 for forward compatibility with a version of DBN
  • Added TsSymbolMap and PitSymbolMap to aid with both historical and live symbology
    • Added support for inverse symbology, i.e. with stype_in=InstrumentId

Breaking changes

  • Changed Metadata::symbol_map to return TsSymbolMap
  • Changed Metadata::symbol_map_for_date to return PitSymbolMap
  • Changed Default implementation for BidAskPair by setting prices to UNDEF_PRICE
  • Added new publisher values in preparation for DBEQ.PLUS
  • Added ts_out parameter to encode_header_for_schema in CsvEncoder and DynEncoder to allow controlling whether "ts_out" is in the header

0.11.1 - 2023-10-05

Enhancements

  • Upgraded async-compression to 0.4.3
  • Upgraded csv to 1.3
  • Upgraded num_enum to 0.7

Bug fixes

  • Changed DBN stream detection to ignore the DBN version

0.11.0 - 2023-09-21

Enhancements

  • Added new EncodeRecordTextExt trait which is implemented for the CSV and JSON encoders. It adds two methods for encoding a symbol field along side the rest of the record fields, matching the behavior of map_symbols in the historical API
  • Added encode_header and encode_header_for_schema methods to CsvEncoder and DynEncoder to give more flexibility for encoding CSV headers
  • Added from_file and from_zstd_file functions to AsyncDbnDecoder to match synchronous decoder
  • Implemented Copy for RecordRef to make it behave more like a reference
  • Added AsyncDbnEncoder for simpler DBN encoding and to match sync API
  • Added RecordEnum and RecordRefEnum to more easily be able to pattern match on records of different types
  • Added ARCX.PILLAR.ARCX publisher
  • Added From DBN records for RecordRef
  • Added re-exports to the top level of the crate for all enums and records for simpler imports
  • Added ClosePrice and NetChange StatTypes used in the OPRA.PILLAR dataset

Breaking changes

  • Split encode_record_ref into a safe method with no arguments and an unsafe method with a ts_out parameter to reduce unsafe usage when not working with live data that may contain ts_out

Bug fixes

  • Fixed dbn CLI not writing CSV header when using --fragment and --zstd-fragment flags
  • Fixed lifetime on return value from RecordRef::get_unchecked
  • Fixed missing check for stype_out before building Metadata symbology maps

0.10.2 - 2023-09-12

Bug fixes

  • Fixed query range checking in Metadata::symbol_map_for_date
  • Added debug_assert_eq! check for alignment in RecordRef::new

0.10.1 - 2023-09-07

Bug fixes

  • Changed Metadata::symbol_map and symbol_map_for_date to return String values instead of &str, which made it difficult to use

0.10.0 - 2023-09-07

Enhancements

  • Added start and end getters to Metadata that return time::OffsetDateTime
  • Added symbol_map and symbol_map_for_date methods to Metadata to aid historical symbology mapping from the instrument IDs in records
  • Added DynReader struct for being agnostic about whether an input stream is zstd-compressed
  • Improved safety of RecordRef::get by adding length check
  • Added Python DBN Transcoder class for converting DBN to JSON and CSV with optional zstd compression
  • Added optional has_metadata parameter to Python DBNDecoder to allow decoding plain records by passing False. By default DBNDecoder expects a complete DBN stream, which begins with metadata
  • Added get_ref methods to dbn::Decoder and dbn::RecordDecoder which return a reference to the inner reader
  • Added UNDEF_PRICE, UNDEF_ORDER_SIZE, UNDEF_STAT_QUANTITY, and UNDEF_TIMESTAMP constants to databento_dbn Python package to make it easier to filter null values
  • Added Metadata::builder() function to create a new builder instance

Breaking changes

  • Split out EncodeRecordRef trait from EncodeDbn to have a boxable trait (i.e. Box<dyn EncodeRecordRef>) for dynamic encoding
  • Split out EncodeRecord trait from EncodeDbn
  • Split out DecodeRecordRef trait from DecodeDbn to have a boxable trait (i.e. Box<dyn DecodeRecordRef>) for dynamic decoding
  • Changed DynWriter from an enum to a struct with only private fields

Bug fixes

  • Fixed typo in BATY.PITCH.BATY publisher
  • Fixed typo in README.md (credit: @thomas-k-cameron)

0.9.0 - 2023-08-24

Enhancements

  • Added publisher method to RecordHeader and all record types for converting the publisher_id to an enum
  • Added getters that return time::OffsetDateTime for the following fields: ts_event, ts_recv, ts_ref, activation, expiration, start_ts, end_ts, ts_out
  • Added getters for ts_in_delta that return time::Duration

0.8.3 - 2023-08-15

Bug fixes

  • Fixed missing raw_instrument_id field in Python InstrumentDefMsg
  • Fixed missing OHLCV_EOD variant in Python Schema type hint

0.8.2 - 2023-08-10

Enhancements

  • Added new OhlcvEod schema variant for future use with OHLCV bars based around the end of the trading session
  • Implemented std::fmt::Display for publisher enums (Publisher, Dataset, and Venue)

Bug fixes

  • Fixed Python type hint for Encoding.variants()

0.8.1 - 2023-08-02

Enhancements

  • Added raw_instrument_id field to InstrumentDefMsg (definition schema) for use in future datasets consolidated from multiple publishers
  • Added new OHLCV_EOD rtype for future daily OHLCV schema based on the trading session
  • Added new SType::Nasdaq and SType::Cms to support querying US equities datasets using either convention, regardless of the original convention of the dataset
  • Relaxed pyo3, tokio, and zstd dependency version requirements
  • Added FIXED_PRICE_SCALE constant to databento_dbn Python package
  • Added generated field metadata for each record type to aid in pandas DataFrame creation

Breaking changes

  • Changed size_hint class method to class attribute for Python records

Bug fixes

  • Fixed multi-frame Zstd decoding for async decoders

0.8.0 - 2023-07-19

Enhancements

  • Switched from anyhow::Error to custom dbn::Error for all public fallible functions and methods. This should make it easier to disambiguate between error types
  • EncodeDbn::encode_record and EncodeDbn::record_record_ref no longer treat a BrokenPipe error differently
  • Added AsyncDbnDecoder
  • Added pretty::Px and pretty::Ts newtypes to expose price and timestamp formatting logic outside of CSV and JSON encoding
  • Added interning for Python strings
  • Added rtype to encoded JSON and CSV to aid differeniating between different record types. This is particularly important when working with live data
  • Added pretty_ Python attributes for DBN price fields
  • Added pretty_ Python attributes for DBN UTC timestamp fields

Breaking changes

  • All fallible operations now return a dbn::Error instead of an anyhow::Error
  • Updated serialization order to serialize ts_recv and ts_event first
  • Moved header fields (rtype, publisher_id, instrument_id, and ts_event) to nested object under the key hd in JSON encoding to match structure definitions
  • Changed JSON encoding of all 64-bit integers to strings to avoid loss of precision
  • Updated MboMsg serialization order to serialize action, side, and channel_id earlier given their importance
  • Updated Mbp1Msg, Mbp10Msg, and TradeMsg serialization order to serialize action, side, and depth earlier given their importance
  • Updated InstrumentDefMsg serialization order to serialize raw_symbol, security_update_action, and instrument_class earlier given their importance
  • Removed bool return value from EncodeDbn::encode_record and EncodeDbn::record_record_ref. These now return dbn::Result<()>

Bug fixes

  • Fixed handling of NUL byte when encoding DBN to CSV and JSON
  • Fixed handling of broken pipe in dbn CLI tool

0.7.1 - 2023-06-26

  • Added Python variants method to return an iterator over the enum variants for Compression, Encoding, Schema, and SType
  • Improved Python enum conversions for Compression, Encoding, Schema, and SType

0.7.0 - 2023-06-20

Enhancements

  • Added publishers enums
  • Added export to Python for Compression, Encoding, SType, and Schema enums
  • Improved Python string representation of ErrorMsg and SystemMsg
  • Added async JSON encoder

Breaking changes

  • Dropped support for Python 3.7

Bug fixes

  • Fixed pretty timestamp formatting to match API

0.6.1 - 2023-06-02

  • Added --fragment and --zstd-fragment CLI arguments to read DBN streams without metadata
  • Added csv::Decoder::get_ref that returns reference to the underlying writer
  • Added missing Python getter for InstrumentDefMsg::group
  • Added dataset constants
  • Changed c_char fields to be exposed to Python as str

0.6.0 - 2023-05-26

Enhancements

  • Added --limit NUM CLI argument to output only the first NUM records
  • Added AsRef<[u8]> implementation for RecordRef
  • Added Python size_hint classmethod for DBN records
  • Improved DBN encoding performance of RecordRefs
  • Added use_pretty_px for price formatting and use_pretty_ts for datetime formatting to CSV and JSON encoders
  • Added UNDEF_TIMESTAMP constant for when timestamp fields are unset

Breaking changes

  • Renamed booklevel MBP field to levels for brevity and consistent naming
  • Renamed --pretty-json CLI flag to --pretty and added support for CSV. Passing this flag now also enables use_pretty_px and use_pretty_ts
  • Removed open_interest_qty and cleared_volume fields that were always unset from definition schema
  • Changed Python DBNDecoder.decode to return records with a ts_out attribute, instead of a tuple
  • Rename Python DbnDecoder to DBNDecoder

Bug fixes

  • Fixed Action conversion methods (credit: @thomas-k-cameron)

0.5.1 - 2023-05-05

  • Added Fill action type for MBO messages
  • Added Python type stub for StatMsg

0.5.0 - 2023-04-25

Enhancements

  • Added support for Statistics schema
  • Added RType enum for exhaustive pattern matching
  • Added &str getters for more c_char array record fields
  • Changed DbnDecoder.decode to always return a list of tuples

Breaking changes

  • Changed schema and stype_in to optional in Metadata to support live data
  • Renamed SType::ProductId to SType::InstrumentId and SType::Native to SType::RawSymbol
  • Renamed RecordHeader::product_id to instrument_id
  • Renamed InstrumentDefMsg::symbol to raw_symbol
  • Renamed SymbolMapping::native_symbol to raw_symbol
  • Deprecated SType::Smart to split into SType::Parent and SType::Continuous

Bug fixes

  • Fixed value associated with Side::None
  • Fixed issue with decoding partial records in Python DbnDecoder
  • Fixed missing type hint for Metadata bytes support
  • Added support for equality comparisons in Python classes

0.4.3 - 2023-04-07

  • Fixed typo in Python type stubs

0.4.2 - 2023-04-06

  • Fixed support for ErrorMsg, SystemMsg, and SymbolMappingMsg in Python

0.4.1 - 2023-04-05

Enhancements

  • Added enums MatchAlgorithm, UserDefinedInstrument
  • Added constants UNDEF_PRICE and UNDEF_ORDER_SIZE
  • Added Python type stubs for databento_dbn package

Bug fixes

  • Fixed Metadata.__bytes__ method to return valid DBN
  • Fixed panics when decoding invalid records
  • Fixed issue with attempting to decode partial records in Python DbnDecoder
  • Fixed support for ImbalanceMsg in Python DbnDecoder

0.4.0 - 2023-03-24

Enhancements

  • Added support for Imbalance schema
  • Updated InstrumentDefMsg to include options-related fields and instrument_class
  • Added support for encoding and decoding ts_out
  • Added ts_out to Metadata
  • Improved enum API
  • Relaxed requirement for slice passed to RecordRef::new to be mutable
  • Added error forwarding from DecodeDbn methods
  • Added SystemMsg record
  • Exposed constructor and additional methods for DBN records and Metadata to Python
  • Made RecordRef implement Sync and Send

Breaking changes

  • Introduced separate rtypes for each OHLCV schema
  • Removed record_count from Metadata
  • Changed serialization of c_char fields to strings instead of ints
  • Renamed dbn::RecordDecoder::decode_record to decode
  • Renamed dbn::RecordDecoder::decode_record_ref to decode_ref
  • Renamed HasRType::size to record_size to avoid confusion with order size fields
  • Stopped serializing related and related_security_id fields in InstrumentDefMsg

0.3.2 - 2023-03-01

Enhancements

  • Added records and Metadata as exports of databento_dbn Python package
  • Improved how Metadata appears in Python and added __repr__

Bug fixes

  • Fixed bug where dbn CLI tool didn't truncate existing files

0.3.1 - 2023-02-27

Enhancements

  • Added improved Python bindings for decoding DBN
  • Standardized documentation for start, end, and limit

Bug fixes

  • Fixed bug with encode_metadata Python function

0.3.0 - 2023-02-22

Enhancements

  • Added ability to migrate legacy DBZ to DBN through CLI
  • Relaxed requirement that DBN be Zstandard-compressed
  • Folded in databento-defs
  • Added support for async encoding and decoding
  • Added billable size calculation to dbn CLI
  • Added MetadataBuilder to assist with defaults
  • Refactored into encoder and decoder types

Breaking changes

  • Renamed DBZ to DBN
  • Renamed python package to databento-dbn
  • Moved metadata out of skippable frame

0.2.1 - 2022-12-02

  • Added Python DBZ writing example
  • Changed databento-defs dependency to crates.io version

0.2.0 - 2022-11-28

Enhancements

  • Added interface for writing DBZ files
  • Enabled Zstd checksums
  • Changed DBZ decoding to use streaming-iterator

Breaking changes

  • Changed JSON output to NDJSON

Bug fixes

  • Change nanosecond timestamps to strings in JSON to avoid loss of precision when parsing

0.1.5 - 2022-09-14

  • Initial release