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

com.oracle.bmc.http.client.HttpRequest Maven / Gradle / Ivy

/**
 * Copyright (c) 2016, 2024, Oracle and/or its affiliates.  All rights reserved.
 * This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license.
 */
package com.oracle.bmc.http.client;

import java.io.InputStream;
import java.net.URI;
import java.util.List;
import java.util.Map;
import java.util.concurrent.CompletionStage;
import java.util.concurrent.Executor;

/**
 * Setup builder for a HTTP request, to be executed with {@link #execute()}.
 *
 * 

A {@link HttpRequest} must be either {@link #execute() executed} or {@link #discard() * discarded} to clean up all resources associated with it. */ public interface HttpRequest { Method method(); HttpRequest body(Object body); HttpRequest body(InputStream body, long contentLength); Object body(); HttpRequest appendPathPart(String encodedPathPart); /** * Add a query parameter. May be called multiple times for the same name. * *

Note: name and value must already be percent-encoded. */ HttpRequest query(String name, String value); URI uri(); HttpRequest header(String name, String value); Map> headers(); Object attribute(String name); HttpRequest removeAttribute(String name); HttpRequest attribute(String name, Object value); /** Executor to offload some work onto (mostly for better stack traces) */ HttpRequest offloadExecutor(Executor executor); /** * Create a new copy of this {@link HttpRequest} with independent request properties. For * example, you can add a new header to the copied request without affecting this one, and * execute them independently. Note that the copied request must be either executed or discarded * (just like this one). */ HttpRequest copy(); /** * Discard this request, signalling that it won't be {@link #execute() executed}. Any resources * associated with this request may be released. */ void discard(); CompletionStage execute(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy