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

com.couchbase.client.java.view.ViewMetaData 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.view;

import com.couchbase.client.core.msg.view.ViewChunkHeader;
import com.couchbase.client.java.json.JsonObject;

import java.util.Optional;

/**
 * Holds Metadata associated with a {@link ViewResult}.
 *
 * @since 3.0.0
 */
public class ViewMetaData {

    /**
     * If present, holds debug information for the response.
     */
    private final Optional debug;

    /**
     * Holds the total amount of rows in the view.
     */
    private final long totalRows;

    /**
     * Creates a new {@link ViewMetaData}.
     *
     * @param debug debug information if available.
     * @param totalRows the total number of rows in the view.
     */
    ViewMetaData(final Optional debug, final long totalRows) {
        this.debug = debug;
        this.totalRows = totalRows;
    }

    /**
     * Creates the {@link ViewMetaData} from the chunk header.
     *
     * @param header the chunk header.
     * @return the initialized {@link ViewMetaData}.
     */
    static ViewMetaData from(final ViewChunkHeader header) {
        return new ViewMetaData(
            header.debug().map(JsonObject::fromJson),
            header.totalRows()
        );
    }

    /**
     * If present, returns debug information of the view request.
     *
     * 

This information is only present if the debug flag has been set on the view options in the first place. Note * that this is a costly operation and should only be used - as the name suggests - during debugging.

* * @return the debug information as a generic {@link JsonObject} if present. */ public Optional debug() { return debug; } /** * Returns the total number of rows in the view as presented by the server. * * @return the total number of rows. */ public long totalRows() { return totalRows; } @Override public String toString() { return "ViewMetaData{" + "totalRows=" + totalRows + ", debug=" + debug + '}'; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy