All notable changes to this project will be documented in this file. Breaking changes to feature functionality will trigger a new Major Version increase. Significant feature improvements and major bug fixes will trigger Minor Version increases. Small, maintenance and additive changes will trigger Patch Version increases.
- Bulk Operations to return the original object passed to the operation if that object was returned by DynamoDB as unprocessed.
- new
.match()
method to replace original Find method functionality. [read more] - New
template
property on Model for building custom composite key templates. Thetemplate
property also brings forward a new syntax similar to template literal syntax. [read more] - New custom composite key syntax using the
template
property. [read more] - Numeric table keys now possible. Before PK and SK values could only be strings, Numeric Keys are now supported through the
templates
index property. [read more]
- Rename of
facets
property on Model tocomposite
for arrays andtemplate
for string templates. [read more] - Get method now returns
null
when value is not found. Prior functionality returned an empty object. [read more] - Strict enforcement of all SK composite attributes being present when performing
.get()
,.put()
,.create()
,.delete()
,.remove()
,.update()
,.patch()
operations. - Find method now does not add filters for values supplied, Find now only identifies an Index (if possible) and fulfills the Composite Attributes of that Index (if possible). [read more]
- Query Option
lastEvaluatedKeyRaw
when used with pagination replaced Query Optionpager
with option values:"raw"
,"item"
,"named"
. Default set to"named"
. [read more] - Query Option
lastEvaluatedKeyRaw
when used with bulk operations replaced Query Optionunprocessed
with option values:"raw"
,"item"
. Default set to"item"
. [read more]
- Removing
facets
property from documentation, examples, and TypeScript typing. Replaced withcomposite
property for arrays andtemplate
for string templates. [read more] - Fully deprecated custom facet string format. Facet strings defined attributes with a prefixed
:
as in:storeId
would resolve tostoreId
. This has been replaced by thetemplate
syntax, surrounding the attribute with${...}
. [read more]
- Expanding "collection" concept to include sub-collections. Sub-collections will allow for more precise cross-entity queries to be modeled. [read more]
- Addressed edge-case when modeling sparse indexes that would leave unable to be queried via secondary index. [read more]
- Added new syntax for Attribute Property
watch
to trigger whenever any attribute is updated/retrieved. [read more]
- The Attribute Property
readOnly
is now enforced beforewatch
properties are evaluated. This allows properties that use the Attribute Propertywatch
to deliberately circumnavigatereadOnly
enforcement. [read more]
- Added new update methods
append
,add
,subtract
,data
,remove
,delete
, anddata
for improved support of all DynamoDB update methods. [read more]
- The property names of
ExpressionAttributeValues
underwent some change in this release due to the addition of new update operations. This is not a breaking change but if you have tests to match on the exact params returned from ElectroDB these will likely break. [read more]
- New Attribute types
map
,list
,set
. [read more] - New Query Options, and support for,
ReturnValues
as requested in Issue#71. [read more] - New type definitions for recently released update methods
append
,add
,subtract
,data
,remove
, anddelete
. [read more]
- Attributes that have been flagged as
required
are now not possible to be removed (using the update methodremove()
) from a stored Item. This was an oversight from the last release. - Attributes that have been flagged as
hidden
now skips invoking that attribute's getter method.
- Issues that prevented the nesting of update
value()
operation. - TypeScript type definitions for
get()
method now incorporate potential fornull
response. - Type definitions for
value()
andname()
where clause operations.
- New entity method
parse()
to expose ElectroDB formatting for values retrieved outside ElectroDB. [read more]
- Newly added method
parse()
had critical typo. Method now has an improved api, and appropriate tests [read more]
- Added support for choosing the case ElectroDB will use when modeling a Partition or Sort Key. [read more]
- Added support for indexes to use fields that are shared with attribute fields. This should help users leverage ElectroDB with existing tables. [read more]
- Added Query Option
ignoreOwnership
to bypass ElectroDB checks/interrogations for ownership of an item before returning it. [read more]
- Typedef support for RegExp validation on string attributes
- RegExp validation issue resulting in undefined (but not required) values being tested.
- Typing for
.page()
method pager. Now includes the destructured keys associated with the index being queried. [read more] - Adding documentation, and expanding typing for the query option
limit
, for use in.params()
calls. [read more]
- ElectroDB would throw when an
undefined
property was passed to query. This has been changed to not throw if a partial query on that index can be accomplished with the data provided.
- Updates did not include composite attributes involved in primary index. Though these values cannot be changed, they should be
set
on update method calls in case the update results in an item insert. [read more]
- Updates did not include composite attributes involved in primary index. Though these values cannot be changed, they should be
set
on update method calls in case the update results in an item insert. [read more]
- Improved .npmignore to remove playground oriented files, and created official directory to keep playground in sync with library changes.
- Adding Entity identifiers to all update operations. When primary index composite attributes were added in 1.4.4, entities were written properly but did not include the identifiers. This resulted in entities being written but not being readable without the query option
ignoreOwnership
being used.
- Using
add()
update mutation now resolves toADD #prop :prop
update expression instead of aSET #prop = #prop + :prop
- Fixed param naming conflict during updates, when map attribute shares a name with another (separate) attribute.
- Addressed issue#90 to flip batchGet's response tuple type definition.
- Queries will now fully paginate all responses. Prior to this change, ElectroDB would only return items from a single ElectroDB query result. Now ElectroDB will paginate through all query results. This will impact both uses of entity queries and service collections. [read more]
- The query option
limit
has an extended meaning with the change to automatically paginate records on query. The optionlimit
now represents a target for the number of items to return from DynamoDB. If this option is passed, Queries on entities and through collections will paginate DynamoDB until this limit is reached or all items for that query have been returned. [read more]
- A new query option
pages
has been added to coincide with the change to automatically paginate all records when queried. Thepages
option sets a max number of pagination iterations ElectroDB will perform on a query. When this option is paired withlimit
, ElectroDB will respect the first condition reached. [read more]
- Exporting TypeScript interfaces for
ElectroError
andElectroValidationError
- Errors thrown within an attribute's validate callback are now wrapped and accessible after being thrown. Prior to this change, only the
message
of the error thrown by a validation function was persisted back through to the user, now the error itself is also accessible. Reference the exported interface typedef forElectroValidationError
here to see the new properties available on a thrown validation error.
- As a byproduct of enhancing validation errors, the format of message text on a validation error has changed. This could be breaking if your app had a hardcoded dependency on the exact text of a thrown validation error.
- For Set attributes, the callback functions
get
,set
, andvalidate
are now consistently given an Array of values. These functions would sometimes (incorrectly) be called with a DynamoDB DocClient Set.
- In some cases the
find()
andmatch()
methods would incorrectly select an index without a complete partition key. This would result in validation exceptions preventing the user from querying if an index definition and provided attribute object aligned improperly. This was fixed and a slightly more robust mechanism for ranking indexes was made.
- The methods
create
,patch
, andremove
will now refer to primary table keys through parameters via ExpressionAttributeNames when usingattribute_exists()
/attribute_not_exists()
DynamoDB conditions. Prior to this they were referenced directly which would fail in cases where key names include illegal characters. Parameter implementation change only, non-breaking.
- Add
data
update operationifNotExists
to allow for use of the UpdateExpression function "if_not_exists()".
- New feature: "Listeners". Listeners open the door to some really cool tooling that was not possible because of how ElectroDB augments raw DynamoDB responses and did not provide easy access to raw DynamoDB parameters. [read more]
- Adding support for the v3 DynamoDBClient. This change also brings in a new ElectroDB dependency @aws-sdk/lib-dynamodb. [read more]
- Fixed issue#111,
update
method specific query option typing no longer lost when using awhere
method in a query chain - Fixing incorrect typing for exposed
UpdateEntityItem
type. Exported type was missing composite key attributes
- Expected typings for the injected v2 client now include methods for
transactWrite
andtransactGet
- Map attributes will now always resolve to least an empty object on a
create
andput
methods (instead of just the root map) - In the past, default values for property attributes on maps only resolves when a user provided an object to place the values on. Now default values within maps attributes will now always resolve onto the object on
create
andput
methods.
- Solidifying default application methodology: default values for nested properties will be applied up until an undefined default occurs or default callback returns undefined
- Issue impacting the successful propagation loggers and listeners from a Service definition to Entity children
- Removing validation that requires at least one attribute to be provided in a PK composite. This opens the door to static PKs if the user so chooses
- Removing validation that an attribute used for one index cannot be used by another. ElectroDB will now simply validate that all composite attributes associated with an indexed field are identical, and that a field is not used as both a PK and SK in separate indexes. This change allows for LSIs to be used with ElectroDB
- Add new batchGet query option,
preserveBatchOrder
, which will ensure the order returned by a batchGet will be the same as the order provided. [read more]
- TypeScript 4.7 introduced changes that caused type inference issues with the Entity, Service, and exposed types. A re-vamp of some typing was done to rectify these issues, new tests and existing tests were made work with the latest versions of TypeScript and tsd.
- Project now is more deliberate about the types exposed via the package. This is because I have moved away from a single type definition file (which by default exports all types). If you had a dependency on a type that used to be exposed, open a ticket and I can expose it. In the future exposed types will be the only types officially supported by semver.
- Exported additional types
- Reorganizing type definition files into single file again to appease the frontend dependency overlords in https://electrodb.fun
- Adding support for "ProjectionExpressions" via the Query Option:
attributes
[read more]
- Sort keys for queries will now match on equality when all sort key composite attributes are provided in full. Prior to this release, ElectroDB would use
begins_with(...)
which could potentially result in data leakages if a sort key's value was the starting prefix to another sort key value. [read more]
- Added support for attribute types "enum string set" and "enum number set". This will allow users to define a finite list of values (strings or numbers ) supported for a set [read more]
- TypeScript support for "Custom Attributes", bring your own types to express complex attributes. [read more]
[2.0.0] - 2022-09-19 [read more]
- Additional exported types to match new response structures. [read more]
- Changing response structure on all methods to be an object with query results on a
data
property. [read more] - Pagination is now performed via the
.go()
terminal method, and the LastEvaluatedKey is now returned a stringcursor
. [read more] - The
go()
terminal method now only queries one page by default. To auto-page (to match functionality prior to this change), pass the query optionpages
with a value of'all'
. [read more]
- The boolean query option
raw
andreturnKeys
have been deprecated (still accepted for the time being) and replaced with the query optiondata
, which accepts the values'raw'
,'includeKeys'
,'attributes'
orundefined
.
.page()
terminal method. All pagination is now done through the.go()
method. Queries and scans now return acursor
property (of type "string") to be passed on subsequent pagination requests. [read more]
- Added a new attribute property
padding
to aid with zero padding patterns. [read more]
- Defect with sort key composition that would treat falsely values as absent attributes.
- Now exporting
ElectroValidationError
andElectroError
as classes, so they can be more easily interrogated/triaged by user error handling.
- On
update
andpatch
operations, thedata
method did not properly apply mutation constraints forrequired
andreadOnly
. Data will now correctly throw in a similar manner the to individual mutation methods.
- A BIG addition to the library: Clustered Indexes. Clustered indexes allow for Collections to be composed of more similar, homogenous data.
- The addition of new Entity and Service methods:
setTableName
,getTableName
,setClient
,getClient
.
- Addressed GitHub issue #144, root map attributes would set an empty object regardless if the user supplied it.
- (since rolled back)
The return type from an update/patch call now returns an Entity item whenall_new
orall_old
response options are passed
- Backed out the response typing change added in
2.2.2
. The type of record coming back from an update is more complex than one might expect. Because update operations can result in a record insert, the response type is not necessarily a TableItem. I am backing out this change for now until I can be more sure of an appropriate typing.
- New function to help with Custom Types: CustomAttributeType. This replaces
createCustomAttribute
(now depreciated) because of the unfortunate widening caused by the initial implementation. [read more)]
- The function
createCustomAttribute
is now deprecated. The function still operates as it did, though any changes related to Custom Attribute types will see development focused onCustomAttributeType
rather than this function.
- Addressed issue#162: attribute validation functions were not invoked when updating through the
data
method. - Conditional filters can now be added to
get
operations. DynamoDBget
does not allow for filtering but the TransactWrite/TransactGet methods allow forConditionCheck
which is essentiallyget
+conditions
.
- Addressed issue#172, where clause mishandling of nested attribute references
- Addressed issue where scans would incorrectly accumulate filters across usages
- Adding new update method:
upsert
. Upsert is similar toput
in that it will create a record if one does not exist, exceptupsert
perform an update if that record already exists.
- Address issue#179, the query option
table
was not correctly propagated, resulting a failure for that declared the table name was "missing"
- Upsert method would silently disregard
where
clause usage, and would not add condition expression to parameters.
- Issue #182: Addressed inconsistency with
remove
anddelete
functionality betweenupdate
andpatch
methods.
- First code contribution by user @NoahDavey (via PR-197). Fixes boolean evaluation during upsert
- Fixes issue that resulted in provided undefined values from becoming involuntarily set via updates
- Updated documentation links in error message to direct traffic to https://electrodb.dev
- Adds the new filter expression methods:
size()
,type()
andescape
. Addresses Issue#208 [read more] - Adds the
createSchema()
function for helping create and type ElectroDB schemas without instantiating an Entity. Addresses Issue#167. [read more]
- Recently added
createSchema()
function would validate but not return the schema object provided
- Restores
ignoreOwnership
execution option. Addresses Issue #194 which calls out regression withignoreOwnership
. This flag is now appropriately applied to "query", "get", and "scan" operations.
- Adds transaction functionality:
get
andwrite
transactions are now supported in ElectroDB via transact write and transact get methods.
- The previous version exported typings directly from the AWS dynamodb client package which, because it was so large, caused the playground to take a massive performance hit. Instead, the library now expose a simplistic version of those types instead.
- Adds new query execution option
hydrate
. When a GSI uses aKEYS_ONLY
projection, thehydrate
option will perform the query and then a subsequentbatchGet
to "hydrate" the results. - Adds new
conversion
methods to help transform values between "composite attributes", "keys", and "cursors". - Adds improved return typing for
patch
operations. The response type forpatch
now returns an Entity item when passed the execution options{ response: 'all_new' }
or{ response: 'all_old' }
.
- A common issue amongst new users, was unexpected errors when using a terminal method twice on a query chain. This would often come up when a user called
.params()
to log out parameters and then call.go()
on the same chain. The fix was to prevent duplicative side effects from occurring on each subsequent terminal method call. - Fixes typing issue with transactGet api that would type
response.data
asnever
when the transaction included more than one element.
- For queries, ElectroDB now trims the ExclusiveStartKey object to only include the keys associated with the index provided. DynamoDB currently rejects queries when properties not associated with the keys of the queried index are provided on the ExclusiveStartKey. By removing irrelevant properties, ElectroDB offers users more flexibility and opportunities for dynamic querying.
- Fixes return typing for
delete
,remove
,update
andupsert
operations. These types were incorrect and did not reflect the real values returned. Instead of breaking the APIs, changing response types toT | null
, the new response type is now the Entity's key composite values by default. You can also now use the Execution Optionresponse
to get back the item as it exists in the table. This is the closed I could get to a non-breaking change that also fixes the incorrect return typing for these methods. - Fixes typing for
contains
where conditions to accept collection element values (e.g.,set
andlist
type attributes). - The exported type
UpdateEntityItem
was incorrectly typed, it now includes the correct typing as the values that can be passed to theset
method
- Upsert operations now take into consideration
readOnly
attributes when applying changes. If an attribute is configured asreadOnly
ElectroDB will apply the property with anif_not_exists
set operation to prevent overwriting the existing value if one is set.
- Upsert now only allies
if_not_exists()
if the attribute is not a composite attribute in an index.
- Fixed bug reported via Issue #271: Root map object with required flag would not set empty object even when it was provided.
- Adds new
cast
option for indexes to allow users to cast index values to a different type than their composite attribute. This change comers from a user requested feature and addresses issue #237
- Fixed edge case when model defines an index without composites while using the template syntax that prevented
ignoreOwnership
from correctly gating return records
- Fixes bug with creating sets when client is provided or changed after initial Entity construction
- Fixes bug reported via Issue #281: ElectroDB failed to use an attribute's
field
name when it was updated viawatch
. - Fixes bug reported via Issue #229: ElectroDB would generate empty string keys on item creating. This would occur only in cases where a key's field name matched an attribute's field name.
- Relaxes validation surrounding the use of composite attributes appearing as composite attributes in both the partition and sort key for the same index. Reported in Issue#265, validation surrounding this pattern have been relaxed to only throw when a composite attribute in both the pk and sk AND the sk contains greater than one composite attribute. This constraint is critical for ElectroDB to reliably generate/format sort key values.
- Addresses Issue #277 Introduces new
composite()
method forupdate
andpatch
operations. Thecomposite
method is used to help electrodb complete and format keys when updating a subset of the key's composite attributes. Prior to this update, updating a key partially resulted in an invalid query error, which caused difficulties when some composite attributes were flagged as readOnly. [read more] - Adds more deliberate collection validation to ensure entity compatibility. This will allow for indexes defined with "template" be used with collections. This also might cause some existing implementations to now throw on service instantiation, however that would mean these services were never valid to begin with.
- Version
2.9.0
was accidentally published without the dependency@aws-sdk/lib-dynamodb
- The
composite()
method forupdate
andpatch
now adds a condition expression that allows for cases where the composite attribute doesn't exist. Prior to this change the condition used a strict equals check on the attribute value (e.g.#prop1 = :prop1
). This change now revises that expression to(#prop1 = :prop1 OR attribute_not_exists(#prop1))
.
- Reverts change in
2.9.2
. Thecomposite()
method no longer allows forattribute_not_exists()
.
- Composite attributes that used the attribute option
watch
, and were not provided to thecreate
orput
methods, were not property applied to their composite keys. This addresses the issue brought forward in discussion #292.
- The
upsert
method now supportsadd
,subtract
,append
,set
, andifNotExists
operations. Addresses Issue #286. - The
add
andsubtract
operations provided to thedata
callback operation withupdate
andpatch
methods now supports a third parameter for supply a defaultValue. Addresses Issue #297. - A condition expression operation called
field
that allows for references to raw field names as they exist in the table. This can be used withescape
andvalue
to create custom filter expressions.
- Transact
upsert
now supportsadd
,subtract
,append
,set
, andifNotExists
operations. Addresses Issue #301.
- Addresses Issue #308 and Issue #228
- Addresses edge case that filtered valid items when item lacked entity identifiers (created outside ElectroDB) when keys (pk or sk) were numeric.
NOTE: This version is depricated, this version introduced code that significantly increased latency. That code was fixed in
2.10.7
- Adds
cause
property toElectroError
, currently populated when error originates from the AWS Client, to help with error triage. This also adds the ability to provide an error type to ElectroError to type the error located oncause
.
- Addresses bug in
patch
andupdate
methods that caused key composite attributes to be set with their attribute name not their "field" name. This would impact users who both use theupdate
method to create new items and use alternative field name definitions for their composite keys. All other users would likely be silently impacted by this issue.
- Addresses Issue #321, fixing expression attribute name and value formatting to remove non-alphanumeric and underscore characters.
- Fixes latency issue introduced in
2.10.4
affecting all queries discovered and brought forward by Ross Gerbasi. Thank you, Ross Gerbasi!
- Adds new property
scope
to index definitions, allowing users to further isolate partition keys beyond justservice
participation. This implements an RFC that was thoughtfully put forward by @Sam3d in Issue #290. Thank you, Brooke for your contribution!
- Adds support for nested usage of
any
andCustomAttributeType
attribute types. Prior to this release,any
andCustomAttributeType
could only be used with root attributes. This change adds support forCustomAttributeType
to be used withmap
attributes. - Adds new
condition
property on index definitions to prevent unnecessary GSI writes & hot partitions for certain data models. The providedcondition
callback will be invoked at query-time, passed all attributes set on that mutation, and if it returnsfalse
the index will not be written to your DynamoDB table. Addresses Issue #330.