Class OutboundMessageContext
java.lang.Object
org.glassfish.jersey.message.internal.OutboundMessageContext
- Direct Known Subclasses:
ClientRequest
Base outbound message context implementation.
- Author:
- Marek Potociar
-
Nested Class Summary
Modifier and TypeClassDescriptionstatic interface
The callback interface which is used to get the terminal output stream into which the entity should be written and to inform the implementation about the entity size. -
Constructor Summary
ConstructorDescriptionDeprecated.OutboundMessageContext
(Configuration configuration) Create new outbound message context.OutboundMessageContext
(OutboundMessageContext original) Create new outbound message context copying the content of another context. -
Method Summary
Modifier and TypeMethodDescriptionvoid
close()
Closes the context.void
Commits theentity stream
if it wasn't already committed.void
enableBuffering
(Configuration configuration) Enable a buffering of serialized entity.Get a list of languages that are acceptable for the message.Get a list of media types that are acceptable for the message.Get the allowed HTTP methods from the Allow HTTP header.The related client/server sideConfiguration
.getDate()
Get message date.Get the message entity Java instance.Get the annotations attached to the entity.Class<?>
Get the raw message entity type information.Get the entity output stream.Get the entity tag.Get the message entity type information.Get the mutable message headers multivalued map.getHeaderString
(String name) Get a message header as a single string value.Get the language of the entity.Get the last modified date.int
Get Content-Length value.long
Get Content-Length value.Get the link for the relation.getLinkBuilder
(String relation) Convenience method that returns aLink.Builder
for the relation.getLinks()
Get the links attached to the message as header.Get the location.Get the media type of the entity.Get any cookies that accompanied the message.Get any new cookies set on the message message.Get a multi-valued map representing outbound message headers with their values converted to strings.boolean
Check if there is an entity available in the message.boolean
Check if link for relation exists.boolean
Returnstrue
if the entity stream has been committed.void
replaceHeaders
(MultivaluedMap<String, Object> headers) Replace all headers.void
Set a new message message entity.void
setEntity
(Object entity, Annotation[] annotations) Set a new message message entity.void
setEntity
(Object entity, Annotation[] annotations, MediaType mediaType) Set a new message message entity.void
setEntity
(Object entity, Type type, Annotation[] annotations) Set a new message message entity.void
setEntityAnnotations
(Annotation[] annotations) Set the annotations attached to the entity.void
setEntityStream
(OutputStream outputStream) Set a new entity output stream.void
setEntityType
(Type type) Set the message entity type information.void
setMediaType
(MediaType mediaType) Set the message content media type.void
setStreamProvider
(OutboundMessageContext.StreamProvider streamProvider) Set a stream provider callback.
-
Constructor Details
-
OutboundMessageContext
Create new outbound message context.- Parameters:
configuration
- the client/serverConfiguration
. Ifnull
, the default behaviour is expected.
-
OutboundMessageContext
Create new outbound message context copying the content of another context.- Parameters:
original
- the original outbound message context.
-
OutboundMessageContext
Deprecated.Create new outbound message context.- See Also:
-
-
Method Details
-
replaceHeaders
Replace all headers.- Parameters:
headers
- new headers.
-
getStringHeaders
Get a multi-valued map representing outbound message headers with their values converted to strings.- Returns:
- multi-valued map of outbound message header names to their string-converted values.
-
getHeaderString
Get a message header as a single string value.Each single header value is converted to String using a
RuntimeDelegate.HeaderDelegate
if one is available viaRuntimeDelegate.createHeaderDelegate(java.lang.Class)
for the header value class or using itstoString
method if a header delegate is not available.- Parameters:
name
- the message header.- Returns:
- the message header value. If the message header is not present then
null
is returned. If the message header is present but has no value then the empty string is returned. If the message header is present more than once then the values of joined together and separated by a ',' character.
-
getHeaders
Get the mutable message headers multivalued map.- Returns:
- mutable multivalued map of message headers.
-
getDate
Get message date.- Returns:
- the message date, otherwise
null
if not present.
-
getLanguage
Get the language of the entity.- Returns:
- the language of the entity or
null
if not specified
-
getMediaType
Get the media type of the entity.- Returns:
- the media type or
null
if not specified (e.g. there's no message entity).
-
getAcceptableMediaTypes
Get a list of media types that are acceptable for the message.- Returns:
- a read-only list of requested message media types sorted according to their q-value, with highest preference first.
-
getAcceptableLanguages
Get a list of languages that are acceptable for the message.- Returns:
- a read-only list of acceptable languages sorted according to their q-value, with highest preference first.
-
getRequestCookies
Get any cookies that accompanied the message.- Returns:
- a read-only map of cookie name (String) to
Cookie
.
-
getAllowedMethods
Get the allowed HTTP methods from the Allow HTTP header.- Returns:
- the allowed HTTP methods, all methods will returned as upper case strings.
-
getLength
public int getLength()Get Content-Length value.Note:
getLengthLong()
should be preferred over this method, since it returns along
instead and is therefore more portable.- Returns:
- Content-Length as a postive integer if present and valid number,
-1
if negative number. - Throws:
ProcessingException
- whenInteger.parseInt(String)
(String)} throwsNumberFormatException
.
-
getLengthLong
public long getLengthLong()Get Content-Length value.- Returns:
- Content-Length as a positive long if present and valid number,
-1
if negative number. - Throws:
ProcessingException
- whenLong.parseLong(String)
throwsNumberFormatException
.
-
getResponseCookies
Get any new cookies set on the message message.- Returns:
- a read-only map of cookie name (String) to a
new cookie
.
-
getEntityTag
Get the entity tag.- Returns:
- the entity tag, otherwise
null
if not present.
-
getLastModified
Get the last modified date.- Returns:
- the last modified date, otherwise
null
if not present.
-
getLocation
Get the location.- Returns:
- the location URI, otherwise
null
if not present.
-
getLinks
Get the links attached to the message as header.- Returns:
- links, may return empty
Set
if no links are present. Never returnsnull
.
-
hasLink
Check if link for relation exists.- Parameters:
relation
- link relation.- Returns:
true
if the for the relation link exists,false
otherwise.
-
getLink
Get the link for the relation.- Parameters:
relation
- link relation.- Returns:
- the link for the relation, otherwise
null
if not present.
-
getLinkBuilder
Convenience method that returns aLink.Builder
for the relation.- Parameters:
relation
- link relation.- Returns:
- the link builder for the relation, otherwise
null
if not present.
-
hasEntity
public boolean hasEntity()Check if there is an entity available in the message.The method returns
true
if the entity is present, returnsfalse
otherwise.- Returns:
true
if there is an entity present in the message,false
otherwise.
-
getEntity
Get the message entity Java instance.Returns
null
if the message does not contain an entity.- Returns:
- the message entity or
null
if message does not contain an entity body.
-
setEntity
Set a new message message entity.- Parameters:
entity
- entity object.- See Also:
-
setEntity
Set a new message message entity.- Parameters:
entity
- entity object.annotations
- annotations attached to the entity.- See Also:
-
setEntity
Set a new message message entity.- Parameters:
entity
- entity object.type
- declared entity class.annotations
- annotations attached to the entity.- See Also:
-
setEntity
Set a new message message entity.- Parameters:
entity
- entity object.annotations
- annotations attached to the entity.mediaType
- entity media type.- See Also:
-
setMediaType
Set the message content media type.- Parameters:
mediaType
- message content media type.
-
getEntityClass
Get the raw message entity type information.- Returns:
- raw message entity type information.
-
getEntityType
Get the message entity type information.- Returns:
- message entity type.
-
setEntityType
Set the message entity type information.This method overrides any computed or previously set entity type information.
- Parameters:
type
- overriding message entity type.
-
getEntityAnnotations
Get the annotations attached to the entity.- Returns:
- entity annotations.
-
setEntityAnnotations
Set the annotations attached to the entity.- Parameters:
annotations
- entity annotations.
-
getEntityStream
Get the entity output stream.- Returns:
- entity output stream.
-
setEntityStream
Set a new entity output stream.- Parameters:
outputStream
- new entity output stream.
-
enableBuffering
Enable a buffering of serialized entity. The buffering will be configured from configuration. The property determining the size of the buffer isCommonProperties.OUTBOUND_CONTENT_LENGTH_BUFFER
. The buffering functionality is by default disabled and could be enabled by calling this method. In this case this method must be called before first bytes are written to theentity stream
.- Parameters:
configuration
- runtime configuration.
-
setStreamProvider
Set a stream provider callback. This method must be called before first bytes are written to theentity stream
.- Parameters:
streamProvider
- non-null
output stream provider.
-
commitStream
Commits theentity stream
if it wasn't already committed.- Throws:
IOException
- in case of the IO error.
-
isCommitted
public boolean isCommitted()Returnstrue
if the entity stream has been committed.- Returns:
true
if the entity stream has been committed. Otherwise returnsfalse
.
-
close
public void close()Closes the context. Flushes and closes the entity stream. -
getConfiguration
The related client/server sideConfiguration
. Can benull
.- Returns:
Configuration
the configuration
-