Interface PostResponse
- All Known Implementing Classes:
AbstractPostResponse
,AbstractPostResponseWrapper
,HtmlPostResponseProxy
,HtmlResponse
,JSONResponse
PostResponse
interface defines the API of a response
container which can (and should) be used by PostOperation
services to
prepare responses to be sent back to the client.
This bundle provides a preconfigured HtmlResponse
and a
JSONResponse
implementation of this interface. Clients may extend the
AbstractPostResponse
class to provide their own response
implementations.
-
Method Summary
Modifier and TypeMethodDescriptiongetError()
Returns any recorded error ornull
Returns the location of the modification.Returns the parent location of the modification.getPath()
Returns the absolute path of the item upon which the request operated.Returns the referer previously set bysetReferer(String)
int
Returns the status code of this instance.Returns the status message ornull
if no has been set with thesetStatus(int, String)
method.boolean
Returnstrue
if this was a create request.boolean
void
Records a generic change of the giventype
with arguments.void
Records a 'copied' change.void
Records a 'created' changevoid
Records a 'deleted' changevoid
onModified
(String path) Records a 'modified' changevoid
Records a 'moved' change.void
send
(javax.servlet.http.HttpServletResponse response, boolean setStatus) Writes the response back over the provided HTTP channel.void
setCreateRequest
(boolean isCreateRequest) Sets whether the request was a create request or not.void
Sets the recorded error causing the operation to fail.void
setLocation
(String location) Sets the location of this modification.void
setParentLocation
(String parentLocation) Sets the parent location of the modification.void
Sets the absolute path of the item upon which the request operated.void
setReferer
(String referer) Sets the referer propertyvoid
Sets the response status code propertiesvoid
Sets the title of the response message
-
Method Details
-
setReferer
Sets the referer property- Parameters:
referer
- the referer
-
getReferer
String getReferer()Returns the referer previously set bysetReferer(String)
- Returns:
- the referer
-
setPath
Sets the absolute path of the item upon which the request operated.- Parameters:
path
- the path
-
getPath
String getPath()Returns the absolute path of the item upon which the request operated.If the
setPath(String)
method has not been called yet, this method returnsnull
.- Returns:
- the path (might be null)
-
setCreateRequest
void setCreateRequest(boolean isCreateRequest) Sets whether the request was a create request or not.- Parameters:
isCreateRequest
- true if the request was a create request
-
isCreateRequest
boolean isCreateRequest()Returnstrue
if this was a create request.Before calling the
setCreateRequest(boolean)
method, this method always returnsfalse
.- Returns:
- if this was a create request
-
setLocation
Sets the location of this modification. This is the externalized form of thecurrent path
.- Parameters:
location
- the location
-
getLocation
String getLocation()Returns the location of the modification.If the
setLocation(String)
method has not been called yet, this method returnsnull
.- Returns:
- the location
-
setParentLocation
Sets the parent location of the modification. This is the externalized form of the parent node of thecurrent path
.- Parameters:
parentLocation
- the parent location of the modification
-
getParentLocation
String getParentLocation()Returns the parent location of the modification.If the
setParentLocation(String)
method has not been called yet, this method returnsnull
.- Returns:
- the parent location
-
setTitle
Sets the title of the response message- Parameters:
title
- the title
-
setStatus
Sets the response status code properties- Parameters:
code
- the codemessage
- the message
-
getStatusCode
int getStatusCode()Returns the status code of this instance. If the status code has never been set by calling thesetStatus(int, String)
method, the status code is determined by checking if there was an error. If there was an error, the response is assumed to be unsuccessful and 500 is returned. If there is no error, the response is assumed to be successful and 200 is returned.- Returns:
- the status code
-
getStatusMessage
String getStatusMessage()Returns the status message ornull
if no has been set with thesetStatus(int, String)
method.- Returns:
- the status message (might be null)
-
setError
Sets the recorded error causing the operation to fail.- Parameters:
error
- the throwable
-
getError
Throwable getError()Returns any recorded error ornull
- Returns:
- an error or
null
-
isSuccessful
boolean isSuccessful()- Returns:
- true if the status code is 2xx
-
onCreated
Records a 'created' change- Parameters:
path
- path of the item that was created
-
onModified
Records a 'modified' change- Parameters:
path
- path of the item that was modified
-
onDeleted
Records a 'deleted' change- Parameters:
path
- path of the item that was deleted
-
onMoved
Records a 'moved' change.Note: the moved change only records the basic move command. the implied changes on the moved properties and sub nodes are not recorded.
- Parameters:
srcPath
- source path of the node that was moveddstPath
- destination path of the node that was moved.
-
onCopied
Records a 'copied' change.Note: the copy change only records the basic copy command. the implied changes on the copied properties and sub nodes are not recorded.
- Parameters:
srcPath
- source path of the node that was copieddstPath
- destination path of the node that was copied.
-
onChange
Records a generic change of the giventype
with arguments.- Parameters:
type
- The type of the modificationarguments
- The arguments to the modifications
-
send
Writes the response back over the provided HTTP channel. The actual format of the response is implementation dependent.- Parameters:
response
- to send tosetStatus
- whether to set the status code on the response- Throws:
IOException
- if an i/o exception occurs
-