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

com.couchbase.client.java.query.QueryMetaData Maven / Gradle / Ivy

/*
 * Copyright (c) 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.query;

import com.couchbase.client.core.annotation.Stability;
import com.couchbase.client.core.api.query.CoreQueryMetaData;
import com.couchbase.client.core.error.DecodingFailureException;
import com.couchbase.client.java.json.JacksonTransformers;
import com.couchbase.client.java.json.JsonArray;
import com.couchbase.client.java.json.JsonObject;

import java.io.IOException;
import java.util.List;
import java.util.Optional;
import java.util.stream.Collectors;

/**
 * Stores any non-rows results related to the execution of a particular N1QL query.
 *
 * @author Graham Pople
 * @since 1.0.0
 */
public class QueryMetaData {
    CoreQueryMetaData internal;

    @Stability.Internal
    public QueryMetaData(CoreQueryMetaData internal) {
      this.internal = internal;
    }

    /**
     * Returns the request identifier string of the query request
     */
    public String requestId() {
      return internal.requestId();
    }

    /**
     * Returns the client context identifier string set on the query request.
     */
    public String clientContextId() {
      return internal.clientContextId();
    }

    /**
     * Returns the raw query execution status as returned by the query engine
     */
    public QueryStatus status() {
      return QueryStatus.from(internal.status().name());
    }

    /**
     * Returns the signature returned by the query engine, parsed as a {@link JsonObject},
     * or an empty optional if no signature is available.
     * 

* A signature describes the "shape" of the query results. *

* For cases where the signature is not known to be a JSON Object, * please use {@link #signatureBytes()} instead. * * @throws DecodingFailureException if the signature is not a JSON Object. */ public Optional signature() { return signatureBytes().map(v -> { try { return JacksonTransformers.MAPPER.readValue(v, JsonObject.class); } catch (IOException ex) { throw new DecodingFailureException(ex); } }); } /** * Returns a byte array containing the signature returned by the query engine, * or an empty optional if no signature is available. *

* The byte array contains JSON describing the "shape" of the query results. * For most queries it's a JSON Object, but it can be any JSON type. */ @Stability.Uncommitted public Optional signatureBytes() { return internal.signature(); } /** * Returns the profiling information returned by the query engine which is then decoded to {@link JsonObject} *

* It is returned as an Optional which will be empty if no profile information is available. * * @throws DecodingFailureException when the profile cannot be decoded successfully */ public Optional profile() { return internal.profile().map(v -> { try { return JacksonTransformers.MAPPER.readValue(v, JsonObject.class); } catch (IOException ex) { throw new DecodingFailureException(ex); } }); } /** * Returns a byte array containing the profiling information returned by the query engine, * or an empty optional if no profiling information is available. *

* The byte array contains a JSON Object. */ public Optional profileBytes() { return internal.profile(); } /** * Returns the {@link QueryMetrics} as returned by the query engine if enabled. * * @throws DecodingFailureException when the metrics cannot be decoded successfully */ public Optional metrics() { return internal.metrics().map(QueryMetrics::new); } /** * Returns any warnings returned by the query engine, as a {@link JsonArray}. *

* It is returned as an Optional which will be empty if no warnings were returned * * @throws DecodingFailureException when the warnings cannot be decoded successfully */ public List warnings() { return internal.warnings() .stream() .map(v -> new QueryWarning(v.inner())) .collect(Collectors.toList()); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy