org.simpleframework.http.Address Maven / Gradle / Ivy
Show all versions of simple Show documentation
/*
* Address.java February 2001
*
* Copyright (C) 2001, Niall Gallagher
*
* 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 org.simpleframework.http;
import org.simpleframework.util.KeyMap;
/**
* The Address
interface is used to represent a generic
* uniform resource identifier. This interface allows each section
* of the uniform resource identifier to be represented. A generic
* uniform resource identifier syntax is represented in RFC 2616
* section 3.2.2 for the HTTP protocol, this allows similar URI's
* for example ftp, http, https, tftp. The syntax is
*
*
* URI = [scheme "://"] host [ ":" port ] [ path [ "?" query ]]
*
*
* This interface represents the host, port, path and query part
* of the uniform resource identifier. The parameters are also
* represented by the URI. The parameters in a URI consist of name
* and value pairs in the path segment of the URI.
*
* This will normalize the path part of the uniform resource
* identifier. A normalized path is one that contains no back
* references like "./" and "../". The normalized path will not
* contain the path parameters.
*
* @author Niall Gallagher
*/
public interface Address {
/**
* This allows the scheme of the URL given to be returned.
* If the URI does not contain a scheme then this will
* return null. The scheme of the URI is the part that
* specifies the type of protocol that the URI is used
* for, an example http://domain/path
is
* a URI that is intended for the http protocol. The
* scheme is the string http
.
*
* @return the scheme tag for the address if available
*/
String getScheme();
/**
* This is used to retrieve the domain of this URI. The
* domain part in the URI is an optional part, an example
* http://domain/path?querypart
. This will
* return the value of the domain part. If there is no
* domain part then this will return null otherwise the
* domain value found in the uniform resource identifier.
*
* @return the domain part of the address if available
*/
String getDomain();
/**
* This is used to retrieve the port of the uniform resource
* identifier. The port part in this is an optional part, an
* example http://host:port/path?querypart
. This
* will return the value of the port. If there is no port then
* this will return -1
because this represents
* an impossible uniform resource identifier port. The port
* is an optional part.
*
* @return this returns the port part if it is available
*/
int getPort();
/**
* This is used to retrieve the path of this URI. The path part
* is the most fundamental part of the URI. This will return
* the value of the path. If there is no path part then this
* will return a Path implementation that represents the root
* path represented by /
.
*
* @return the path part of the uniform resource identifier
*/
Path getPath();
/**
* This is used to retrieve the query of this URI. The query part
* in the URI is an optional part. This will return the value
* of the query part. If there is no query part then this will
* return an empty Query
object. The query is
* an optional member of a URI and comes after the path part, it
* is preceded by a question mark, ?
character.
* For example the following URI contains query
for
* its query part, http://host:port/path?query
.
*
* This returns a org.simpleframework.http.Query
* object that can be used to interact directly with the query
* values. The Query
object is a read-only interface
* to the query parameters, and so will not affect the URI.
*
* @return a Query
object for the query part
*/
Query getQuery();
/**
* This extracts the parameter values from the uniform resource
* identifier represented by this object. The parameters that a
* uniform resource identifier contains are embedded in the path
* part of the URI. If the path contains no parameters then this
* will return an empty Map
instance.
*
* This will produce unique name and value parameters. Thus if the
* URI contains several path segments with similar parameter names
* this will return the deepest parameter. For example if the URI
* represented was http://domain/path1;x=y/path2;x=z
* the value for the parameter named x
would be
* z
.
*
* @return this will return the parameter names found in the URI
*/
KeyMap getParameters();
/**
* This is used to convert this URI object into a String
* object. This will only convert the parts of the URI that exist, so
* the URI may not contain the domain or the query part and it will
* not contain the path parameters. If the URI contains all these
* parts then it will return something like
*
* scheme://host:port/path/path?querypart
*
*
* It can return /path/path?querypart
style relative
* URI's. If any of the parts are set to null then that part will be
* missing, for example if only the path is available then this will
* omit the domain, port and scheme. Showing a relative address.
*
* scheme://host:port/?querypart
*
*
* @return the URI address with the optional parts if available
*/
String toString();
}