📂 File Browser

AgentAI/vendor/google/apiclient-services/src/Firestore
🌙 Dark Mode
🎯 Quick Launch:

📁 Directories

📁 Resource/ 🔓 Open

📄 Files

🐘 Aggregation.php
▶ Open 📄 View Source
🐘 AggregationResult.php
▶ Open 📄 View Source
🐘 ArrayValue.php
▶ Open 📄 View Source
🐘 Avg.php
▶ Open 📄 View Source
🐘 BatchGetDocumentsRequest.php
▶ Open 📄 View Source
🐘 BatchGetDocumentsResponse.php
▶ Open 📄 View Source
🐘 BatchWriteRequest.php
▶ Open 📄 View Source
🐘 BatchWriteResponse.php
▶ Open 📄 View Source
🐘 BeginTransactionRequest.php
▶ Open 📄 View Source
🐘 BeginTransactionResponse.php
▶ Open 📄 View Source
🐘 BitSequence.php
▶ Open 📄 View Source
🐘 BloomFilter.php
▶ Open 📄 View Source
🐘 CollectionSelector.php
▶ Open 📄 View Source
🐘 CommitRequest.php
▶ Open 📄 View Source
🐘 CommitResponse.php
▶ Open 📄 View Source
🐘 CompositeFilter.php
▶ Open 📄 View Source
🐘 Count.php
▶ Open 📄 View Source
🐘 Cursor.php
▶ Open 📄 View Source
🐘 Document.php
▶ Open 📄 View Source
🐘 DocumentChange.php
▶ Open 📄 View Source
🐘 DocumentDelete.php
▶ Open 📄 View Source
🐘 DocumentMask.php
▶ Open 📄 View Source
🐘 DocumentRemove.php
▶ Open 📄 View Source
🐘 DocumentTransform.php
▶ Open 📄 View Source
🐘 DocumentsTarget.php
▶ Open 📄 View Source
🐘 ExecutePipelineRequest.php
▶ Open 📄 View Source
🐘 ExecutePipelineResponse.php
▶ Open 📄 View Source
🐘 ExecutionStats.php
▶ Open 📄 View Source
🐘 ExistenceFilter.php
▶ Open 📄 View Source
🐘 ExplainMetrics.php
▶ Open 📄 View Source
🐘 ExplainOptions.php
▶ Open 📄 View Source
🐘 ExplainStats.php
▶ Open 📄 View Source
🐘 FieldFilter.php
▶ Open 📄 View Source
🐘 FieldReference.php
▶ Open 📄 View Source
🐘 FieldTransform.php
▶ Open 📄 View Source
🐘 Filter.php
▶ Open 📄 View Source
🐘 FindNearest.php
▶ Open 📄 View Source
🐘 FirestoreEmpty.php
▶ Open 📄 View Source
🐘 FirestoreFunction.php
▶ Open 📄 View Source
🐘 FirestoreReadOnly.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1Backup.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1BackupSchedule.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1BackupSource.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1BulkDeleteDocumentsMetadata.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1BulkDeleteDocumentsRequest.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1CloneDatabaseMetadata.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1CloneDatabaseRequest.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1CmekConfig.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1CreateDatabaseMetadata.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1CustomerManagedEncryptionOptions.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1DailyRecurrence.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1Database.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1DatabaseSnapshot.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1DeleteDatabaseMetadata.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1DisableUserCredsRequest.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1EnableUserCredsRequest.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1EncryptionConfig.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1ExportDocumentsMetadata.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1ExportDocumentsRequest.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1ExportDocumentsResponse.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1Field.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1FieldOperationMetadata.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1FlatIndex.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1GoogleDefaultEncryptionOptions.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1ImportDocumentsMetadata.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1ImportDocumentsRequest.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1Index.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1IndexConfig.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1IndexConfigDelta.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1IndexField.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1IndexOperationMetadata.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1ListBackupSchedulesResponse.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1ListBackupsResponse.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1ListDatabasesResponse.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1ListFieldsResponse.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1ListIndexesResponse.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1ListUserCredsResponse.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1LocationMetadata.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1PitrSnapshot.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1Progress.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1ResetUserPasswordRequest.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1ResourceIdentity.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1RestoreDatabaseMetadata.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1RestoreDatabaseRequest.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1SearchConfig.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1SearchGeoSpec.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1SearchIndexOptions.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1SearchNumberSpec.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1SearchTextIndexSpec.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1SearchTextSpec.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1SourceEncryptionOptions.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1SourceInfo.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1Stats.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1TtlConfig.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1TtlConfigDelta.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1UpdateDatabaseMetadata.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1UserCreds.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1VectorConfig.php
▶ Open 📄 View Source
🐘 GoogleFirestoreAdminV1WeeklyRecurrence.php
▶ Open 📄 View Source
🐘 GoogleLongrunningCancelOperationRequest.php
▶ Open 📄 View Source
🐘 GoogleLongrunningListOperationsResponse.php
▶ Open 📄 View Source
🐘 GoogleLongrunningOperation.php
▶ Open 📄 View Source
🐘 LatLng.php
▶ Open 📄 View Source
🐘 ListCollectionIdsRequest.php
▶ Open 📄 View Source
🐘 ListCollectionIdsResponse.php
▶ Open 📄 View Source
🐘 ListDocumentsResponse.php
▶ Open 📄 View Source
🐘 ListLocationsResponse.php
▶ Open 📄 View Source
🐘 ListenRequest.php
▶ Open 📄 View Source
🐘 ListenResponse.php
▶ Open 📄 View Source
🐘 Location.php
▶ Open 📄 View Source
🐘 MapValue.php
▶ Open 📄 View Source
🐘 Order.php
▶ Open 📄 View Source
🐘 PartitionQueryRequest.php
▶ Open 📄 View Source
🐘 PartitionQueryResponse.php
▶ Open 📄 View Source
🐘 Pipeline.php
▶ Open 📄 View Source
🐘 PlanSummary.php
▶ Open 📄 View Source
🐘 Precondition.php
▶ Open 📄 View Source
🐘 Projection.php
▶ Open 📄 View Source
🐘 QueryPlan.php
▶ Open 📄 View Source
🐘 QueryTarget.php
▶ Open 📄 View Source
🐘 ReadWrite.php
▶ Open 📄 View Source
🐘 ResultSetStats.php
▶ Open 📄 View Source
🐘 RollbackRequest.php
▶ Open 📄 View Source
🐘 RunAggregationQueryRequest.php
▶ Open 📄 View Source
🐘 RunAggregationQueryResponse.php
▶ Open 📄 View Source
🐘 RunQueryRequest.php
▶ Open 📄 View Source
🐘 RunQueryResponse.php
▶ Open 📄 View Source
🐘 Stage.php
▶ Open 📄 View Source
🐘 Status.php
▶ Open 📄 View Source
🐘 StructuredAggregationQuery.php
▶ Open 📄 View Source
🐘 StructuredPipeline.php
▶ Open 📄 View Source
🐘 StructuredQuery.php
▶ Open 📄 View Source
🐘 Sum.php
▶ Open 📄 View Source
🐘 Target.php
▶ Open 📄 View Source
🐘 TargetChange.php
▶ Open 📄 View Source
🐘 TimeOfDay.php
▶ Open 📄 View Source
🐘 TransactionOptions.php
▶ Open 📄 View Source
🐘 UnaryFilter.php
▶ Open 📄 View Source
🐘 Value.php
▶ Open 📄 View Source
🐘 Write.php
▶ Open 📄 View Source
🐘 WriteRequest.php
▶ Open 📄 View Source
🐘 WriteResponse.php
▶ Open 📄 View Source
🐘 WriteResult.php
▶ Open 📄 View Source

📄 Source: StructuredQuery.php

<?php
/*
 * Copyright 2014 Google Inc.
 *
 * 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.
 */

namespace Google\Service\Firestore;

class StructuredQuery extends \Google\Collection
{
  protected $collection_key = 'orderBy';
  protected $endAtType = Cursor::class;
  protected $endAtDataType = '';
  protected $findNearestType = FindNearest::class;
  protected $findNearestDataType = '';
  protected $fromType = CollectionSelector::class;
  protected $fromDataType = 'array';
  /**
   * The maximum number of results to return. Applies after all other
   * constraints. Requires: * The value must be greater than or equal to zero if
   * specified.
   *
   * @var int
   */
  public $limit;
  /**
   * The number of documents to skip before returning the first result. This
   * applies after the constraints specified by the `WHERE`, `START AT`, & `END
   * AT` but before the `LIMIT` clause. Requires: * The value must be greater
   * than or equal to zero if specified.
   *
   * @var int
   */
  public $offset;
  protected $orderByType = Order::class;
  protected $orderByDataType = 'array';
  protected $selectType = Projection::class;
  protected $selectDataType = '';
  protected $startAtType = Cursor::class;
  protected $startAtDataType = '';
  protected $whereType = Filter::class;
  protected $whereDataType = '';

  /**
   * A potential prefix of a position in the result set to end the query at.
   * This is similar to `START_AT` but with it controlling the end position
   * rather than the start position. Requires: * The number of values cannot be
   * greater than the number of fields specified in the `ORDER BY` clause.
   *
   * @param Cursor $endAt
   */
  public function setEndAt(Cursor $endAt)
  {
    $this->endAt = $endAt;
  }
  /**
   * @return Cursor
   */
  public function getEndAt()
  {
    return $this->endAt;
  }
  /**
   * Optional. A potential nearest neighbors search. Applies after all other
   * filters and ordering. Finds the closest vector embeddings to the given
   * query vector.
   *
   * @param FindNearest $findNearest
   */
  public function setFindNearest(FindNearest $findNearest)
  {
    $this->findNearest = $findNearest;
  }
  /**
   * @return FindNearest
   */
  public function getFindNearest()
  {
    return $this->findNearest;
  }
  /**
   * The collections to query.
   *
   * @param CollectionSelector[] $from
   */
  public function setFrom($from)
  {
    $this->from = $from;
  }
  /**
   * @return CollectionSelector[]
   */
  public function getFrom()
  {
    return $this->from;
  }
  /**
   * The maximum number of results to return. Applies after all other
   * constraints. Requires: * The value must be greater than or equal to zero if
   * specified.
   *
   * @param int $limit
   */
  public function setLimit($limit)
  {
    $this->limit = $limit;
  }
  /**
   * @return int
   */
  public function getLimit()
  {
    return $this->limit;
  }
  /**
   * The number of documents to skip before returning the first result. This
   * applies after the constraints specified by the `WHERE`, `START AT`, & `END
   * AT` but before the `LIMIT` clause. Requires: * The value must be greater
   * than or equal to zero if specified.
   *
   * @param int $offset
   */
  public function setOffset($offset)
  {
    $this->offset = $offset;
  }
  /**
   * @return int
   */
  public function getOffset()
  {
    return $this->offset;
  }
  /**
   * The order to apply to the query results. Callers can provide a full
   * ordering, a partial ordering, or no ordering at all. While Firestore will
   * always respect the provided order, the behavior for queries without a full
   * ordering is different per database edition: In Standard edition, Firestore
   * guarantees a stable ordering through the following rules: * The `order_by`
   * is required to reference all fields used with an inequality filter. * All
   * fields that are required to be in the `order_by` but are not already
   * present are appended in lexicographical ordering of the field name. * If an
   * order on `__name__` is not specified, it is appended by default. Fields are
   * appended with the same sort direction as the last order specified, or
   * 'ASCENDING' if no order was specified. For example: * `ORDER BY a` becomes
   * `ORDER BY a ASC, __name__ ASC` * `ORDER BY a DESC` becomes `ORDER BY a
   * DESC, __name__ DESC` * `WHERE a > 1` becomes `WHERE a > 1 ORDER BY a ASC,
   * __name__ ASC` * `WHERE __name__ > ... AND a > 1` becomes `WHERE __name__ >
   * ... AND a > 1 ORDER BY a ASC, __name__ ASC` In Enterprise edition,
   * Firestore does not guarantee a stable ordering. Instead it will pick the
   * most efficient ordering based on the indexes available at the time of query
   * execution. This will result in a different ordering for queries that are
   * otherwise identical. To ensure a stable ordering, always include a unique
   * field in the `order_by` clause, such as `__name__`.
   *
   * @param Order[] $orderBy
   */
  public function setOrderBy($orderBy)
  {
    $this->orderBy = $orderBy;
  }
  /**
   * @return Order[]
   */
  public function getOrderBy()
  {
    return $this->orderBy;
  }
  /**
   * Optional sub-set of the fields to return. This acts as a DocumentMask over
   * the documents returned from a query. When not set, assumes that the caller
   * wants all fields returned.
   *
   * @param Projection $select
   */
  public function setSelect(Projection $select)
  {
    $this->select = $select;
  }
  /**
   * @return Projection
   */
  public function getSelect()
  {
    return $this->select;
  }
  /**
   * A potential prefix of a position in the result set to start the query at.
   * The ordering of the result set is based on the `ORDER BY` clause of the
   * original query. ``` SELECT * FROM k WHERE a = 1 AND b > 2 ORDER BY b ASC,
   * __name__ ASC; ``` This query's results are ordered by `(b ASC, __name__
   * ASC)`. Cursors can reference either the full ordering or a prefix of the
   * location, though it cannot reference more fields than what are in the
   * provided `ORDER BY`. Continuing off the example above, attaching the
   * following start cursors will have varying impact: - `START BEFORE (2,
   * /k/123)`: start the query right before `a = 1 AND b > 2 AND __name__ >
   * /k/123`. - `START AFTER (10)`: start the query right after `a = 1 AND b >
   * 10`. Unlike `OFFSET` which requires scanning over the first N results to
   * skip, a start cursor allows the query to begin at a logical position. This
   * position is not required to match an actual result, it will scan forward
   * from this position to find the next document. Requires: * The number of
   * values cannot be greater than the number of fields specified in the `ORDER
   * BY` clause.
   *
   * @param Cursor $startAt
   */
  public function setStartAt(Cursor $startAt)
  {
    $this->startAt = $startAt;
  }
  /**
   * @return Cursor
   */
  public function getStartAt()
  {
    return $this->startAt;
  }
  /**
   * The filter to apply.
   *
   * @param Filter $where
   */
  public function setWhere(Filter $where)
  {
    $this->where = $where;
  }
  /**
   * @return Filter
   */
  public function getWhere()
  {
    return $this->where;
  }
}

// Adding a class alias for backwards compatibility with the previous class name.
class_alias(StructuredQuery::class, 'Google_Service_Firestore_StructuredQuery');
← Back