All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.couchbase.client.java.manager.query.QueryIndex Maven / Gradle / Ivy

/*
 * Copyright 2019 Couchbase, 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.
 */

package com.couchbase.client.java.manager.query;

import com.couchbase.client.core.annotation.Stability;
import com.couchbase.client.core.api.manager.CoreQueryIndex;
import com.couchbase.client.java.json.JsonArray;
import com.couchbase.client.java.json.JsonObject;

import java.util.Objects;
import java.util.Optional;

import static com.couchbase.client.core.logging.RedactableArgument.redactMeta;
import static com.couchbase.client.core.util.CbObjects.defaultIfNull;
import static com.couchbase.client.core.util.CbStrings.emptyToNull;
import static java.util.Objects.requireNonNull;

/**
 * Contains the properties of a Query Index.
 */
public class QueryIndex {
  private final CoreQueryIndex internal;

  @Stability.Internal
  QueryIndex(final CoreQueryIndex internal) {
    this.internal = requireNonNull(internal);
  }

  /**
   * True if this index is a primary index.
   *
   * @return true if this index is a primary index.
   */
  public boolean primary() {
    return internal.primary();
  }

  /**
   * Returns the name of this index.
   *
   * @return the name of the index.
   */
  public String name() {
    return internal.name();
  }

  /**
   * Returns the index type (most likely "gsi").
   *
   * @return the type of the index.
   */
  public String type() {
    return internal.type();
  }

  /**
   * Returns the state in which the index is in (i.e. "online").
   *
   * @return the state of the index.
   */
  public String state() {
    return internal.state();
  }

  /**
   * Returns the keyspace of this index.
   * 

* If the index is at the bucket-level, this will return the bucket name. If the index is at the collection-level, * the keyspace is the name of the collection. * * @return the keyspace of this index. */ public String keyspace() { return internal.keyspace(); } /** * Returns the namespace of this index. *

* The namespace should not be confused with the keyspace - the namespace usually is "default". * * @return the namespace of this index. */ public String namespace() { return internal.namespace(); } /** * Returns an {@link JsonArray array} of Strings that represent the index key(s). *

* The array is empty in the case of a PRIMARY INDEX. *

* Note that the query service can present the key in a slightly different manner from when you declared the index: * for instance, it will show the indexed fields in an escaped format (surrounded by backticks). * * @return an array of Strings that represent the index key(s), or an empty array in the case of a PRIMARY index. */ public JsonArray indexKey() { return JsonArray.fromJson(internal.indexKey().toString()); } /** * Returns the {@link String} representation of the index's condition (the WHERE clause of the index), or an empty * Optional if no condition was set. *

* Note that the query service can present the condition in a slightly different manner from when you declared the index: * for instance it will wrap expressions with parentheses and show the fields in an escaped format (surrounded by * backticks). * * @return the condition/WHERE clause of the index or empty string if none. */ public Optional condition() { return internal.condition(); } /** * If present, returns the configured partition for the index. * * @return the partition if set, empty if none. */ public Optional partition() { return internal.partition(); } /** * If present, returns the name of the scope this index is stored in. * * @return the name of the scope, if present. */ public Optional scopeName() { return internal.scopeName(); } /** * If present, returns the name of the bucket this index is stored in. * * @return the name of the bucket, if present. */ public String bucketName() { return internal.bucketName(); } /** * If present, returns the name of the collection this index is stored in. * * @return the name of the collection, if present. */ public Optional collectionName() { return internal.collectionName(); } /** * Returns the JSON as it arrived from the server. * * @return the raw JSON representation of the index information, as returned by the query service. */ public JsonObject raw() { return JsonObject.fromJson(internal.raw().toString()); } @Override public boolean equals(Object o) { if (this == o) { return true; } if (o == null || getClass() != o.getClass()) { return false; } QueryIndex that = (QueryIndex) o; return raw().equals(that.raw()); } @Override public int hashCode() { return Objects.hash(raw()); } @Override public String toString() { return redactMeta(raw()).toString(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy