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

ratpack.http.HttpUrlBuilder Maven / Gradle / Ivy

There is a newer version: 2.0.0-rc-1
Show newest version
/*
 * Copyright 2014 the original author or authors.
 *
 * 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 ratpack.http;

import com.google.common.collect.ImmutableMultimap;
import com.google.common.collect.Multimap;
import ratpack.func.Action;
import ratpack.http.internal.DefaultHttpUrlBuilder;

import java.net.URI;
import java.util.Map;

/**
 * Builds a HTTP URL, safely.
 * 

* This builder applies appropriate escaping of values to produce valid HTTP URLs. * Typically used to build URLs for use with the {@link ratpack.http.client.HttpClient}. *

{@code
 * import ratpack.http.HttpUrlBuilder;
 *
 * import static org.junit.Assert.assertEquals;
 *
 * public class Example {
 *
 *   public static void main(String... args) {
 *     String url = HttpUrlBuilder.http()
 *       .host("foo.com")
 *       .path("a/b")
 *       .segment("c/%s", "d")
 *       .params("k1", "v1", "k2", "v2")
 *       .build()
 *       .toString();
 *
 *     assertEquals("http://foo.com/a/b/c%2Fd?k1=v1&k2=v2", url);
 *   }
 * }
 * }
*/ public interface HttpUrlBuilder { /** * Create a new builder, with the initial state of the given URI. *

* The URI must be of the {@code http} or {@code https} protocol. * If it is of any other, an {@link IllegalArgumentException} will be thrown. * * @param uri the uri to base the builder's state from * @return a new url builder */ static HttpUrlBuilder base(URI uri) { return new DefaultHttpUrlBuilder(uri); } /** * Create a new HTTP URL builder. *

* The protocol is set to HTTP, host to {@code localhost} and port to the default for the protocol. * * @return a new url builder */ static HttpUrlBuilder http() { return new DefaultHttpUrlBuilder(); } /** * Create a new HTTPS URL builder. *

* The protocol is set to HTTPS, host to {@code localhost} and port to the default for the protocol. * * @return a new url builder */ static HttpUrlBuilder https() { return http().secure(); } /** * Sets the protocol to be HTTPS. *

* If the port has not been explicitly set, it will be changed to match the default for HTTPS. * * @return this */ HttpUrlBuilder secure(); /** * Sets the host to the given value. * * @param host The host. * @return this */ HttpUrlBuilder host(String host); /** * Sets the port to the given value. *

* Any value less than 1 will throw an {@link IllegalAccessException}. * * @param port The port number. * @return this */ HttpUrlBuilder port(int port); /** * Appends some path to the URL. *

* The given value will may be a string such as {@code "foo"} or {@code "foo/bar"}. * In the case of the latter, the {@code "/"} character will not be URL escaped. * All other meta characters that apply to the path component of a HTTP URL will be percent encoded. *

* If the value to append should be exactly one path segment (i.e. {@code "/"} should be encoded), use {@link #segment(String, Object...)}. * * @param path The path to append. * @return this */ HttpUrlBuilder path(String path); /** * Appends one path segment to the URL. *

* This method first builds a string using {@link String#format(String, Object...)}. * The resultant string is percent encoded as is applicable for the path component of a HTTP URL. *

* This method should generally be preferred over {@link #path(String)} when incrementally building dynamic URLs, where values may container the HTTP URL path delimiter (i.e. {@code "/"}). * * @param pathSegment the path segment format string * @param args token arguments * @return this */ HttpUrlBuilder segment(String pathSegment, Object... args); /** * Add some query params to the URL. *

* Counting from zero, even numbered items are considered keys and odd numbered items are considered values. * If param list ends in a key, a subsequent value of {@code ""} will be implied. * * @param params the param list * @return this */ HttpUrlBuilder params(String... params); /** * Add some query params to the URL. *

* The given action will be supplied with a multi map builder, to which it can contribute query params. *

* This method is additive with regard to the query params of this builder. * * @param params an action that contributes query params * @return this * @throws Exception any thrown by {@code params} */ default HttpUrlBuilder params(Action> params) throws Exception { return params(Action.with(ImmutableMultimap.builder(), params).build()); } /** * Add some query params to the URL. *

* The entries of the given map are added as query params to the URL being built. *

* This method is additive with regard to the query params of this builder. * * @param params a map of query params to add to the URL being built * @return this */ HttpUrlBuilder params(Map params); /** * Add some query params to the URL. *

* The entries of the given multi map are added as query params to the URL being built. *

* This method is additive with regard to the query params of this builder. * * @param params a multi map of query params to add to the URL being built * @return this */ HttpUrlBuilder params(Multimap params); /** * Builds the URI based on this builder's current state. * * @return a new HTTP/HTTPS URI */ URI build(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy