b662f8c0a
#4168 - Release Firestore Bundles (pre-packaged Firestore data). For NPM users, this can be enabled via an additional import: 'firebase/firestore/bundle'. For CDN usage, it is enabled by default.
1b5407372
#4153 - A write to a document that contains FieldValue transforms is no longer split up into two separate operations. This reduces the number of writes the backend performs and allows each WriteBatch to hold 500 writes regardless of how many FieldValue transformations are attached.
- Updated dependencies [
b662f8c0a
]:- @firebase/[email protected]
8993f16b8
#4136 (fixes #4125) - Fixes an issue that returned invalidDocumentReference
s inQuerySnapshot
s.
-
9822e125c
#4078 - Fix an issue that preventedexperimentalAutoDetectLongPolling
from working correctly. -
Updated dependencies [
9822e125c
]:- @firebase/[email protected]
e0bf3f70b
#4080 (fixes #4071) - Fixes a regression introduced in v8.0.2 that returned invalid values forDocumentChange.newIndex
.
d2adf4e3e
#4051 - Fixed an issue that causedDocumentReference
s inDocumentSnapshot
s to be returned with the custom converter of the originalDocumentReference
.
-
007ddd1eb
#4030 - Internal changes to support upcoming modular API. -
Updated dependencies [
9cf727fcc
]:- @firebase/[email protected]
- @firebase/[email protected]
344bd8856
#3943 - Removed depreactedexperimentalTabSynchronization
settings. To enable multi-tab sychronization, usesynchronizeTabs
instead.
4b540f91d
#3939 - This releases removes all input validation. Please use our TypeScript types to validate API usage.
ffef32e38
#3897 (fixes #3879) - Removed thetimestampsInSnapshots
option fromFirestoreSettings
. Now, Firestore always returnsTimestamp
values for all timestamp values.
9719635fe
#3960 - Removed excess validation of null and NaN values in query filters. This more closely aligns the SDK with the Firestore backend, which has always accepted null and NaN for all operators, even though this isn't necessarily useful.
-
a5768b0aa
#3932 - Point browser field to esm build. Now you need to use default import instead of namespace import to import firebase.Before this change
import * as firebase from 'firebase/app';
After this change
import firebase from 'firebase/app';
-
Updated dependencies [
a5768b0aa
,79b049375
,ffef32e38
,7d916d905
]:- @firebase/[email protected]
- @firebase/[email protected]
- @firebase/[email protected]
4f997bce1
#3724 - Adds a newexperimentalAutoDetectLongPolling
to FirestoreSettings. When enabled, the SDK's underlying transport (WebChannel) automatically detects if long-polling should be used. This is very similar toexperimentalForceLongPolling
, but only uses long-polling if required.
-
2bea0a367
#3919 - Fixed a potential issue in our internal queue that could have allowed API calls to be executed out of order. -
Updated dependencies [
4f997bce1
]:- @firebase/[email protected]
- @firebase/[email protected]
a10c18f89
#3871 - The SDK now include more information in the error message for failed IndexedDB transactions.
4dc8817c3
#3821 - Fixes an issue that preventswaitForPendingWrites()
from resolving in background tabs when multi-tab is used (firebase#3816).
16c6ba979
#3820 (fixes #3814) - Fixes a "Comparison with -0" lint warning for customers that build from source.
f9004177e
#3772 - [feature] Addednot-in
and!=
query operators for use with.where()
.not-in
finds documents where a specified field’s value is not in a specified array.!=
finds documents where a specified field's value does not equal the specified value. Neither query operator will match documents where the specified field is not present.
-
e81c429ae
#3755 (fixes #3742) - Fixed a bug where CollectionReference.add() called FirestoreDataConverter.toFirestore() twice intead of once (#3742). -
Updated dependencies [
f9004177e
,a8ff3dbaa
]:- @firebase/[email protected]
-
249d40cb6
#3700 - Fixes a bug that caused the client to not raise snapshots from cache if a user change happened while the network connection was disabled. -
Updated dependencies [
da1c7df79
,fb3b095e4
]:- @firebase/[email protected]
- @firebase/[email protected]
61b4cd31b
#3464 (fixes #3354) - feat: Addedmerge
option tofirestore.settings()
, which merges the provided settings with settings from a previous call. This allows adding settings on top of the settings that were applied by@firebase/testing
.- Updated dependencies [
61b4cd31b
]:- @firebase/[email protected]
960093d5b
#3575 (fixes #2755) -terminate()
can now be retried if it fails with an IndexedDB exception.
b97c7e758
#3487 - Enable fallback for auto-generated identifiers in environments that supportcrypto
but notcrypto.getRandomValues
.
36be62a8
#3535 (fixes #3495) - The SDK no longer crashes with the error "The database connection is closing". Instead, the individual operations that cause this error may be rejected.
-
68995c24
#3586 - Fixed a bug that caused slow retries for IndexedDB operations even when a webpage re-entered the foreground. -
Updated dependencies [
d4ca3da0
]:- @firebase/[email protected]
- @firebase/[email protected]
- Updated dependencies [
7f0860a4
]:- @firebase/[email protected]
- Updated dependencies [
a87676b8
]:- @firebase/[email protected]
- @firebase/[email protected]
5a355360
#3162 Thanks @schmidt-sebastian! - The SDK no longer crashes if an IndexedDB failure occurs when unsubscribing from a Query.
9a9a81fe
#3279 Thanks @schmidt-sebastian! - [fixed] Removed a delay that may have prevented Firestore from immediately reestablishing a network connection if a connectivity change occurred while the app was in the background.
39ca8ecf
#3254 Thanks @thebrianchen! - Added support forset()
with merge options when usingFirestoreDataConverter
.
877c060c
#3251 Thanks @schmidt-sebastian! - Re-adding the ReactNative bundle, which allows Firestore to be used withoutbtoa
/atob
Polyfills.
-
e90304c8
#3309 Thanks @schmidt-sebastian! - Removed internal wrapper around our public API that was meant to prevent incorrect SDK usage for JavaScript users, but caused our SDK to stop working in IE11. -
Updated dependencies [
a754645e
,39ca8ecf
]:- @firebase/[email protected]
- @firebase/[email protected]
- @firebase/[email protected]
-
[fixed] Fixed an issue that may have prevented the client from connecting to the backend immediately after a user signed in.
-
[feature] Added an
experimentalForceOwningTab
setting that can be used to enable persistence in environments without LocalStorage, which allows persistence to be used in Web Workers (#983). -
[changed] All known failure cases for Indexed-related crashes have now been addressed. Instead of crashing the client, IndexedDB failures will result in rejected operations (e.g. rejected Writes or errored Query listeners). If these rejections surface in your app, you can retry these operations when IndexedDB access is restored. IndexedDB failures that occur due to background work are automatically retried.
If you continue to see Indexed-related crashes, we appreciate feedback (firebase#2755).
- [fixed] Fixed an issue that could cause Firestore to temporarily go offline when a Window visibility event occurred.
- [feature] Added support for calling
FirebaseFiresore.settings
with{ ignoreUndefinedProperties: true }
. When set, Firestore ignores undefined properties inside objects rather than rejecting the API call.
- [fixed] Fixed a regression introduced in v7.14.2 that incorrectly applied
a
FieldValue.increment
in combination withset({...}, {merge: true})
.
- [fixed] Firestore now rejects
onSnapshot()
listeners if they cannot be registered in IndexedDB. Previously, these errors crashed the client.
- [fixed] Firestore now rejects write operations if they cannot be persisted in IndexedDB. Previously, these errors crashed the client.
- [fixed] Fixed a source of IndexedDB-related crashes for tabs that receive multi-tab notifications while the file system is locked.
- [fixed] Temporarily reverted the use of window.crypto to generate document IDs to address compatibility issues with IE 11, WebWorkers, and React Native.
- [changed] Firestore now limits the number of concurrent document lookups it will perform when resolving inconsistencies in the local cache (#2683).
- [changed] Changed the in-memory representation of Firestore documents to
reduce memory allocations and improve performance. Calls to
DocumentSnapshot.getData()
andDocumentSnapshot.toObject()
will see the biggest improvement.
- [fixed] Fixed an issue where the number value
-0.0
would lose its sign when stored in Firestore.
- [feature] Implemented
Timestamp.valueOf()
so thatTimestamp
objects can be compared for relative ordering using the JavaScript arithmetic comparison operators (#2632). - [fixed] Fixed an issue where auth credentials were not respected in Cordova environments (#2626).
- [fixed] Fixed a performance regression introduced by the addition of
Query.limitToLast(n: number)
in Firestore 1.7.0 (Firebase 7.3.0) (#2620). - [fixed] Fixed an issue where
CollectionReference.add()
would reject custom types when usingwithConverter()
(#2606).
- [fixed] Fixed an issue where auth credentials were not respected in some Firefox or Chrome extensions. (#1491)
- [changed] Firestore previously required that every document read in a transaction must also be written. This requirement has been removed, and you can now read a document in transaction without writing to it.
- [fixed] Fixed an issue where auth credentials were not respected in certain browser environments (Electron 7, IE11 in trusted zone, UWP apps). (#1491)
- [feature] Added support for storing and retrieving custom types in Firestore.
Added support for strongly typed collections, documents, and
queries. You can now use
withConverter()
to supply a custom data converter that will convert between Firestore data and your custom type.
- [changed] Improved the performance of repeatedly executed queries when
persistence is enabled. Recently executed queries should see dramatic
improvements. This benefit is reduced if changes accumulate while the query
is inactive. Queries that use the
limit()
API may not always benefit, depending on the accumulated changes.
- [changed] The client can now recover if certain periodic IndexedDB operations fail.
- [feature] Added
in
andarray-contains-any
query operators for use with.where()
.in
finds documents where a specified field’s value is IN a specified array.array-contains-any
finds documents where a specified field is an array and contains ANY element of a specified array. - [feature] Added
Query.limitToLast(n: number)
, which returns the lastn
documents as the result.
- [changed] Improved iOS 13 support by eliminating an additional crash in our IndexedDB persistence layer.
- [changed] Fixed a crash on iOS 13 that occurred when persistence was enabled in a background tab (#2232).
- [fixed] Fixed an issue in the interaction with the Firestore Emulator that caused requests with timestamps to fail.
- [feature] Added a
Firestore.onSnapshotsInSync()
method that notifies you when all your snapshot listeners are in sync with each other. - [fixed] Fixed a regression that caused queries with nested field filters to crash the client if the field was not present in the local copy of the document.
- [feature] Added a
Firestore.waitForPendingWrites()
method that allows users to wait until all pending writes are acknowledged by the Firestore backend. - [feature] Added a
Firestore.terminate()
method which terminates the instance, releasing any held resources. Once it completes, you can optionally callFirestore.clearPersistence()
to wipe persisted Firestore data from disk. - [changed] Improved performance for queries with filters that only return a small subset of the documents in a collection.
- [fixed] Fixed a race condition between authenticating and initializing Firestore that could result in initial writes to the database being dropped.
- [changed] Transactions now perform exponential backoff before retrying. This means transactions on highly contended documents are more likely to succeed.
- [changed] Transactions are now more flexible. Some sequences of operations that were previously incorrectly disallowed are now allowed. For example, after reading a document that doesn't exist, you can now set it multiple times successfully in a transaction.
- [fixed] Fixed an issue where query results were temporarily missing documents that previously had not matched but had been updated to now match the query (firebase/firebase-android-sdk#155).
- [fixed] Fixed an internal assertion that was triggered when an update
with a
FieldValue.serverTimestamp()
and an update with aFieldValue.increment()
were pending for the same document.
- [changed] Added logging and a custom error message to help users hitting https://bugs.webkit.org/show_bug.cgi?id=197050 (a bug in iOS 12.2 causing the SDK to potentially crash when persistence is enabled).
- [fixed] Fixed an issue for environments missing
window.addEventListener
, such as in React Native with Expo (#1824).
- [feature] Added
clearPersistence()
, which clears the persistent storage including pending writes and cached documents. This is intended to help write reliable tests (#449).
- [changed] Firestore now recovers more quickly after network connectivity changes (airplane mode, Wi-Fi availability, etc.).
- [changed] Deprecated the
experimentalTabSynchronization
setting in favor ofsynchronizeTabs
. If you use multi-tab synchronization, it is recommended that you update your call toenablePersistence()
. Firestore logs an error if you continue to useexperimentalTabSynchronization
. - [feature] You can now query across all collections in your database with a
given collection ID using the
FirebaseFirestore.collectionGroup()
method.
- [feature] Added an
experimentalForceLongPolling
setting that that can be used to work around proxies that prevent the Firestore client from connecting to the Firestore backend.
- [changed] Increased a connection timeout that could lead to large writes perputually retrying without ever succeeding (#1447).
- [fixed] Fixed an issue with IndexedDb persistence that triggered an internal assert for Queries that use nested DocumentReferences in where() clauses (#1524, #1596).
- [fixed] Fixed an issue where transactions in a Node.JS app could be sent without auth credentials, leading to Permission Denied errors.
- [feature] Added
FieldValue.increment()
, which can be used inupdate()
andset(..., {merge:true})
to increment or decrement numeric field values safely without transactions. - [changed] Prepared the persistence layer to support collection group queries. While this feature is not yet available, all schema changes are included in this release. Once you upgrade, you will not be able to use an older version of the Firestore SDK with persistence enabled.
- [changed] Improved performance when querying over documents that contain subcollections.
- [fixed] Fixed an uncaught promise error occurring when
enablePersistence()
was called in a second tab (#1531).
- [changed] The
timestampsInSnapshots
setting is now enabled by default. Timestamp fields that read from aDocumentSnapshot
are now returned asTimestamp
objects instead ofDate
objects. This is a breaking change; developers must update any code that expects to receive aDate
object. See https://firebase.google.com/docs/reference/js/firebase.firestore.Settings#~timestampsInSnapshots for more details. - [fixed] Fixed a crash that could happen when the app is shut down after a write has been sent to the server but before it has been received on a listener.
- [fixed] Fixed a regression introduced in 5.7.0 that caused apps using experimentalTabSynchronization to hit an exception for "Failed to obtain primary lease for action 'Collect garbage'".
- [changed] Added a custom error for schema downgrades.
- [changed] Removed eval()-based fallback for JSON parsing, allowing SDK to be used in environments that prohibit eval().
- [feature] Added a garbage collection process to on-disk persistence that
removes older documents. This is enabled automatically if persistence is
enabled, and the SDK will attempt to periodically clean up older, unused
documents once the on-disk cache passes a threshold size (default: 40 MB).
This threshold can be configured by changing the setting
cacheSizeBytes
in the settings passed toFirestore.settings()
. It must be set to a minimum of 1 MB. The garbage collection process can be disabled entirely by settingcacheSizeBytes
toCACHE_SIZE_UNLIMITED
.
- [fixed] Fixed an issue that prevented query synchronization between multiple tabs.
- [fixed] Fixed an issue where native ES6 module loading was not working.
- [fixed] Fixed an issue where typings are created in the wrong location.
- [feature] Access to offline persistence is no longer limited to a single tab.
You can opt into this new experimental mode by invoking
enablePersistence()
with{experimentalTabSynchronization: true}
. All tabs accessing persistence must use the same setting for this flag. - [fixed] Fixed an issue where the first
get()
call made after being offline could incorrectly return cached data without attempting to reach the backend. - [changed] Changed
get()
to only make one attempt to reach the backend before returning cached data, potentially reducing delays while offline. - [fixed] Fixed an issue that caused Firebase to drop empty objects from calls
to
set(..., { merge: true })
. - [changed] Improved argument validation for several API methods.
- [changed] Changed the internal handling for locally updated documents that
haven't yet been read back from Firestore. This can lead to slight behavior
changes and may affect the
SnapshotMetadata.hasPendingWrites
metadata flag. - [changed] Eliminated superfluous update events for locally cached documents that are known to lag behind the server version. Instead, we buffer these events until the client has caught up with the server.
- [fixed] Fixed a regression that prevented use of Firestore on ReactNative's Expo platform (#1138).
- [fixed] Fixed
get({source: 'cache'})
to be able to return nonexistent documents from cache. - [changed] Prepared the persistence layer to allow shared access from multiple tabs. While this feature is not yet available, all schema changes are included in this release. Once you upgrade, you will not be able to use an older version of the Firestore SDK with persistence enabled.
- [fixed] Fixed an issue where changes to custom authentication claims did not take effect until you did a full sign-out and sign-in. (firebase/firebase-ios-sdk#1499)
- [changed] Improved how Firestore handles idle queries to reduce the cost of re-listening within 30 minutes.
- [changed] Improved offline performance with many outstanding writes.
- [fixed] Fixed an issue where queries returned fewer results than they should, caused by documents that were cached as deleted when they should not have been (firebase/firebase-ios-sdk#1548). Because some cache data is cleared, clients might use extra bandwidth the first time they launch with this version of the SDK.
- [feature] Added
firebase.firestore.FieldValue.arrayUnion()
andfirebase.firestore.FieldValue.arrayRemove()
to atomically add and remove elements from an array field in a document. - [feature] Added
'array-contains'
query operator for use with.where()
to find documents where an array field contains a specific element.
- [changed] Merged the
includeQueryMetadataChanges
andincludeDocumentMetadataChanges
options passed toQuery.onSnapshot()
into a singleincludeMetadataChanges
option. - [changed]
QuerySnapshot.docChanges()
is now a method that optionally takes anincludeMetadataChanges
option. By default, even when listening to a query with{ includeMetadataChanges:true }
, metadata-only document changes are suppressed indocChanges()
. - [feature] Added new
{ mergeFields: (string|FieldPath)[] }
option toset()
which allows merging of a reduced subset of fields.
- [fixed] Fixed a regression in Firebase JS release 4.13.0 regarding the loading of proto files, causing Node.JS support to break.
- [feature] Added a new
Timestamp
class to represent timestamp fields, currently supporting up to microsecond precision. It can be passed to API methods anywhere a JS Date object is currently accepted. To makeDocumentSnapshot
s read timestamp fields back asTimestamp
s instead of Dates, you can set the newly added flagtimestampsInSnapshots
inFirestoreSettings
totrue
. Note that the current behavior (DocumentSnapshot
s returning JS Date objects) will be removed in a future release.Timestamp
supports higher precision than JS Date. - [feature] Added ability to control whether DocumentReference.get() and Query.get() should fetch from server only, (by passing { source: 'server' }), cache only (by passing { source: 'cache' }), or attempt server and fall back to the cache (which was the only option previously, and is now the default).
- [fixed] Fixed a regression in the Firebase JS release 4.11.0 that could cause get() requests made while offline to be delayed by up to 10 seconds (rather than returning from cache immediately).
- [fixed] Fixed a regression in the Firebase JS release 4.11.0 that could cause a crash if a user signs out while the client is offline, resulting in an error of "Attempted to schedule multiple operations with timer id listen_stream_connection_backoff".
- [changed] If the SDK's attempt to connect to the Cloud Firestore backend neither succeeds nor fails within 10 seconds, the SDK will consider itself "offline", causing get() calls to resolve with cached results, rather than continuing to wait.
- [fixed] Fixed a potential race condition after calling
enableNetwork()
that could result in a "Mutation batchIDs must be acknowledged in order" assertion crash.
- [fixed] Fixed a regression in Firebase JS release 4.9.0 that could in certain cases result in an "OnlineState should not affect limbo documents." assertion crash when the client loses its network connection.
- [changed] Snapshot listeners (with the
includeMetadataChanges
option enabled) now receive an event withsnapshot.metadata.fromCache
set totrue
if the SDK loses its connection to the backend. A new event withsnapshot.metadata.fromCache
set to false will be raised once the connection is restored and the query is in sync with the backend again. - [feature] Added
SnapshotOptions
API to control how DocumentSnapshots return unresolved server timestamps. - [feature] Added
disableNetwork()
andenableNetwork()
methods toFirestore
class, allowing for explicit network management. - [changed] For non-existing documents,
DocumentSnapshot.data()
now returnsundefined
instead of throwing an exception. A newQueryDocumentSnapshot
class is introduced for Queries to reduce the number of undefined-checks in your code. - [added] Added
isEqual
API toGeoPoint
,Blob
,SnapshotMetadata
,DocumentSnapshot
,QuerySnapshot
,CollectionReference
,FieldValue
andFieldPath
. - [changed] A "Could not reach Firestore backend." message will be logged when the initial connection to the Firestore backend fails.
- [changed] A "Using maximum backoff delay to prevent overloading the backend." message will be logged when we get a resource-exhausted error from the backend.
- [feature] Added Node.js support for Cloud Firestore (with the exception of the offline persistence feature).
- [changed] Webchannel requests use $httpHeaders URL parameter rather than normal HTTP headers to avoid an extra CORS preflight request when initiating streams / RPCs.
- [changed] Network streams are automatically closed after 60 seconds of idleness.
- [changed] We no longer log 'RPC failed' messages for expected failures.
- [changed] We now support
FieldValue.delete()
sentinels inset()
calls with{merge:true}
. - [fixed] Fixed validation of nested arrays to allow indirect nesting
- [fixed] Fixed an issue causing exceptions when trying to use
firebase.firestore.FieldPath.documentId()
in anorderBy()
orwhere()
clause in a query.
- Initial public release.