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

com.cognite.client.servicesV1.ResponseItems Maven / Gradle / Ivy

/*
 * Copyright (c) 2020 Cognite AS
 *
 * 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.cognite.client.servicesV1;

import com.cognite.client.servicesV1.response.JsonErrorItemResponseParser;
import com.cognite.client.servicesV1.response.JsonStringAttributeResponseParser;
import com.cognite.client.servicesV1.response.ResponseParser;
import com.google.auto.value.AutoValue;
import com.google.common.base.Preconditions;
import com.google.common.collect.ImmutableList;

import javax.annotation.Nullable;
import java.io.Serializable;

/**
 * This class represents a collection of response items from a Cognite API request.
 *
 *
 */
@AutoValue
public abstract class ResponseItems implements Serializable {
    static  Builder builder() {
        return new com.cognite.client.servicesV1.AutoValue_ResponseItems.Builder()
                .setDuplicateResponseParser(JsonErrorItemResponseParser.builder()
                        .setErrorSubPath("duplicated")
                        .build())
                .setMissingResponseParser(JsonErrorItemResponseParser.builder()
                        .setErrorSubPath("missing")
                        .build())
                .setErrorMessageResponseParser(JsonStringAttributeResponseParser.create()
                        .withAttributePath("error.message"))
                .setStatusResponseParser(JsonStringAttributeResponseParser.create()
                        .withAttributePath("error.code"));
    }

    public static  ResponseItems of(ResponseParser responseParser, ResponseBinary response) {
        Preconditions.checkNotNull(responseParser, "Response parser cannot be null.");
        Preconditions.checkNotNull(response, "Response binary cannot be null.");

        return ResponseItems.builder()
                .setResponseParser(responseParser)
                .setResponseBinary(response)
                .build();
    }

    abstract Builder toBuilder();

    abstract ResponseParser getResponseParser();
    abstract ResponseParser getDuplicateResponseParser();
    abstract ResponseParser getMissingResponseParser();
    abstract ResponseParser getErrorMessageResponseParser();
    abstract ResponseParser getStatusResponseParser();
    @Nullable
    abstract ImmutableList getResultsItemsList();
    public abstract ResponseBinary getResponseBinary();

    /**
     * Specifies the parser for extracting duplicate items from the response payload.
     *
     * The default parser looks in the *duplicated* object of the response json.
     * @param parser
     * @return
     */
    public ResponseItems withDuplicateResponseParser(ResponseParser parser) {
        Preconditions.checkNotNull(parser, "Parser cannot be null.");
        return toBuilder().setDuplicateResponseParser(parser).build();
    }

    /**
     * Specifies the parser for extracting missing items from the response payload.
     *
     * The default parser looks in the *missing* object of the response json.
     * @param parser
     * @return
     */
    public ResponseItems withMissingResponseParser(ResponseParser parser) {
        Preconditions.checkNotNull(parser, "Parser cannot be null.");
        return toBuilder().setMissingResponseParser(parser).build();
    }

    /**
     * Specifies the parser for extracting the error message from the response payload.
     *
     * The default parser looks in the *message* attribute of the response json.
     * @param parser
     * @return
     */
    public ResponseItems withErrorMessageResponseParser(ResponseParser parser) {
        Preconditions.checkNotNull(parser, "Parser cannot be null.");
        return toBuilder().setErrorMessageResponseParser(parser).build();
    }

    /**
     * Specifies the parser for extracting the error code (http status code) from the response payload.
     *
     * The default parser looks in the *code* attribute of the response json.
     * @param parser
     * @return
     */
    public ResponseItems withStatusResponseParser(ResponseParser parser) {
        Preconditions.checkNotNull(parser, "Parser cannot be null.");
        return toBuilder().setStatusResponseParser(parser).build();
    }

    /**
     * Specifies a results items list. By setting this list you will override the default behavior
     * which is to parse the results items from the response body (bytes).
     *
     * That is, if a results items list is specified, the parser will not attempt to parse the response body.
     *
     * @param itemsList
     * @return
     */
    public ResponseItems withResultsItemsList(ImmutableList itemsList) {
        return toBuilder().setResultsItemsList(itemsList).build();
    }

    /**
     * Returns the main result items.
     *
     * @return A list of result items.
     * @throws Exception
     */
    public ImmutableList getResultsItems() throws Exception {
        if (null != getResultsItemsList()) {
            // a results items list is specified, so this will override the parser
            return getResultsItemsList();
        }
        return getResponseParser().extractItems(getResponseBinary().getResponseBodyBytes().toByteArray());
    }

    /**
     * Returns a list of duplicate items.
     *
     *
     * @return A list of duplicate items.
     * @throws Exception
     */
    public ImmutableList getDuplicateItems() throws Exception {
        return getDuplicateResponseParser().extractItems(getResponseBinary().getResponseBodyBytes().toByteArray());
    }

    public ImmutableList getMissingItems() throws Exception {
        return getMissingResponseParser().extractItems(getResponseBinary().getResponseBodyBytes().toByteArray());
    }

    public ImmutableList getStatus() throws Exception {
        return getStatusResponseParser().extractItems(getResponseBinary().getResponseBodyBytes().toByteArray());
    }

    public ImmutableList getErrorMessage() throws Exception {
        return getErrorMessageResponseParser().extractItems(getResponseBinary().getResponseBodyBytes().toByteArray());
    }

    public String getResponseBodyAsString() {
        return getResponseBinary().getResponseBodyBytes().toStringUtf8();
    }

    public boolean isSuccessful() {
        return getResponseBinary().getResponse().isSuccessful();
    }

    @AutoValue.Builder
    abstract static class Builder {
        abstract Builder setResponseParser(ResponseParser value);
        abstract Builder setDuplicateResponseParser(ResponseParser value);
        abstract Builder setMissingResponseParser(ResponseParser value);
        abstract Builder setErrorMessageResponseParser(ResponseParser value);
        abstract Builder setStatusResponseParser(ResponseParser value);
        abstract Builder setResponseBinary(ResponseBinary value);
        abstract Builder setResultsItemsList(ImmutableList value);

        abstract ResponseItems build();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy