Package org.apache.coyote.http11.filters
Class SavedRequestInputFilter
- java.lang.Object
-
- org.apache.coyote.http11.filters.SavedRequestInputFilter
-
- All Implemented Interfaces:
InputFilter,InputBuffer
public class SavedRequestInputFilter extends java.lang.Object implements InputFilter
Input filter responsible for replaying the request body when restoring the saved request after FORM authentication.
-
-
Constructor Summary
Constructors Constructor Description SavedRequestInputFilter(ByteChunk input)Create a new SavedRequestInputFilter.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intavailable()Obtain an estimate of the number of bytes that can be read without blocking.intdoRead(ApplicationBufferHandler handler)Read from the input stream into the ByteBuffer provided by the ApplicationBufferHandler.longend()End the current request (has no effect).ByteChunkgetEncodingName()Get the name of the encoding handled by this filter.booleanisFinished()Has the request body been read fully?voidrecycle()Make the filter ready to process the next request.voidsetBuffer(InputBuffer buffer)Set the next buffer in the filter pipeline (has no effect).voidsetRequest(Request request)Some filters need additional parameters from the request.
-
-
-
Field Detail
-
input
protected ByteChunk input
The original request body.
-
-
Constructor Detail
-
SavedRequestInputFilter
public SavedRequestInputFilter(ByteChunk input)
Create a new SavedRequestInputFilter.- Parameters:
input- The saved request body to be replayed.
-
-
Method Detail
-
doRead
public int doRead(ApplicationBufferHandler handler) throws java.io.IOException
Description copied from interface:InputBufferRead from the input stream into the ByteBuffer provided by the ApplicationBufferHandler. IMPORTANT: the current model assumes that the protocol will 'own' the ByteBuffer and return a pointer to it.- Specified by:
doReadin interfaceInputBuffer- Parameters:
handler- ApplicationBufferHandler that provides the buffer to read data into.- Returns:
- The number of bytes that have been added to the buffer or -1 for end of stream
- Throws:
java.io.IOException- If an I/O error occurs reading from the input stream
-
setRequest
public void setRequest(Request request)
Some filters need additional parameters from the request. Set the content length on the request.- Specified by:
setRequestin interfaceInputFilter- Parameters:
request- The request to be associated with this filter
-
recycle
public void recycle()
Description copied from interface:InputFilterMake the filter ready to process the next request.- Specified by:
recyclein interfaceInputFilter
-
getEncodingName
public ByteChunk getEncodingName()
Description copied from interface:InputFilterGet the name of the encoding handled by this filter.- Specified by:
getEncodingNamein interfaceInputFilter- Returns:
- null
-
setBuffer
public void setBuffer(InputBuffer buffer)
Set the next buffer in the filter pipeline (has no effect).- Specified by:
setBufferin interfaceInputFilter- Parameters:
buffer- ignored
-
available
public int available()
Description copied from interface:InputBufferObtain an estimate of the number of bytes that can be read without blocking. Typically, this will be the number of available bytes known to be buffered.- Specified by:
availablein interfaceInputBuffer- Returns:
- The number of bytes that can be read without blocking
-
end
public long end() throws java.io.IOExceptionEnd the current request (has no effect).- Specified by:
endin interfaceInputFilter- Returns:
- 0
- Throws:
java.io.IOException- If an error happens
-
isFinished
public boolean isFinished()
Description copied from interface:InputFilterHas the request body been read fully?- Specified by:
isFinishedin interfaceInputFilter- Returns:
trueif the request body has been fully read, otherwisefalse
-
-