Skip to content

Latest commit

 

History

History
558 lines (442 loc) · 18.7 KB

CHANGELOG.md

File metadata and controls

558 lines (442 loc) · 18.7 KB

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog and this project adheres to Semantic Versioning.

2.2.1 - 2018-06-17

Fixed

  • Frozen set collections that uses UDTs are not normalized properly and throws schemamismatch error

2.2.0 - 2018-02-03

Changed

  • Separate index per table for elassandra instead of a single index for the whole keyspace. This fixes conflicts where the same fieldname with different datatypes exists in different tables. The index names are now of the format: keyspaceName_tableName

2.1.1 - 2018-01-05

Fixed

  • Reserved keywords not quoted in materialized view where query
  • Some query options were missing in options normalizer

2.1.0 - 2017-12-13

Added

  • Support for materialized view filters added in cassandra 3.10.

Changed

  • SyncDB callback now informs whether any db schema was updated. It returns true if any db schema was updated and false if no schema change was detected.

Fixed

  • Unexpected pause behaviour in fixture import json streamer

2.0.0 - 2017-11-10

Breaking

  • Hooks api has some major changes about how it works. Hooks are no longer asynchronous functions. Instead of callback based error or success to control the corresponding operation, it now requires to return true or false instead. This API change helped us to eliminate some major issues related to hooks and hope to prevent future inconsistencies with it.
  • Custom schema load and sync has been decoupled and the api changed significantly for good. You can now load the schema and syncDB seperately. You have complete control over loading a schema instance and syncing the schema with cassandra. Also calling the init function is now optional.

Added

  • Support for automatic elasticsearch index management and search analytics for Elassandra users
  • Support for automatic graph management and gremlin graph traversals for JanusGraph users
  • Support for auto timestamp and versioning fields. This enables automatic creation and management of versionKey, createdAt and updatedAt fields in cassandra against a schema
  • Support for export/import of data from cassandra to fixture json files
  • Added get_table_name function for model instances
  • Added docs and tests for db_function support

Changed

  • Signifant performance improvement in ORM batches and importer
  • Major refactoring to organise the codebase to keep it maintainable.
  • Upgraded eslint to version 4
  • try-catch instead of try-require for optional modules
  • createTable, createKeyspace are now optional and defaults to true

Fixed

  • Buggy alter logic for materialized views, fixes migration hang issues
  • Unable to query indexed map with multiple entries
  • CamelCased frozen typeDef for UDT incorrectly detect schema mismatch

1.10.0 - 2017-09-06

Changed

  • Removing dse-driver due to license issues. Datastax enterprise users now need to install dse-driver along with express-cassandra to work with datastax enterprise. The dse-driver will be used by express-cassandra if present, otherwise it will fallback to the default cassandra-driver.

Fixed

  • Altering/adding field to UDT fails if out of order

1.9.1 - 2017-08-28

Fixed

  • Patch to support working with tables containing elassandra indexes

1.9.0 - 2017-06-11

Added

  • Support for query operators for light weight transactions
  • Doc to clarify usage of connection policies

1.8.3 - 2017-04-28

Fixed

  • Order by does not work for multiple clustering columns with different order

1.8.2 - 2017-04-21

Added

  • Support for nested directory models

Fixed

  • Semantic versioning issue with dse-driver, uses wrong protocol version

1.8.1 - 2017-04-15

Fixed

  • isModified not working properly for some corner cases

1.8.0 - 2017-04-11

Added

  • Support for custom model instance methods
  • Support for isModified model instance method

1.7.5 - 2017-03-02

Fixed

  • Hook functions are not called on orm batch

1.7.4 - 2017-02-21

Fixed

  • All clients are not properly shutdown on close

1.7.2 - 2017-01-17

Added

  • Truncate table support for cassandra

1.7.1 - 2017-01-16

Added

  • Codeclimate for improving coding standards

Changed

  • Default prepare for prototype batch
  • Safer arguments handling in the prototype.doBatch
  • Updating eslint and fixing new code linting errors

1.7.0 - 2016-12-26

Added

  • Multiple validator support in schema
  • Error message reference in docs

1.6.5 - 2016-12-22

Changed

  • Making rule validator function optional

Fixed

  • Required fields without a validator is not allowed

1.6.4 - 2016-12-22

Fixed

  • Default options are completely overwritten by user provided options in batch query

1.6.3 - 2016-12-22

Changed

  • Validate query_segment instead of parameter

Fixed

  • Empty strings with $in clause throwing errors

1.6.2 - 2016-12-03

Fixed

  • Ignoring dse solr_query index to fix model sync

1.6.1 - 2016-11-30

Fixed

  • Resolved loadSchema callback and promise issue

1.6.0 - 2016-11-30

Added

  • Support for builtin promises in all APIs

1.5.0 - 2016-11-26

Added

  • Support for solr_query and index expression
  • Support for datastax enterprise cassandra

Changed

  • Upgraded to cassandra driver 3.1.6
  • Upgraded travis build cassandra to 3.9

Fixed

  • Proper handling of batches having less than 2 queries
  • Counter update doc with datatype conversions

1.4.2 - 2016-09-28

Fixed

  • Handling typeof null values properly
  • Doc confusions regarding null and unset

1.4.1 - 2016-09-05

Changed

  • Upgraded to cassandra driver 3.1.3

1.4.0 - 2016-09-04

Added

  • Support for hook functions before and after save, update, delete operations
  • Option for disabling tty confirmation on migrations

1.3.3 - 2016-09-02

Fixed

  • Camel cased udts not handled properly

1.3.2 - 2016-08-29

Fixed

  • Whitelist file extensions for modelsync

1.3.1 - 2016-08-29

Fixed

  • Streaming queries ignore materialized_view option
  • Nodejs 4.x error for missing babel-register module

1.3.0 - 2016-08-27

Added

  • Implemented require validator for schema rules
  • Tests for utility functions and require validator

Changed

  • Major refactoring to es2015 with eslint and babel
  • Refactored utility functions seperating concerns

1.2.1 - 2016-08-12

Changed

  • Improving docs with readthedocs build

1.2.0 - 2016-08-11

Added

  • Migrations support without fixture (Experimental)

Changed

  • Refactor using strict mode for all js files
  • Typo in variable name on uda errors

1.1.2 - 2016-07-30

Fixed

  • Tablename issue in alternate model loader

1.1.1 - 2016-07-25

Changed

  • Doc updates for custom sasi indexes
  • Doc reorganization and $like query clarifications

1.1.0 - 2016-07-25

Added

  • Support for sasi and multiple custom indexes

Changed

  • Doc update Long datatype reference link

1.0.3 - 2016-06-28

Added

  • Implemented 'toJSON' model instance method

1.0.2 - 2016-06-23

Changed

  • Making datatypes accessible from within model definitions

1.0.1 - 2016-05-24

Changed

  • Doc update for connecting to cassandra using authProvider

1.0.0 - 2016-05-17

Breaking

  • Consistent data types validation. All datatypes are now cassandra-driver compliant. Such as bigint, counter, uuid etc now use Long, UUID etc classes exposed by the cassandra-driver. Dealing with non javascript compatible datatypes from cassandra now follows the cassandra-driver datatype conversion standards.

Added

  • Support for frozen keyword and tuple data type
  • Support for User defined types, functions and aggregates
  • Support for streaming queries
  • Support for cassandra shared static columns
  • Support for $prepend and $replace operators for collections
  • Support for querying indexed collections
  • Support for altering keyspace replication

0.8.2 - 2016-05-07

Added

  • Support for cassandra authProvider option
  • Support for all cassandra-driver connection options

0.8.1 - 2016-04-26

Added

  • Support for select * in materialized views
  • Support for test coverage

0.8.0 - 2016-04-17

Added

  • Support for composite data types add/remove element

Changed

  • Using database limit for findOne queries

0.7.2 - 2016-04-05

Fixed

  • Instance delete for composite partition keys not working

0.7.1 - 2016-04-03

Added

  • Support for index expressions in find query

Fixed

  • Resolved models.doBatch error when using options

0.7.0 - 2016-03-25

Changed

  • Consistent datatypes handling using nodejs driver params

0.6.4 - 2016-03-08

Changed

  • Clarifying custom index documentation
  • Updated doc for token with composite keys

Fixed

  • Token operator fix for composite partition keys

0.6.3 - 2016-03-02

Added

  • Support for async custom model loading
  • Support for multiple orm connections

0.6.1 - 2016-02-22

Added

  • Support for aggregate functions

0.6.0 - 2016-02-17

Added

  • Support for cassandra 3.x
  • Support for materialized views

0.5.4 - 2016-01-05

Fixed

  • Long types in where clause throws invalidop error

0.5.3 - 2015-12-22

Added

  • Support for maxTimeuuid & minTimeuuid in timeuuid generator

Changed

  • Refactored error messages to be more specific

0.5.2 - 2015-12-12

Added

  • Support for clustering order in primary key definition
  • Support for SELECT DISTINCT through options
  • Option for avoiding keyspace creation

Fixed

  • Uppercase keyspace names not handled properly

0.5.1 - 2015-12-03

Fixed

  • Table not synced for map typeDef changes
  • DB value expression for timestamp columns not consistent
  • Counter columns type handling not consistent
  • Default value for composite types throws errors

0.5.0 - 2015-11-21

Added

  • Support for ORM batch operations

0.4.12 - 2015-11-21

Fixed

  • Instance delete query escaped twice

0.4.11 - 2015-11-21

Added

  • Support for uuid and timeuuid types in where query
  • Added test cases for uuid types

0.4.10 - 2015-11-15

Added

  • Support for nodejs 4 in tests
  • Added uuidFromString() util function

Changed

  • Test cases for timeuuid

Fixed

  • Map types not working with timestamps

0.4.9 - 2015-10-18

Added

  • Support for counter column operations

0.4.8 - 2015-10-13

Fixed

  • Proper handling of undefined values

0.4.7 - 2015-10-04

Changed

  • Exposing function for closing connections

Fixed

  • Instance delete not working consistently

0.4.6 - 2015-10-04

Fixed

  • Instance delete not working consistently

0.4.5 - 2015-10-04

Fixed

  • Instance delete not working properly

0.4.4 - 2015-09-29

Fixed

  • Properly escape composite datatype values

0.4.3 - 2015-09-26

Fixed

  • Virtual fields treated similarly to db fields in some cases

0.4.2 - 2015-09-22

Added

  • Option for setting prepare to false in queries

0.4.1 - 2015-09-09

Added

  • Support for raw client driver interface

0.4.0 - 2015-09-08

Added

  • Support for token pagination operators
  • Support for comparison query operators

0.3.8 - 2015-09-06

Changed

  • Doc update for supported frameworks and minor adjustments

0.3.7 - 2015-09-01

Added

  • FindOne query for single object retrieval

Changed

  • Doc clarify use case of save function

0.3.6 - 2015-08-28

Fixed

  • Find query with $in operator bug

0.3.5 - 2015-08-25

Changed

  • Validation errors are now passed as error on save function callback instead of raising exceptions
  • Refactored codebase for consistent error messages

Fixed

  • Model validations for update operation

0.3.4 - 2015-08-25

Changed

  • Doc clarifications and updates

0.3.3 - 2015-08-24

Added

  • Travis integration for automated tests and build status

0.3.2 - 2015-08-24

Added

  • Mocha test framework and initial test cases

Fixed

  • Proper composite type validations
  • Proper field value expressions for composite types

0.3.1 - 2015-08-23

Fixed

  • Camel cased field names not handled properly

0.3.0 - 2015-08-21

Added

  • Support for composite map, list and set datatypes

0.2.5 - 2015-06-06

Added

  • Support for custom indexes

Changed

  • Refactored code to include modified apollo orm

0.2.4 - 2015-06-03

Added

  • Warning for schema mismatch

0.2.3 - 2015-06-02

Added

  • Support for partial selects in find operations

0.2.2 - 2015-06-02

Added

  • License file

0.2.1 - 2015-06-01

Added

  • Doc for batch query interface

Fixed

  • Build models even if cassandra is not available

0.2.0 - 2015-05-31

Added

  • Initial featureset and documentation
  • Basic ODM with CRUD support
  • Support for virtual fields
  • Support for schema validators
  • Support for auto loading of model schema from directory