com.aspectran.core.adapter.RequestAdapter Maven / Gradle / Ivy
Show all versions of aspectran-core Show documentation
/*
* Copyright (c) 2008-2017 The Aspectran Project
*
* 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 com.aspectran.core.adapter;
import com.aspectran.core.activity.request.parameter.FileParameter;
import com.aspectran.core.component.bean.scope.RequestScope;
import com.aspectran.core.context.rule.type.MethodType;
import com.aspectran.core.util.MultiValueMap;
import java.io.UnsupportedEncodingException;
import java.util.Collection;
import java.util.Enumeration;
import java.util.Locale;
import java.util.Map;
import java.util.TimeZone;
/**
* The Interface RequestAdapter.
*
* @since 2011. 3. 13.
*/
public interface RequestAdapter {
/**
* Returns the adaptee object to provide request information.
*
* @param the type of the adaptee object
* @return the adaptee object
*/
T getAdaptee();
/**
* Gets the request scope.
*
* @return the request scope
*/
RequestScope getRequestScope();
/**
* Gets the request scope.
*
* @param create {@code true} to create a new request scope for this
* request if necessary; {@code false} to return {@code null}
* @return the request scope
*/
RequestScope getRequestScope(boolean create);
/**
* Returns the name of the character encoding used in the body of this request.
*
* @return a {@code String} containing the name of the character encoding,
* or {@code null} if the request does not specify a character encoding
*/
String getEncoding();
/**
* Overrides the name of the character encoding used in the body of this request.
* This method must be called prior to reading request parameters
* or reading input using getReader(). Otherwise, it has no effect.
*
* @param encoding a {@code String} containing the name of the character encoding.
* @throws UnsupportedEncodingException if the specified encoding is invalid
*/
void setEncoding(String encoding) throws UnsupportedEncodingException;
/**
* Returns the method used for the request.
*
* @return a {@code MethodType} object
*/
MethodType getRequestMethod();
/**
* Returns a map of the request headers that can be modified.
*
* @return an {@code MultiValueMap} object, may be {@code null}
*/
MultiValueMap getAllHeaders();
/**
* Returns the value of the response header with the given name.
*
* If a response header with the given name exists and contains
* multiple values, the value that was added first will be returned.
*
* @param name the name of the response header whose value to return
* @return the value of the response header with the given name,
* or {@code null} if no header with the given name has been set
* on this response
*/
String getHeader(String name);
/**
* Returns the values of the response header with the given name.
*
* @param name the name of the response header whose values to return
* @return a (possibly empty) {@code Collection} of the values
* of the response header with the given name
*/
Collection getHeaders(String name);
/**
* Returns the names of the headers of this response.
*
* @return a (possibly empty) {@code Collection} of the names
* of the headers of this response
*/
Collection getHeaderNames();
/**
* Returns a boolean indicating whether the named response header
* has already been set.
*
* @param name the header name
* @return {@code true} if the named response header
* has already been set; {@code false} otherwise
*/
boolean containsHeader(String name);
/**
* Set the given single header value under the given header name.
*
* @param name the header name
* @param value the header value to set
*/
void setHeader(String name, String value);
/**
* Add the given single header value to the current list of values
* for the given header.
*
* @param name the header name
* @param value the header value to be added
*/
void addHeader(String name, String value);
/**
* Returns the value of a request parameter as a {@code String},
* or {@code null} if the parameter does not exist.
*
* @param name a {@code String} specifying the name of the parameter
* @return a {@code String} representing the
* single value of the parameter
* @see #getParameterValues
*/
String getParameter(String name);
/**
* Returns an array of {@code String} objects containing all
* of the values the given activity's request parameter has,
* or {@code null} if the parameter does not exist.
*
* @param name a {@code String} specifying the name of the parameter
* @return an array of {@code String} objects
* containing the parameter's values
* @see #getParameter
*/
String[] getParameterValues(String name);
/**
* Returns an {@code Enumeration} of {@code String} objects containing
* the names of the parameters contained in this request.
* If the request has no parameters, the method returns an empty {@code Enumeration}.
*
* @return an {@code Enumeration} of {@code String} objects, each {@code String}
* containing the name of a request parameter;
* or an empty {@code Enumeration} if the request has no parameters
*/
Enumeration getParameterNames();
/**
* Sets the value to the parameter with the given name.
*
* @param name a {@code String} specifying the name of the parameter
* @param value a {@code String} representing the
* single value of the parameter
* @see #setParameter(String, String[])
*/
void setParameter(String name, String value);
/**
* Sets the value to the parameter with the given name.
*
* @param name a {@code String} specifying the name of the parameter
* @param values an array of {@code String} objects
* containing the parameter's values
* @see #setParameter
*/
void setParameter(String name, String[] values);
/**
* Return an immutable Map of the request parameters,
* with parameter names as map keys and parameter values as map values.
* If the parameter value type is the String then map value will be of type String.
* If the parameter value type is the String array then map value will be of type String array.
*
* @return the immutable parameter map
* @since 1.4.0
*/
Map getAllParameters();
/**
* Returns the parameter copied to the new instance.
*
* @return the mutable parameter map
*/
Map copyAllParameters();
/**
* Fills all parameters to the specified map.
*
* @param targetParameters the target parameter map to be filled
* @since 2.0.0
*/
void fillAllParameters(Map targetParameters);
/**
* Returns a {@code FileParameter} object as a given request parameter name,
* or {@code null} if the file parameter does not exist.
*
* @param name a {@code String} specifying the name of the file parameter
* @return a {@code FileParameter} representing the
* single value of the parameter
* @see #getFileParameterValues
*/
FileParameter getFileParameter(String name);
/**
* Returns an array of {@code FileParameter} objects containing all
* of the values the given request parameter has,
* or {@code null} if the parameter does not exist.
*
* @param name a {@code String} specifying the name of the file parameter
* @return an array of {@code FileParameter} objects
* containing the parameter's values
* @see #getFileParameter
*/
FileParameter[] getFileParameterValues(String name);
/**
* Returns an {@code Enumeration} of {@code String} objects containing
* the names of the file parameters contained in this request.
* If the request has no parameters, the method returns an empty {@code Enumeration}.
*
* @return an {@code Enumeration} of {@code String} objects, each {@code String}
* containing the name of a file parameter;
* or an empty {@code Enumeration} if the request has no file parameters
*/
Enumeration getFileParameterNames();
/**
* Sets the {@code FileParameter} object to the file parameter with the given name.
*
* @param name a {@code String} specifying the name of the file parameter
* @param fileParameter a {@code FileParameter} representing the
* single value of the parameter
* @see #setFileParameter(String, FileParameter[])
*/
void setFileParameter(String name, FileParameter fileParameter);
/**
* Sets the value to the file parameter with the given name.
*
* @param name a {@code String} specifying the name of the file parameter
* @param fileParameters an array of {@code FileParameter} objects
* containing the file parameter's values
* @see #setFileParameter
*/
void setFileParameter(String name, FileParameter[] fileParameters);
/**
* Removes the file parameter with the specified name.
*
* @param name a {@code String} specifying the name of the file parameter
*/
void removeFileParameter(String name);
/**
* Returns the value of the named attribute as a given type,
* or {@code null} if no attribute of the given name exists.
*
* @param the generic type
* @param name a {@code String} specifying the name of the attribute
* @return an {@code Object} containing the value of the attribute,
* or {@code null} if the attribute does not exist
*/
T getAttribute(String name);
/**
* Stores an attribute in this request.
*
* @param name specifying the name of the attribute
* @param value the {@code Object} to be stored
*/
void setAttribute(String name, Object value);
/**
* Returns an {@code Enumeration} containing the
* names of the attributes available to this request.
* This method returns an empty {@code Enumeration}
* if the request has no attributes available to it.
*
* @return the attribute names
*/
Enumeration getAttributeNames();
/**
* Removes an attribute from this request.
*
* @param name a {@code String} specifying the name of the attribute to remove
*/
void removeAttribute(String name);
/**
* Returns an immutable map of the attributes,
* with attribute names as map keys and attribute value as map value.
*
* @return an unmodifiable map of the attributes
*/
Map getAllAttributes();
/**
* Copies all of the mappings from the specified attributes.
*
* @param attributes the specified attributes
*/
void putAllAttributes(Map attributes);
/**
* Fills all attributes to the specified map.
*
* @param targetAttributes the target attribute map to be filled
* @since 2.0.0
*/
void fillAllAttributes(Map targetAttributes);
/**
* Returns whether request header has exceed the maximum length.
*
* @return true, if max length exceeded
*/
boolean isMaxLengthExceeded();
/**
* Sets whether request header has exceed the maximum length.
*
* @param maxLengthExceeded whether the max length exceeded
*/
void setMaxLengthExceeded(boolean maxLengthExceeded);
/**
* Returns the preferred {@code Locale}.
*
* @return a preferred {@code Locale}
*/
Locale getLocale();
/**
* Sets the preferred {@code Locale}.
*
* @param locale a given {@code Locale}
*/
void setLocale(Locale locale);
/**
* Returns the preferred {@code TimeZone}.
*
* @return a preferred {@code TimeZone}
*/
TimeZone getTimeZone();
/**
* Sets the preferred {@code TimeZone}.
*
* @param timeZone a given {@code TimeZone}
*/
void setTimeZone(TimeZone timeZone);
}