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

io.helidon.webclient.WebClientResponseImpl Maven / Gradle / Ivy

There is a newer version: 4.1.4
Show newest version
/*
 * Copyright (c) 2020, 2024 Oracle and/or its affiliates.
 *
 * 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 io.helidon.webclient;

import java.net.URI;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.concurrent.Flow;
import java.util.logging.Logger;

import io.helidon.common.http.DataChunk;
import io.helidon.common.http.Http;
import io.helidon.common.http.MediaType;
import io.helidon.common.reactive.Single;
import io.helidon.media.common.MessageBodyReadableContent;
import io.helidon.media.common.MessageBodyReaderContext;

/**
 * Immutable implementation of the {@link WebClientResponse}.
 */
final class WebClientResponseImpl implements WebClientResponse {

    private static final Logger LOGGER = Logger.getLogger(NettyClientHandler.class.getName());

    private final WebClientResponseHeadersImpl headers;
    private final Flow.Publisher publisher;
    private final Http.ResponseStatus status;
    private final Http.Version version;
    private final MessageBodyReaderContext readerContext;
    private final NettyClientHandler.ResponseCloser responseCloser;
    private final URI lastEndpointUri;

    private WebClientResponseImpl(Builder builder) {
        headers = WebClientResponseHeadersImpl.create(builder.headers, builder.mediaTypeParserRelaxed);
        publisher = builder.publisher;
        status = builder.status;
        version = builder.version;
        readerContext = builder.readerContext;
        responseCloser = builder.responseCloser;
        lastEndpointUri = builder.lastEndpointUri;
    }

    /**
     * Creates builder for {@link WebClientResponseImpl}.
     *
     * @return builder
     */
    public static Builder builder() {
        return new Builder();
    }

    @Override
    public Http.ResponseStatus status() {
        return status;
    }

    @Override
    public Http.Version version() {
        return version;
    }

    @Override
    public URI lastEndpointURI() {
        return lastEndpointUri;
    }

    @Override
    public Single close() {
        return responseCloser.close();
    }

    @Override
    public MessageBodyReadableContent content() {
        Optional mediaType = headers.contentType();
        MessageBodyReaderContext readerContext = MessageBodyReaderContext.create(this.readerContext, null, headers, mediaType);
        return MessageBodyReadableContent.create(publisher, readerContext);
    }

    @Override
    public WebClientResponseHeaders headers() {
        return headers;
    }

    /**
     * Builder for {@link WebClientResponseImpl}.
     */
    static class Builder implements io.helidon.common.Builder {

        private final Map> headers = new HashMap<>();

        private Flow.Publisher publisher;
        private Http.ResponseStatus status = Http.Status.INTERNAL_SERVER_ERROR_500;
        private Http.Version version = Http.Version.V1_1;
        private NettyClientHandler.ResponseCloser responseCloser;
        private MessageBodyReaderContext readerContext;
        private URI lastEndpointUri;
        private boolean mediaTypeParserRelaxed;

        @Override
        public WebClientResponseImpl build() {
            return new WebClientResponseImpl(this);
        }

        /**
         * Sets content publisher to the response.
         *
         * @param publisher content publisher
         * @return updated builder instance
         */
        Builder contentPublisher(Flow.Publisher publisher) {
            this.publisher = publisher;
            return this;
        }

        /**
         * Reader context of the request.
         *
         * @param readerContext message body reader
         * @return updated builder instance
         */
        Builder readerContext(MessageBodyReaderContext readerContext) {
            this.readerContext = readerContext;
            return this;
        }

        /**
         * Sets response status code.
         *
         * @param status response status code
         * @return updated builder instance
         */
        Builder status(Http.ResponseStatus status) {
            this.status = status;
            return this;
        }

        /**
         * Http version of the response.
         *
         * @param version response http version
         * @return updated builder instance
         */
        Builder httpVersion(Http.Version version) {
            this.version = version;
            return this;
        }

        /**
         * Adds header to the response.
         *
         * @param name   header name
         * @param values header value
         * @return updated builder instance
         */
        Builder addHeader(String name, List values) {
            this.headers.put(name, values);
            return this;
        }

        /**
         * Sets objects which helps to close response.
         *
         * @param responseCloser object closer object
         * @return updated builder instance
         */
        Builder responseCloser(NettyClientHandler.ResponseCloser responseCloser) {
            this.responseCloser = responseCloser;
            return this;
        }

        /**
         * Set last endpoint uri.
         *
         * @param lastEndpointUri endpoint uri
         * @return updated builder instance
         */
        Builder lastEndpointURI(URI lastEndpointUri) {
            this.lastEndpointUri = lastEndpointUri;
            return this;
        }

        /**
         * Set media type parsing mode for HTTP {@code Content-Type} header.
         *
         * @param mediaTypeParserRelaxed value of {@code true} sets relaxed media type parsing mode,
         *                               value of {@code false} sets strict media type parsing mode
         * @return updated builder instance
         */
        Builder mediaTypeParserRelaxed(boolean mediaTypeParserRelaxed) {
            this.mediaTypeParserRelaxed = mediaTypeParserRelaxed;
            return this;
        }

    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy