# Changelog All notable changes to this project will be documented in this file. ## [4.1.1] - 2020-11-06 ### Fixed - dead locks in receiving module (see: `spec/receiving/handler_spec.rb#avoid dead locks`) ## [4.1.0] - 2020-11-02 ### Changed - move `TableSync::Instrument.notify` from models to the handler - fire `TableSync::Instrument.notify` after commit insted of in transaction ## [4.0.0] - 2020-10-23 ### Returned - config inheritance ### Removed - TableSync::Plugins ## [3.0.0] - 2020-09-05 ### Added - option `except` - `to_model` in receive method - TableSync::Utils::InterfaceChecker ### Changed - .rubocop.yml - documentation - modules hierarchy (split receiving and publishing) `TableSync::Publisher` -> `TableSync::Publishing::Publisher` `TableSync::BatchPublisher` -> `TableSync::Publishing::BatchPublisher` `TableSync::ReceivingHandler` -> `TableSync::Receiving::Handler` - made data batches processing as native - implemented callbacks as options - implemented `wrap_receiving` as option - type checking in options - `before_commit on: event, &block` -> `before_update(&block)` or `before_destroy(&block)` - `after_commit on: event, &block` -> `after_commit_on_update(&block)` or `after_commit_on_destroy(&block)` - changed parameters in some options: add `raw_data` `current_row` -> `row` ... see documents for details ### Removed - TableSync::Config::CallbackRegistry - TableSync::EventActions - TableSync::EventActions::DataWrapper - config option `on_destroy` - config option `partitions` - config option `first_sync_time_key` ## [2.3.0] - 2020-07-22 ### Added - ruby 2.7 in Travis - Gemfile.lock ### Changed - some fixes to get rid of warnings for ruby 2.7 (implicit conversion of hashes into kwargs will be dropped) - TableSync.sync now explicitly expects klass and kwargs (it converts them into hash) - TableSync::Instrument.notify now explicitly expects kwargs and delegates them further as kwargs ### Removed - ruby 2.3, 2.4 from Travis ## [2.2.0] - 2020-04-12 ### Added - Introduce Plugin ecosystem (**TableSync::Plugins**); ## [2.1.1] - 2020-04-10 ### Fixed - Updated docs for batch_publishing to fully reflect changes in 2.1.0 ## [2.1.0] - 2020-04-09 ### Added - **TableSync::BatchPublisher**: custom headers; - **TableSync::BatchPublisher**: custom events; ### Changed - Slight changes to specs ## [2.0.0] - 2020-04-06 ### Changed - Sequel publishing hooks: checking for `:destroy` events inside `:if`/`:unless` predicates ## [1.13.1] - 2020-03-24 ### Fixed - **TableSync::BatchPublisher**: incorrect `attrs_for_metadata` definition (typo in method name); ## [1.13.0] - 2019-11-02 ### Added - Wrapping interface around receiving logic (`wrap_receiving`); ## [1.12.1] - 2019-09-27 ### Fixed - The `default_values` option no longer overrides original values. ## [1.12.0] - 2019-09-20 ### Changed - Payload for existing ActiveSupport adapter contains both `table` and `schema` fields now. ## [1.11.0] - 2019-09-11 ### Added - Receiving: inconsistent events raises `TableSync::UnprovidedEventTargetKeysError` (events that include only some of the target keys (or none)) ## [1.10.0] - 2019-08-28 ### Added - convert symbolic values to strings in hashes to support older versions of activejob ## [1.9.0] - 2019-07-23 ### Added - add notifications ## [1.8.0] - 2019-07-23 ### Added - `debounce_time` option for publishing ## [1.7.0] - 2019-07-11 ### Added - `on_destroy` return value for manipulation with `after_commit` callback; ## [1.6.0] - 2019-07-08 ### Added - `on_destroy` - defines a custom logic and behavior for `destroy` event;