UNPKG

@firebase/firestore

Version:

The Cloud Firestore component of the Firebase JS SDK.

1,101 lines (1,085 loc) • 44 kB
'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var common = require('./common-cf07e910.cjs.js'); require('@firebase/app'); require('@firebase/util'); require('@firebase/webchannel-wrapper/bloom-blob'); require('@firebase/logger'); require('@firebase/webchannel-wrapper/webchannel-blob'); require('re2js'); /** * @license * Copyright 2025 Google LLC * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * @deprecated use selectablesToObject instead * @param selectables */ function __PRIVATE_selectablesToMap(e) { return new Map(Object.entries(__PRIVATE_selectablesToObject(e))); } function __PRIVATE_selectablesToObject(e) { const s = {}; for (const a of e) { let e, t; if ("string" == typeof a ? (e = a, t = common.field(a)) : a instanceof common.Field || a instanceof common.AliasedExpression ? (e = a.alias, t = a.expr) : common.fail(21273, { selectable: a }), void 0 !== s[e]) throw new common.FirestoreError("invalid-argument", `Duplicate alias or field '${e}'`); s[e] = t; } return s; } /** * Converts a value to an Expression, Returning either a Constant, MapFunction, * ArrayFunction, or the input itself (if it's already an expression). * If the input is a string, it is assumed to be a field name, and a * field(value) is returned. * * @private * @internal * @param value */ function __PRIVATE_fieldOrExpression(e) { if (common.__PRIVATE_isString$1(e)) { return common.field(e); } /** * Converts a value to an Expression, Returning either a Constant, MapFunction, * ArrayFunction, or the input itself (if it's already an expression). * * @private * @internal * @param value */ return function __PRIVATE_valueToDefaultExpr(e) { let s; if (common.__PRIVATE_isFirestoreValue(e)) return common.constant(e); if (e instanceof common.Expression) return e; s = common.__PRIVATE_isPlainObject(e) ? common.map(e) : e instanceof Array ? common.array(e) : /** * Checks if a value is a Pipeline object. * * We use duck typing here to avoid a circular dependency between pipeline.ts and pipeline_util.ts. */ function __PRIVATE_isPipeline$1(e) { return "object" == typeof e && null !== e && "function" == typeof e.toArrayExpression; } /** * @license * Copyright 2024 Google LLC * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * * The Pipeline class provides a flexible and expressive framework for building complex data * transformation and query pipelines for Firestore. * * A pipeline takes data sources, such as Firestore collections or collection groups, and applies * a series of stages that are chained together. Each stage takes the output from the previous stage * (or the data source) and produces an output for the next stage (or as the final output of the * pipeline). * * Expressions can be used within each stage to filter and transform data through the stage. * * NOTE: The chained stages do not prescribe exactly how Firestore will execute the pipeline. * Instead, Firestore only guarantees that the result is the same as if the chained stages were * executed in order. * * @example * ```typescript * const db: Firestore; // Assumes a valid firestore instance. * * // Example 1: Select specific fields and rename 'rating' to 'bookRating' * const results1 = await execute(db.pipeline() * .collection("books") * .select("title", "author", field("rating").as("bookRating"))); * * // Example 2: Filter documents where 'genre' is "Science Fiction" and 'published' is after 1950 * const results2 = await execute(db.pipeline() * .collection("books") * .where(and(field("genre").equal("Science Fiction"), field("published").greaterThan(1950)))); * * // Example 3: Calculate the average rating of books published after 1980 * const results3 = await execute(db.pipeline() * .collection("books") * .where(field("published").greaterThan(1980)) * .aggregate(average(field("rating")).as("averageRating"))); * ``` */ (e) ? common.pipelineValue(e) : common.__PRIVATE__constant(e, void 0); return s; }(e); } class Pipeline$1 { /** * @internal * @private * @param _db * @param userDataReader * @param _userDataWriter * @param stages */ constructor( /** * @internal * @private */ e, /** * @internal * @private */ s, /** * @internal * @private */ a, /** * @internal * @private */ t) { this._db = e, this.userDataReader = s, this._userDataWriter = a, this.stages = t; } _readUserData(e) { this.stages.forEach((s => { const a = e.contextWith({ methodName: s._name }); s._readUserData(a); })); } addFields(e, ...s) { // Process argument union(s) from method overloads let a, t; common.__PRIVATE_isSelectable(e) ? (a = [ e, ...s ], t = {}) : ({fields: a, ...t} = e); // Convert user land convenience types to internal types const n = __PRIVATE_selectablesToMap(a), i = new common.__PRIVATE_AddFields(n, t); // Create stage object // Add stage to the pipeline return this._addStage(i); } removeFields(e, ...s) { // Process argument union(s) from method overloads const a = common.__PRIVATE_isField(e) || common.__PRIVATE_isString$1(e) ? {} : e, t = (common.__PRIVATE_isField(e) || common.__PRIVATE_isString$1(e) ? [ e, ...s ] : e.fields).map((e => common.__PRIVATE_isString$1(e) ? common.field(e) : e)), n = new common.__PRIVATE_RemoveFields(t, a); // Add stage to the pipeline return this._addStage(n); } define(e, ...s) { // Process argument union(s) from method overloads const a = common.__PRIVATE_isAliasedExpr(e) ? {} : e, t = __PRIVATE_selectablesToMap(common.__PRIVATE_isAliasedExpr(e) ? [ e, ...s ] : e.variables), n = new common.__PRIVATE_Define(t, a); return this._addStage(n); } /** * Converts this Pipeline into an expression that evaluates to an array of results. * * <p>Result Unwrapping:</p> * <ul> * <li>If the items have a single field, their values are unwrapped and returned directly in the array.</li> * <li>If the items have multiple fields, they are returned as objects in the array</li> * </ul> * * @example * ```typescript * // Get a list of reviewers for each book * db.pipeline().collection("books") * .define(field("id").as("book_id")) * .addFields( * db.pipeline().collection("reviews") * .where(field("book_id").equal(variable("book_id"))) * .select(field("reviewer")) * .toArrayExpression() * .as("reviewers") * ) * ``` * * Output: * ```json * [ * { * "id": "1", * "title": "1984", * "reviewers": ["Alice", "Bob"] * } * ] * ``` * * Multiple Fields: * ```typescript * // Get a list of reviews (reviewer and rating) for each book * db.pipeline().collection("books") * .define(field("id").as("book_id")) * .addFields( * db.pipeline().collection("reviews") * .where(field("book_id").equal(variable("book_id"))) * .select(field("reviewer"), field("rating")) * .toArrayExpression() * .as("reviews")) * ``` * * Output: * ```json * [ * { * "id": "1", * "title": "1984", * "reviews": [ * { "reviewer": "Alice", "rating": 5 }, * { "reviewer": "Bob", "rating": 4 } * ] * } * ] * ``` * * @returns An `Expression` representing the execution of this pipeline. */ toArrayExpression() { return new common.FunctionExpression("array", [ __PRIVATE_fieldOrExpression(this) ]); } /** * Converts this Pipeline into an expression that evaluates to a single scalar result. * * <p><b>Runtime Validation:</b> The runtime validates that the result set contains zero or one item. If * zero items, it evaluates to `null`.</p> * * <p>Result Unwrapping:</p> * <ul> * <li>If the item has a single field, its value is unwrapped and returned directly.</li> * <li>If the item has multiple fields, they are returned as an object.</li> * </ul> * * @example * ```typescript * // Calculate average rating for a restaurant * db.pipeline().collection("restaurants").addFields( * db.pipeline().collection("reviews") * .where(field("restaurant_id").equal(variable("rid"))) * .aggregate(average("rating").as("avg")) * // Unwraps the single "avg" field to a scalar double * .toScalarExpression().as("average_rating") * ) * ``` * * Output: * ```json * { * "name": "The Burger Joint", * "average_rating": 4.5 * } * ``` * * Multiple Fields: * ```typescript * // Calculate average rating AND count for a restaurant * db.pipeline().collection("restaurants").addFields( * db.pipeline().collection("reviews") * .where(field("restaurant_id").equal(variable("rid"))) * .aggregate( * average("rating").as("avg"), * count().as("count") * ) * // Returns an object with "avg" and "count" fields * .toScalarExpression().as("stats") * ) * ``` * * Output: * ```json * { * "name": "The Burger Joint", * "stats": { * "avg": 4.5, * "count": 100 * } * } * ``` * * @returns An `Expression` representing the execution of this pipeline. */ toScalarExpression() { return new common.FunctionExpression("scalar", [ __PRIVATE_fieldOrExpression(this) ]); } select(e, ...s) { // Process argument union(s) from method overloads const a = common.__PRIVATE_isSelectable(e) || common.__PRIVATE_isString$1(e) ? {} : e, t = __PRIVATE_selectablesToMap(common.__PRIVATE_isSelectable(e) || common.__PRIVATE_isString$1(e) ? [ e, ...s ] : e.selections), n = new common.__PRIVATE_Select(t, a); // Add stage to the pipeline return this._addStage(n); } where(e) { // Process argument union(s) from method overloads const s = common.__PRIVATE_isBooleanExpr(e) ? {} : e, a = common.__PRIVATE_isBooleanExpr(e) ? e : e.condition, t = new common.__PRIVATE_Where(a, s); // Add stage to the pipeline return this._addStage(t); } offset(e) { // Process argument union(s) from method overloads let s, a; common.__PRIVATE_isNumber$1(e) ? (s = {}, a = e) : (s = e, a = e.offset); // Create stage object const t = new common.__PRIVATE_Offset(a, s); // Add stage to the pipeline return this._addStage(t); } limit(e) { // Process argument union(s) from method overloads const s = common.__PRIVATE_isNumber$1(e) ? {} : e, a = common.__PRIVATE_isNumber$1(e) ? e : e.limit, t = new common.__PRIVATE_Limit(a, s); // Add stage to the pipeline return this._addStage(t); } distinct(e, ...s) { // Process argument union(s) from method overloads const a = common.__PRIVATE_isString$1(e) || common.__PRIVATE_isSelectable(e) ? {} : e, t = __PRIVATE_selectablesToMap(common.__PRIVATE_isString$1(e) || common.__PRIVATE_isSelectable(e) ? [ e, ...s ] : e.groups), n = new common.__PRIVATE_Distinct(t, a); // Add stage to the pipeline return this._addStage(n); } aggregate(e, ...s) { // Process argument union(s) from method overloads const a = common.__PRIVATE_isAliasedAggregate(e) ? {} : e, t = common.__PRIVATE_isAliasedAggregate(e) ? [ e, ...s ] : e.accumulators, n = common.__PRIVATE_isAliasedAggregate(e) ? [] : e.groups ?? [], i = function __PRIVATE_aliasedAggregateToMap(e) { return e.reduce(((e, s) => { if (void 0 !== e.get(s.alias)) throw new common.FirestoreError("invalid-argument", `Duplicate alias or field '${s.alias}'`); return e.set(s.alias, s.aggregate), e; }), new Map); } /** * Converts a value to an Expression, Returning either a Constant, MapFunction, * ArrayFunction, or the input itself (if it's already an expression). * * @private * @internal * @param value */ (t), r = __PRIVATE_selectablesToMap(n), o = new common.__PRIVATE_Aggregate(r, i, a); // Add stage to the pipeline return this._addStage(o); } /** * Performs a vector proximity search on the documents from the previous stage, returning the * K-nearest documents based on the specified query `vectorValue` and `distanceMeasure`. The * returned documents will be sorted in order from nearest to furthest from the query `vectorValue`. * * @example * ```typescript * // Find the 10 most similar books based on the book description. * const bookDescription = "Lorem ipsum..."; * const queryVector: number[] = ...; // compute embedding of `bookDescription` * * firestore.pipeline().collection("books") * .findNearest({ * field: 'embedding', * vectorValue: queryVector, * distanceMeasure: 'euclidean', * limit: 10, // optional * distanceField: 'computedDistance' // optional * }); * ``` * * @param options - An object that specifies required and optional parameters for the stage. * @returns A new {@link @firebase/firestore/pipelines#Pipeline} object with this stage appended to the stage list. */ findNearest(e) { // Convert user land convenience types to internal types const s = common.__PRIVATE_toField(e.field), a = function __PRIVATE_vectorToExpr(e) { if (e instanceof common.Expression) return e; if (e instanceof common.VectorValue) return common.constant(e); if (Array.isArray(e)) return common.constant(common.vector(e)); throw new Error("Unsupported value: " + typeof e); }(e.vectorValue), t = { distanceField: e.distanceField ? common.__PRIVATE_toField(e.distanceField) : void 0, limit: e.limit, rawOptions: e.rawOptions }, n = new common.__PRIVATE_FindNearest(a, s, e.distanceMeasure, t); // Add stage to the pipeline return this._addStage(n); } // TODO(search) link to external documentation citing list of supported // expressions, when that documentation is created. List is not maintained // in the SDK because the list will change as the backend enables support. /** * Add a search stage to the Pipeline. The search stage supports * full-text search and geo search expressions. * * @remarks * This must be the first stage of the pipeline. A limited set of expressions are supported in the search stage. * * @example * ```typescript * // Full-text search example * firestore.pipeline().collection("restaurants") * .search({ * query: documentMatches("waffles OR pancakes"), * sort: [ * score().descending(), * ], * addFields: [ * score().as("searchScore"), * ] * }) * ``` * * @example * ```typescript * // Geo distance search example * const queryLocation = new GeoPoint(0, 0); * db.pipeline().collection('restaurants').search({ * query: field('location').geoDistance(queryLocation).lessThanOrEqual(1000), * sort: [ * score().descending(), * ], * }) * ``` * * @param options - An object that specifies parameters for the stage. * @return A new `Pipeline` object with this stage appended to the stage list. * @beta */ search(e) { // Convert user land convenience types to internal types const s = e.addFields ? __PRIVATE_selectablesToObject(e.addFields) : void 0, a = common.__PRIVATE_isExpr(e.query) ? e.query : common.documentMatches(e.query), t = common.__PRIVATE_isOrdering(e.sort) ? [ e.sort ] : e.sort, n = { ...e, addFields: s, select: undefined, query: a, sort: t }, i = new common.__PRIVATE_Search(n); // Add stage to the pipeline return this._addStage(i); } sort(e, ...s) { // Process argument union(s) from method overloads const a = common.__PRIVATE_isOrdering(e) ? {} : e, t = common.__PRIVATE_isOrdering(e) ? [ e, ...s ] : e.orderings, n = new common.__PRIVATE_Sort(t, a); // Add stage to the pipeline return this._addStage(n); } replaceWith(e) { // Process argument union(s) from method overloads const s = common.__PRIVATE_isString$1(e) || common.__PRIVATE_isExpr(e) ? {} : e, a = __PRIVATE_fieldOrExpression(common.__PRIVATE_isString$1(e) || common.__PRIVATE_isExpr(e) ? e : e.map), t = new common.__PRIVATE_Replace(a, s); // Add stage to the pipeline return this._addStage(t); } sample(e) { // Process argument union(s) from method overloads const s = common.__PRIVATE_isNumber$1(e) ? {} : e; let a, t; common.__PRIVATE_isNumber$1(e) ? (a = e, t = "documents") : common.__PRIVATE_isNumber$1(e.documents) ? (a = e.documents, t = "documents") : (a = e.percentage, t = "percent"); // Create stage object const n = new common.__PRIVATE_Sample(a, t, s); // Add stage to the pipeline return this._addStage(n); } union(e) { // Process argument union(s) from method overloads let s, a; !function __PRIVATE_isPipeline(e) { return e instanceof Pipeline$1; } /** * @license * Copyright 2024 Google LLC * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * Represents the results of a Firestore pipeline execution. * * A `PipelineSnapshot` contains zero or more {@link @firebase/firestore/pipelines#PipelineResult} objects * representing the documents returned by a pipeline query. It provides methods * to iterate over the documents and access metadata about the query results. * * @example * ```typescript * const snapshot: PipelineSnapshot = await firestore * .pipeline() * .collection('myCollection') * .where(field('value').greaterThan(10)) * .execute(); * * snapshot.results.forEach(doc => { * console.log(doc.id, '=>', doc.data()); * }); * ``` */ (e) ? ({other: a, ...s} = e) : (s = {}, a = e); // Create stage object const t = new common.__PRIVATE_Union(a, s); // Add stage to the pipeline return this._addStage(t); } unnest(e, s) { // Process argument union(s) from method overloads let a, t, n; common.__PRIVATE_isSelectable(e) ? (a = {}, t = e, n = s) : ({selectable: t, indexField: n, ...a} = e); // Convert user land convenience types to internal types const i = t.alias, r = t.expr; common.__PRIVATE_isString$1(n) && (a.indexField = common._field(n, "unnest")); // Create stage object const o = new common.__PRIVATE_Unnest(i, r, a); // Add stage to the pipeline return this._addStage(o); } /** * Adds a raw stage to the pipeline. * * <p>This method provides a flexible way to extend the pipeline's functionality by adding custom * stages. Each raw stage is defined by a unique `name` and a set of `params` that control its * behavior. * * <p>Example (Assuming there is no 'where' stage available in SDK): * * @example * ```typescript * // Assume we don't have a built-in 'where' stage * firestore.pipeline().collection('books') * .rawStage('where', [field('published').lessThan(1900)]) // Custom 'where' stage * .select('title', 'author'); * ``` * * @param name - The unique name of the raw stage to add. * @param params - A list of parameters to configure the raw stage's behavior. * @param options - An object of key value pairs that specifies optional parameters for the stage. * @returns A new {@link @firebase/firestore/pipelines#Pipeline} object with this stage appended to the stage list. */ rawStage(e, s, a) { // Convert user land convenience types to internal types const t = s.map((e => e instanceof common.Expression || e instanceof common.AggregateFunction ? e : common.__PRIVATE_isPlainObject(e) ? common.__PRIVATE__mapValue(e) : common.__PRIVATE__constant(e, "rawStage"))), n = new common.__PRIVATE_RawStage(e, t, a ?? {}); // Create stage object // Add stage to the pipeline return this._addStage(n); } /** * @internal * @private */ _toProto(e) { return { stages: this.stages.map((s => s._toProto(e))) }; } _addStage(e) { const s = this.stages.map((e => e)); return s.push(e), this.newPipeline(this._db, s); } /** * @internal * @private * @param db * @param userDataReader * @param userDataWriter * @param stages * @protected */ newPipeline(e, s) { return new Pipeline$1(e, this.userDataReader, this._userDataWriter, s); } } class PipelineSnapshot { constructor(e, s, a) { this._pipeline = e, this._executionTime = a, this._results = s; } /** * An array of all the results in the `PipelineSnapshot`. */ get results() { return this._results; } /** * The time at which the pipeline producing this result is executed. * * @readonly * */ get executionTime() { if (void 0 === this._executionTime) throw new Error("'executionTime' is expected to exist, but it is undefined"); return this._executionTime; } } /** * * A PipelineResult contains data read from a Firestore Pipeline. The data can be extracted with the * {@link @firebase/firestore/pipelines#PipelineResult.data} or {@link @firebase/firestore/pipelines#PipelineResult.(get:1)} methods. * * <p>If the PipelineResult represents a non-document result, `ref` will return a undefined * value. */ class PipelineResult { /** * @private * @internal * * @param userDataWriter - The serializer used to encode/decode protobuf. * @param fields - The fields of the Firestore `Document` Protobuf backing * this document. * @param ref - The reference to the document. * @param createTime - The time when the document was created if the result is a document, undefined otherwise. * @param updateTime - The time when the document was last updated if the result is a document, undefined otherwise. * @param metadata * @param listenOptions */ constructor(e, s, a, t, n, i, r) { this._ref = a, this._userDataWriter = e, this._createTime = t, this._updateTime = n, this._fields = s, this._metadata = i, this._listenOptions = r; } /** * @private * @internal * @param userDataWriter * @param doc * @param ref * @param metadata * @param listenOptions */ static fromDocument(e, s, a, t, n) { return new PipelineResult(e, s.data, a, s.createTime.toTimestamp(), s.version.toTimestamp(), t, n); } /** * The reference of the document, if it is a document; otherwise `undefined`. */ get ref() { return this._ref; } /** * The ID of the document for which this PipelineResult contains data, if it is a document; otherwise `undefined`. * * @readonly * */ get id() { return this._ref?.id; } /** * The time the document was created. Undefined if this result is not a document. * * @readonly */ get createTime() { return this._createTime; } /** * The time the document was last updated (at the time the snapshot was * generated). Undefined if this result is not a document. * * @readonly */ get updateTime() { return this._updateTime; } /** * Retrieves all fields in the result as an object. * * @returns An object containing all fields in the document or * 'undefined' if the document doesn't exist. * * @example * ``` * let p = firestore.pipeline().collection('col'); * * p.execute().then(results => { * let data = results[0].data(); * console.log(`Retrieved data: ${JSON.stringify(data)}`); * }); * ``` */ data() { return this._userDataWriter.convertValue(this._fields.value, this._listenOptions?.serverTimestampBehavior); } /** * @internal * @private * * Retrieves all fields in the result as a proto value. * * @returns An `Object` containing all fields in the result. */ _fieldsProto() { // Return a cloned value to prevent manipulation of the Snapshot's data return this._fields.clone().value.mapValue.fields; } /** * Retrieves the field specified by `field`. * * @param field - The field path * (e.g. 'foo' or 'foo.bar') to a specific field. * @returns The data at the specified field location or `undefined` if no * such field exists. * * @example * ``` * let p = firestore.pipeline().collection('col'); * * p.execute().then(results => { * let field = results[0].get('a.b'); * console.log(`Retrieved field value: ${field}`); * }); * ``` */ // We deliberately use `any` in the external API to not impose type-checking // on end users. // eslint-disable-next-line @typescript-eslint/no-explicit-any get(e) { if (void 0 === this._fields) return; common.__PRIVATE_isField(e) && (e = e.fieldName); const s = this._fields.field(common.__PRIVATE_fieldPathFromArgument("DocumentSnapshot.get", e)); return null !== s ? this._userDataWriter.convertValue(s, this._listenOptions?.serverTimestampBehavior) : void 0; } } /** * Test equality of two PipelineResults. * @param left - First PipelineResult to compare. * @param right - Second PipelineResult to compare. */ function pipelineResultEqual(e, s) { return e === s || common.__PRIVATE_isOptionalEqual(e._ref, s._ref, common.refEqual) && common.__PRIVATE_isOptionalEqual(e._fields, s._fields, ((e, s) => e.isEqual(s))); } /** * @license * Copyright 2024 Google LLC * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** * Provides the entry point for defining the data source of a Firestore {@link @firebase/firestore/pipelines#Pipeline}. * * Use the methods of this class (e.g., {@link @firebase/firestore/pipelines#PipelineSource.(collection:1)}, {@link @firebase/firestore/pipelines#PipelineSource.(collectionGroup:1)}, * {@link @firebase/firestore/pipelines#PipelineSource.(database:1)}, or {@link @firebase/firestore/pipelines#PipelineSource.(documents:1)}) to specify the initial data * for your pipeline, such as a collection, a collection group, the entire database, or a set of specific documents. */ class PipelineSource { /** * @internal * @private * @param databaseId * @param userDataReader * @param _createPipeline */ constructor(e, s, /** * @internal * @private */ a) { this.databaseId = e, this.userDataReader = s, this._createPipeline = a; } collection(e) { // Process argument union(s) from method overloads const s = common.__PRIVATE_isString$1(e) || common.__PRIVATE_isCollectionReference(e) ? {} : e, a = common.__PRIVATE_isString$1(e) || common.__PRIVATE_isCollectionReference(e) ? e : e.collection; // Validate that a user provided reference is for the same Firestore DB common.__PRIVATE_isCollectionReference(a) && this._validateReference(a); // Convert user land convenience types to internal types const t = common.__PRIVATE_isString$1(a) ? a : a.path, n = new common.__PRIVATE_CollectionSource(t, s), i = this.userDataReader.createContext(3 /* UserDataSource.Argument */ , "collection"); // Create stage object // Add stage to the pipeline return n._readUserData(i), this._createPipeline([ n ]); } collectionGroup(e) { // Process argument union(s) from method overloads let s, a; common.__PRIVATE_isString$1(e) ? (s = e, a = {}) : ({collectionId: s, ...a} = e); // Create stage object const t = new common.__PRIVATE_CollectionGroupSource(s, a), n = this.userDataReader.createContext(3 /* UserDataSource.Argument */ , "collectionGroup"); // User data must be read in the context of the API method to // provide contextual errors // Add stage to the pipeline return t._readUserData(n), this._createPipeline([ t ]); } database(e) { // Create stage object const s = new common.__PRIVATE_DatabaseSource( // Process argument union(s) from method overloads e = e ?? {}), a = this.userDataReader.createContext(3 /* UserDataSource.Argument */ , "database"); // User data must be read in the context of the API method to // provide contextual errors // Add stage to the pipeline return s._readUserData(a), this._createPipeline([ s ]); } documents(e) { // Process argument union(s) from method overloads let s, a; Array.isArray(e) ? (a = e, s = {}) : ({docs: a, ...s} = e), // Validate that all user provided references are for the same Firestore DB a.filter((e => e instanceof common.DocumentReference)).forEach((e => this._validateReference(e))); // Convert user land convenience types to internal types const t = a.map((e => common.__PRIVATE_isString$1(e) ? e : e.path)), n = new common.__PRIVATE_DocumentsSource(t, s), i = this.userDataReader.createContext(3 /* UserDataSource.Argument */ , "documents"); // Create stage object // Add stage to the pipeline return n._readUserData(i), this._createPipeline([ n ]); } /** * Convert the given Query into an equivalent Pipeline. * * @param query - A Query to be converted into a Pipeline. * * @throws `FirestoreError` Thrown if any of the provided DocumentReferences target a different project or database than the pipeline. */ createFrom(e) { return this._createPipeline(common.__PRIVATE_toPipelineStages(e._query, e.firestore)); } _validateReference(e) { const s = e.firestore._databaseId; if (!s.isEqual(this.databaseId)) throw new common.FirestoreError(common.D.INVALID_ARGUMENT, `Invalid ${e instanceof common.CollectionReference ? "CollectionReference" : "DocumentReference"}. The project ID ("${s.projectId}") or the database ("${s.database}") does not match the project ID ("${this.databaseId.projectId}") and database ("${this.databaseId.database}") of the target database of this Pipeline.`); } } function subcollection(e) { // Process argument union(s) from method overloads let s, a; common.__PRIVATE_isString$1(e) ? (s = e, a = {}) : ({path: s, ...a} = e); // Create stage object const t = new common.__PRIVATE_SubcollectionSource(s, a); return new Pipeline$1(void 0, void 0, void 0, [ t ]); } /** * @license * Copyright 2024 Google LLC * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ class Pipeline extends Pipeline$1 { /** * @internal * @private * @param db * @param userDataReader * @param userDataWriter * @param stages * @param converter * @protected */ newPipeline(e, s) { return new Pipeline(e, this.userDataReader, this._userDataWriter, s); } } /** * @license * Copyright 2024 Google LLC * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ function execute(e) { const s = e instanceof Pipeline$1 ? { pipeline: e } : e, {pipeline: t, rawOptions: n, ...i} = s; if (!t._db) return Promise.reject(new common.FirestoreError(common.D.FAILED_PRECONDITION, "This pipeline was created without a database (e.g., as a subcollection pipeline) and cannot be executed directly. It can only be used as part of another pipeline.")); const r = common.__PRIVATE_cast(t._db, common.Firestore), o = common.ensureFirestoreConfigured(r), c = common.__PRIVATE_newUserDataReader(r).createContext(3 /* UserDataSource.Argument */ , "execute"); t._readUserData(c); const l = new common.__PRIVATE_ExpUserDataWriter(r), u = new common.__PRIVATE_StructuredPipelineOptions(i, n); u._readUserData(c); const p = new common.StructuredPipeline(t, u); return common.__PRIVATE_firestoreClientExecutePipeline(o, p).then((e => { // Get the execution time from the first result. // firestoreClientExecutePipeline returns at least one PipelineStreamElement // even if the returned document set is empty. const s = e.length > 0 ? e[0].executionTime?.toTimestamp() : void 0, a = e.filter((e => !!e.fields)).map((e => new PipelineResult(l, e.fields, e.key?.path ? new common.DocumentReference(r, null, e.key) : void 0, e.createTime?.toTimestamp(), e.updateTime?.toTimestamp()))); return new PipelineSnapshot(t, a, s); })); } /** * @beta * Creates and returns a new PipelineSource, which allows specifying the source stage of a {@link @firebase/firestore/pipelines#Pipeline}. * * @example * ```typescript * let myPipeline: Pipeline = firestore.pipeline().collection('books'); * ``` */ // Augment the Firestore class with the pipeline() factory method common.Firestore.prototype.pipeline = function() { const e = common.__PRIVATE_newUserDataReader(this); return new PipelineSource(this._databaseId, e, (s => new Pipeline(this, e, new common.__PRIVATE_ExpUserDataWriter(this), s))); }; exports.AggregateFunction = common.AggregateFunction; exports.AliasedAggregate = common.AliasedAggregate; exports.AliasedExpression = common.AliasedExpression; exports.BooleanExpression = common.BooleanExpression; exports.Expression = common.Expression; exports.Field = common.Field; exports.FunctionExpression = common.FunctionExpression; exports.Ordering = common.Ordering; exports._internalPipelineToExecutePipelineRequestProto = common._internalPipelineToExecutePipelineRequestProto; exports.abs = common.abs; exports.add = common.add; exports.and = common.and; exports.array = common.array; exports.arrayAgg = common.arrayAgg; exports.arrayAggDistinct = common.arrayAggDistinct; exports.arrayConcat = common.arrayConcat; exports.arrayContains = common.arrayContains; exports.arrayContainsAll = common.arrayContainsAll; exports.arrayContainsAny = common.arrayContainsAny; exports.arrayFilter = common.arrayFilter; exports.arrayFirst = common.arrayFirst; exports.arrayFirstN = common.arrayFirstN; exports.arrayGet = common.arrayGet; exports.arrayIndexOf = common.arrayIndexOf; exports.arrayIndexOfAll = common.arrayIndexOfAll; exports.arrayLast = common.arrayLast; exports.arrayLastIndexOf = common.arrayLastIndexOf; exports.arrayLastN = common.arrayLastN; exports.arrayLength = common.arrayLength; exports.arrayMaximum = common.arrayMaximum; exports.arrayMaximumN = common.arrayMaximumN; exports.arrayMinimum = common.arrayMinimum; exports.arrayMinimumN = common.arrayMinimumN; exports.arraySlice = common.arraySlice; exports.arraySum = common.arraySum; exports.arrayTransform = common.arrayTransform; exports.arrayTransformWithIndex = common.arrayTransformWithIndex; exports.ascending = common.ascending; exports.average = common.average; exports.byteLength = common.byteLength; exports.ceil = common.ceil; exports.charLength = common.charLength; exports.coalesce = common.coalesce; exports.collectionId = common.collectionId; exports.concat = common.concat; exports.conditional = common.conditional; exports.constant = common.constant; exports.cosineDistance = common.cosineDistance; exports.count = common.count; exports.countAll = common.countAll; exports.countDistinct = common.countDistinct; exports.countIf = common.countIf; exports.currentDocument = common.currentDocument; exports.currentTimestamp = common.currentTimestamp; exports.descending = common.descending; exports.divide = common.divide; exports.documentId = common.documentId; exports.documentMatches = common.documentMatches; exports.dotProduct = common.dotProduct; exports.endsWith = common.endsWith; exports.equal = common.equal; exports.equalAny = common.equalAny; exports.euclideanDistance = common.euclideanDistance; exports.exists = common.exists; exports.exp = common.exp; exports.field = common.field; exports.first = common.first; exports.floor = common.floor; exports.geoDistance = common.geoDistance; exports.greaterThan = common.greaterThan; exports.greaterThanOrEqual = common.greaterThanOrEqual; exports.ifAbsent = common.ifAbsent; exports.ifError = common.ifError; exports.ifNull = common.ifNull; exports.isAbsent = common.isAbsent; exports.isError = common.isError; exports.isType = common.isType; exports.join = common.join; exports.last = common.last; exports.length = common.length; exports.lessThan = common.lessThan; exports.lessThanOrEqual = common.lessThanOrEqual; exports.like = common.like; exports.ln = common.ln; exports.log = common.log; exports.log10 = common.log10; exports.logicalMaximum = common.logicalMaximum; exports.logicalMinimum = common.logicalMinimum; exports.ltrim = common.ltrim; exports.map = common.map; exports.mapEntries = common.mapEntries; exports.mapGet = common.mapGet; exports.mapKeys = common.mapKeys; exports.mapMerge = common.mapMerge; exports.mapRemove = common.mapRemove; exports.mapSet = common.mapSet; exports.mapValues = common.mapValues; exports.maximum = common.maximum; exports.minimum = common.minimum; exports.mod = common.mod; exports.multiply = common.multiply; exports.nor = common.nor; exports.not = common.not; exports.notEqual = common.notEqual; exports.notEqualAny = common.notEqualAny; exports.or = common.or; exports.parent = common.parent; exports.pow = common.pow; exports.rand = common.rand; exports.regexContains = common.regexContains; exports.regexFind = common.regexFind; exports.regexFindAll = common.regexFindAll; exports.regexMatch = common.regexMatch; exports.reverse = common.reverse; exports.round = common.round; exports.rtrim = common.rtrim; exports.score = common.score; exports.split = common.split; exports.sqrt = common.sqrt; exports.startsWith = common.startsWith; exports.stringConcat = common.stringConcat; exports.stringContains = common.stringContains; exports.stringIndexOf = common.stringIndexOf; exports.stringRepeat = common.stringRepeat; exports.stringReplaceAll = common.stringReplaceAll; exports.stringReplaceOne = common.stringReplaceOne; exports.stringReverse = common.stringReverse; exports.substring = common.substring; exports.subtract = common.subtract; exports.sum = common.sum; exports.switchOn = common.switchOn; exports.timestampAdd = common.timestampAdd; exports.timestampDiff = common.timestampDiff; exports.timestampExtract = common.timestampExtract; exports.timestampSubtract = common.timestampSubtract; exports.timestampToUnixMicros = common.timestampToUnixMicros; exports.timestampToUnixMillis = common.timestampToUnixMillis; exports.timestampToUnixSeconds = common.timestampToUnixSeconds; exports.timestampTruncate = common.timestampTruncate; exports.toLower = common.toLower; exports.toUpper = common.toUpper; exports.trim = common.trim; exports.trunc = common.trunc; exports.type = common.type; exports.unixMicrosToTimestamp = common.unixMicrosToTimestamp; exports.unixMillisToTimestamp = common.unixMillisToTimestamp; exports.unixSecondsToTimestamp = common.unixSecondsToTimestamp; exports.variable = common.variable; exports.vectorLength = common.vectorLength; exports.xor = common.xor; exports.Pipeline = Pipeline; exports.PipelineResult = PipelineResult; exports.PipelineSnapshot = PipelineSnapshot; exports.PipelineSource = PipelineSource; exports.execute = execute; exports.pipelineResultEqual = pipelineResultEqual; exports.subcollection = subcollection; //# sourceMappingURL=pipelines.cjs.js.map