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

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

There is a newer version: 4.1.4
Show newest version
/*
 * Copyright (c) 2020 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.util.Map;

import io.helidon.common.context.Context;
import io.helidon.common.http.HttpRequest;
import io.helidon.common.reactive.Single;
import io.helidon.webclient.spi.WebClientService;

/**
 * Request to SPI {@link WebClientService} that supports modification of the outgoing request.
 */
public interface WebClientServiceRequest extends HttpRequest {
    /**
     * Configured request headers.
     *
     * @return headers (mutable)
     */
    WebClientRequestHeaders headers();

    /**
     * Registry that can be used to propagate information from server (e.g. security context, tracing spans etc.).
     *
     * @return registry propagated by the user
     */
    Context context();

    /**
     * Request id which will be used in logging messages.
     *
     * @return current request id
     */
    long requestId();

    /**
     * Set new request id. This id is used in logging messages.
     *
     * @param requestId new request id
     */
    void requestId(long requestId);

    /**
     * Completes when the request part of this request is done (e.g. we have sent all headers and bytes).
     *
     * @return completion stage that finishes when we fully send request (including entity) to server
     */
    Single whenSent();

    /**
     * Completes when the response headers has been received, but entity has not been processed yet.
     *
     * @return completion stage that finishes when we received headers
     */
    Single whenResponseReceived();

    /**
     * Completes when the full processing of this request is done (e.g. we have received a full response).
     *
     * @return completion stage that finishes when we receive and fully read response from the server
     */
    Single whenComplete();

    /**
     * Properties configured by user when creating this client request.
     *
     * @return properties that were configured (mutable)
     * @see WebClientRequestBuilder#property(String, String)
     */
    Map properties();

    /**
     * Schema of the request uri.
     *
     * This will not match schema returned by {@link WebClientServiceRequest#uri()}
     * if changed by {@link WebClientServiceRequest#schema(String schema)}
     *
     * @return schema of the request
     */
    String schema();

    /**
     * Set new schema of the request.
     *
     * @param schema new request schema
     */
    void schema(String schema);

    /**
     * Host of the request uri.
     *
     * This will not match host returned by {@link WebClientServiceRequest#uri()}
     * if changed by {@link WebClientServiceRequest#host(String host)}
     *
     * @return host of the request
     */
    String host();

    /**
     * Set new host of the request.
     *
     * @param host new request host
     */
    void host(String host);

    /**
     * Port of the request uri.
     *
     * This will not match port returned by {@link WebClientServiceRequest#uri()}
     * if changed by {@link WebClientServiceRequest#port(int port)}
     *
     * @return port of the request
     */
    int port();

    /**
     * Set new port of the request.
     *
     * @param port new request port
     */
    void port(int port);

    /**
     * Set the new path of the request.
     *
     * @param path new request path
     */
    void path(String path);

    /**
     * Set the new fragment of the request.
     *
     * @param fragment new request fragment
     */
    void fragment(String fragment);

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy