Package ca.uhn.fhir.rest.api.server
Class SystemRequestDetails
java.lang.Object
ca.uhn.fhir.rest.api.server.RequestDetails
ca.uhn.fhir.rest.api.server.SystemRequestDetails
A default RequestDetails implementation that can be used for system calls to
Resource DAO methods when partitioning is enabled. Using a SystemRequestDetails
instance for system calls will ensure that any resource queries or updates will
use the DEFAULT partition when partitioning is enabled.
-
Field Summary
Fields inherited from class ca.uhn.fhir.rest.api.server.RequestDetails
BAD_STREAM_PLACEHOLDER
-
Constructor Summary
ConstructorDescriptionSystemRequestDetails
(ca.uhn.fhir.interceptor.api.IInterceptorBroadcaster theInterceptorBroadcaster) SystemRequestDetails
(RequestDetails theDetails) -
Method Summary
Modifier and TypeMethodDescriptionvoid
Adds a new headerstatic SystemRequestDetails
static SystemRequestDetails
forRequestPartitionId
(ca.uhn.fhir.interceptor.model.RequestPartitionId thePartitionId) getAttribute
(String theAttributeName) Returns the attribute map for this request.protected byte[]
Return the charset as defined by the header contenttype.ca.uhn.fhir.context.FhirContext
Returns the HAPI FHIR Context associated with this requestgetHeaders
(String name) Retrieves the body of the request as binary data.Retrieves the body of the request as character data using aBufferedReader
.ca.uhn.fhir.interceptor.model.RequestPartitionId
Returns the server base URL (with no trailing '/') for a given requeststatic SystemRequestDetails
void
setAttribute
(String theAttributeName, Object theAttributeValue) Returns the attribute map for this request.void
setFhirContext
(ca.uhn.fhir.context.FhirContext theFhirContext) void
setHeaders
(String theName, List<String> theValues) Replaces any existing header(s) with the given name using a List of new header valuessetRequestPartitionId
(ca.uhn.fhir.interceptor.model.RequestPartitionId theRequestPartitionId) void
setServer
(RestfulServer theServer) Methods inherited from class ca.uhn.fhir.rest.api.server.RequestDetails
addParameter, getCompartmentName, getCompleteUrl, getConditionalUrl, getFhirServerBase, getFixedConditionalUrl, getId, getInterceptorBroadcaster, getMaxRetries, getOperation, getParameters, getRequestContentsIfLoaded, getRequestId, getRequestPath, getRequestStopwatch, getRequestType, getResource, getResourceName, getResponse, getRestOperationType, getSecondaryOperation, getTenantId, getTransactionGuid, getUnqualifiedToQualifiedNames, getUserData, isPreferAsync, isRespondGzip, isRetry, isRewriteHistory, isSubRequest, loadRequestContents, removeParameter, setCompartmentName, setCompleteUrl, setFhirServerBase, setFixedConditionalUrl, setId, setMaxRetries, setOperation, setParameters, setRequestContents, setRequestId, setRequestPath, setRequestType, setResource, setResourceName, setRespondGzip, setResponse, setRestOperationType, setRetry, setRewriteHistory, setSecondaryOperation, setSubRequest, setTenantId, setTransactionGuid
-
Constructor Details
-
SystemRequestDetails
public SystemRequestDetails() -
SystemRequestDetails
public SystemRequestDetails(ca.uhn.fhir.interceptor.api.IInterceptorBroadcaster theInterceptorBroadcaster) -
SystemRequestDetails
-
-
Method Details
-
forRequestPartitionId
public static SystemRequestDetails forRequestPartitionId(ca.uhn.fhir.interceptor.model.RequestPartitionId thePartitionId) -
getRequestPartitionId
-
setRequestPartitionId
public SystemRequestDetails setRequestPartitionId(ca.uhn.fhir.interceptor.model.RequestPartitionId theRequestPartitionId) -
getByteStreamRequestContents
- Specified by:
getByteStreamRequestContents
in classRequestDetails
-
getCharset
Description copied from class:RequestDetails
Return the charset as defined by the header contenttype. Return null if it is not set.- Specified by:
getCharset
in classRequestDetails
-
getFhirContext
Description copied from class:RequestDetails
Returns the HAPI FHIR Context associated with this request- Specified by:
getFhirContext
in classRequestDetails
-
setFhirContext
-
getHeader
- Specified by:
getHeader
in classRequestDetails
-
getHeaders
- Specified by:
getHeaders
in classRequestDetails
-
addHeader
Description copied from class:RequestDetails
Adds a new header- Specified by:
addHeader
in classRequestDetails
- Parameters:
theName
- The header nametheValue
- The header value
-
setHeaders
Description copied from class:RequestDetails
Replaces any existing header(s) with the given name using a List of new header values- Specified by:
setHeaders
in classRequestDetails
- Parameters:
theName
- The header nametheValues
- The header value
-
getAttribute
Description copied from class:RequestDetails
Returns the attribute map for this request. Attributes are a place for user-supplied objects of any type to be attached to an individual request. They can be used to pass information between interceptor methods.- Specified by:
getAttribute
in classRequestDetails
-
setAttribute
Description copied from class:RequestDetails
Returns the attribute map for this request. Attributes are a place for user-supplied objects of any type to be attached to an individual request. They can be used to pass information between interceptor methods.- Specified by:
setAttribute
in classRequestDetails
-
getInputStream
Description copied from class:RequestDetails
Retrieves the body of the request as binary data. Either this method orRequestDetails.getReader()
may be called to read the body, not both.- Specified by:
getInputStream
in classRequestDetails
- Returns:
- a
InputStream
object containing the body of the request - Throws:
IOException
- if an input or output exception occurred
-
getReader
Description copied from class:RequestDetails
Retrieves the body of the request as character data using aBufferedReader
. The reader translates the character data according to the character encoding used on the body. Either this method orRequestDetails.getInputStream()
may be called to read the body, not both.- Specified by:
getReader
in classRequestDetails
- Returns:
- a
Reader
containing the body of the request - See Also:
-
getServer
- Specified by:
getServer
in classRequestDetails
-
setServer
-
getServerBaseForRequest
Description copied from class:RequestDetails
Returns the server base URL (with no trailing '/') for a given request- Specified by:
getServerBaseForRequest
in classRequestDetails
-
forAllPartitions
-
newSystemRequestAllPartitions
-