Class BaseHttpInboundEndpoint
java.lang.Object
org.springframework.integration.context.IntegrationObjectSupport
org.springframework.integration.endpoint.AbstractEndpoint
org.springframework.integration.gateway.MessagingGatewaySupport
org.springframework.integration.http.inbound.BaseHttpInboundEndpoint
- All Implemented Interfaces:
- Aware,- BeanFactoryAware,- BeanNameAware,- DisposableBean,- InitializingBean,- ApplicationContextAware,- Lifecycle,- Phased,- SmartLifecycle,- ExpressionCapable,- OrderlyShutdownCapable,- IntegrationPattern,- NamedComponent,- IntegrationInboundManagement,- IntegrationManagement,- ManageableLifecycle,- ManageableSmartLifecycle,- TrackableComponent
- Direct Known Subclasses:
- HttpRequestHandlingEndpointSupport,- WebFluxInboundEndpoint
public class BaseHttpInboundEndpoint extends MessagingGatewaySupport implements OrderlyShutdownCapable
The 
MessagingGatewaySupport extension for HTTP Inbound endpoints
 with basic properties.- Since:
- 5.0
- Author:
- Artem Bilan, Gary Russell
- 
Nested Class SummaryNested classes/interfaces inherited from interface org.springframework.integration.support.management.IntegrationManagementIntegrationManagement.ManagementOverrides
- 
Field SummaryFields Modifier and Type Field Description protected AtomicIntegeractiveCountprotected static booleanJAXB_PRESENTprotected static List<HttpMethod>NON_READABLE_BODY_HTTP_METHODSprotected static booleanROME_TOOLS_PRESENTFields inherited from class org.springframework.integration.gateway.MessagingGatewaySupportmessagingTemplateFields inherited from class org.springframework.integration.endpoint.AbstractEndpointlifecycleCondition, lifecycleLockFields inherited from class org.springframework.integration.context.IntegrationObjectSupportEXPRESSION_PARSER, loggerFields inherited from interface org.springframework.integration.support.management.IntegrationManagementMETER_PREFIX, RECEIVE_COUNTER_NAME, SEND_TIMER_NAME
- 
Constructor SummaryConstructors Constructor Description BaseHttpInboundEndpoint(boolean expectReply)
- 
Method SummaryModifier and Type Method Description intafterShutdown()Called after normal shutdown of schedulers, executors etc, and after the shutdown delay has elapsed, but before any forced shutdown of any remaining active scheduler/executor threads.Can optionally return the number of active messages still in process.intbeforeShutdown()Called before shutdown begins.protected StandardEvaluationContextcreateEvaluationContext()protected HttpStatusevaluateHttpStatus(HttpEntity<?> httpEntity)StringgetComponentType()Subclasses may implement this method to provide component type information.CrossOrigingetCrossOrigin()protected booleangetExtractReplyPayload()protected Map<String,Expression>getHeaderExpressions()protected HeaderMapper<HttpHeaders>getHeaderMapper()IntegrationPatternTypegetIntegrationPatternType()Return a pattern type this component implements.protected ExpressiongetPayloadExpression()RequestMappinggetRequestMapping()protected ResolvableTypegetRequestPayloadType()protected ExpressiongetStatusCodeExpression()protected ValidatorgetValidator()protected booleanisExpectReply()protected static booleanisReadable(HttpMethod httpMethod)Checks if the request has a readable body (not a GET, HEAD, or OPTIONS request).protected voidonInit()Subclasses may implement this for initialization logic.protected HttpStatusresolveHttpStatusFromHeaders(MessageHeaders headers)voidsetCrossOrigin(CrossOrigin crossOrigin)Set theCrossOriginto permit cross origin requests for this endpoint.voidsetExtractReplyPayload(boolean extractReplyPayload)Specify whether only the reply Message's payload should be passed in the response.voidsetHeaderExpressions(Map<String,Expression> headerExpressions)Specifies a Map of SpEL expressions to evaluate in order to generate the Message headers.voidsetHeaderMapper(HeaderMapper<HttpHeaders> headerMapper)Set theHeaderMapperto use when mapping between HTTP headers and MessageHeaders.voidsetPayloadExpression(Expression payloadExpression)Specifies a SpEL expression to evaluate in order to generate the Message payload.voidsetRequestMapping(RequestMapping requestMapping)Set theRequestMappingwhich allows you to specify a flexible RESTFul-mapping for this endpoint.voidsetRequestPayloadType(ResolvableType requestPayloadType)Specify the type of payload to be generated when the inbound HTTP request content is read by the converters/encoders.voidsetRequestPayloadTypeClass(Class<?> requestPayloadType)Specify the type of payload to be generated when the inbound HTTP request content is read by the converters/encoders.voidsetStatusCodeExpression(Expression statusCodeExpression)Specify theExpressionto resolve a status code for Response to override the default '200 OK' or '500 Internal Server Error' for a timeout.voidsetStatusCodeExpressionString(String statusCodeExpression)Specify theExpressionto resolve a status code for Response to override the default '200 OK' or '500 Internal Server Error' for a timeout.voidsetValidator(Validator validator)Specify aValidatorto validate a converted payload from request.protected voidvalidate(Object value)Methods inherited from class org.springframework.integration.gateway.MessagingGatewaySupportbuildErrorMessage, buildSendTimer, destroy, doStart, doStop, getErrorChannel, getErrorMessageAttributes, getManagedName, getManagedType, getOverrides, getReplyChannel, getRequestChannel, isLoggingEnabled, receive, receive, receiveMessage, receiveMessage, registerMetricsCaptor, registerReplyMessageCorrelatorIfNecessary, send, sendAndReceive, sendAndReceiveMessage, sendAndReceiveMessageReactive, sendTimer, setErrorChannel, setErrorChannelName, setErrorMessageStrategy, setErrorOnTimeout, setLoggingEnabled, setManagedName, setManagedType, setReplyChannel, setReplyChannelName, setReplyMapper, setReplyTimeout, setRequestChannel, setRequestChannelName, setRequestMapper, setRequestTimeout, setShouldTrackMethods inherited from class org.springframework.integration.endpoint.AbstractEndpointdoStop, getPhase, getRole, isActive, isAutoStartup, isRunning, setAutoStartup, setPhase, setRole, start, stop, stopMethods inherited from class org.springframework.integration.context.IntegrationObjectSupportafterPropertiesSet, extractTypeIfPossible, generateId, getApplicationContext, getApplicationContextId, getBeanDescription, getBeanFactory, getBeanName, getChannelResolver, getComponentName, getConversionService, getExpression, getIntegrationProperties, getIntegrationProperty, getMessageBuilderFactory, getTaskScheduler, isInitialized, setApplicationContext, setBeanFactory, setBeanName, setChannelResolver, setComponentName, setConversionService, setMessageBuilderFactory, setPrimaryExpression, setTaskScheduler, toStringMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.springframework.integration.support.management.IntegrationManagementgetThisAsMethods inherited from interface org.springframework.integration.support.context.NamedComponentgetBeanName, getComponentName
- 
Field Details- 
JAXB_PRESENTprotected static final boolean JAXB_PRESENT
- 
ROME_TOOLS_PRESENTprotected static final boolean ROME_TOOLS_PRESENT
- 
NON_READABLE_BODY_HTTP_METHODS
- 
activeCount
 
- 
- 
Constructor Details- 
BaseHttpInboundEndpointpublic BaseHttpInboundEndpoint(boolean expectReply)
 
- 
- 
Method Details- 
setPayloadExpressionSpecifies a SpEL expression to evaluate in order to generate the Message payload. The EvaluationContext will be populated with an HttpEntity instance as the root object, and it may contain variables:- #pathVariables
- #requestParams
- #requestAttributes
- #requestHeaders
- #matrixVariables
- #cookies
 - Parameters:
- payloadExpression- The payload expression.
 
- 
setHeaderExpressionsSpecifies a Map of SpEL expressions to evaluate in order to generate the Message headers. The keys in the map will be used as the header names. When evaluating the expression, the EvaluationContext will be populated with an HttpEntity instance as the root object, and it may contain variables:- #pathVariables
- #requestParams
- #requestAttributes
- #requestHeaders
- #matrixVariables
- #cookies
 - Parameters:
- headerExpressions- The header expressions.
 
- 
setRequestMappingSet theRequestMappingwhich allows you to specify a flexible RESTFul-mapping for this endpoint.- Parameters:
- requestMapping- The request mapping.
 
- 
getRequestMapping
- 
setCrossOriginSet theCrossOriginto permit cross origin requests for this endpoint.- Parameters:
- crossOrigin- the CrossOrigin config.
- Since:
- 4.2
 
- 
getCrossOrigin
- 
getPayloadExpression
- 
getHeaderExpressions
- 
isExpectReplyprotected boolean isExpectReply()- Returns:
- Whether to expect a reply.
 
- 
setHeaderMapperSet theHeaderMapperto use when mapping between HTTP headers and MessageHeaders.- Parameters:
- headerMapper- The header mapper.
 
- 
getHeaderMapper
- 
setRequestPayloadTypeClassSpecify the type of payload to be generated when the inbound HTTP request content is read by the converters/encoders. By default this value is null which means at runtime any "text" Content-Type will result in String while all others default tobyte[].class.- Parameters:
- requestPayloadType- The payload type.
 
- 
setRequestPayloadTypeSpecify the type of payload to be generated when the inbound HTTP request content is read by the converters/encoders. By default this value is null which means at runtime any "text" Content-Type will result in String while all others default tobyte[].class.- Parameters:
- requestPayloadType- The payload type.
 
- 
getRequestPayloadType
- 
setExtractReplyPayloadpublic void setExtractReplyPayload(boolean extractReplyPayload)Specify whether only the reply Message's payload should be passed in the response. If this is set to 'false', the entire Message will be used to generate the response. The default is 'true'.- Parameters:
- extractReplyPayload- true to extract the reply payload.
 
- 
getExtractReplyPayloadprotected boolean getExtractReplyPayload()
- 
setStatusCodeExpressionStringSpecify theExpressionto resolve a status code for Response to override the default '200 OK' or '500 Internal Server Error' for a timeout.- Parameters:
- statusCodeExpression- The status code Expression.
- Since:
- 5.0
- See Also:
- setStatusCodeExpression(Expression)
 
- 
setStatusCodeExpressionSpecify theExpressionto resolve a status code for Response to override the default '200 OK' or '500 Internal Server Error' for a timeout.The statusCodeExpressionis applied only for the one-way<http:inbound-channel-adapter/>or when no reply (timeout) is received for a gateway. The<http:inbound-gateway/>(or wheneverexpectReplyis true) resolves anHttpStatusfrom theHttpHeaders.STATUS_CODEreplyMessageheader.- Parameters:
- statusCodeExpression- The status code Expression.
- Since:
- 4.1
- See Also:
- MessagingGatewaySupport.setReplyTimeout(long),- HttpRequestHandlingEndpointSupport(boolean)
 
- 
getStatusCodeExpression
- 
setValidatorSpecify aValidatorto validate a converted payload from request.- Parameters:
- validator- the- Validatorto use.
- Since:
- 5.2
 
- 
getValidator
- 
onInitprotected void onInit()Description copied from class:IntegrationObjectSupportSubclasses may implement this for initialization logic.- Overrides:
- onInitin class- MessagingGatewaySupport
 
- 
evaluateHttpStatus
- 
resolveHttpStatusFromHeaders
- 
createEvaluationContext
- 
beforeShutdownpublic int beforeShutdown()Description copied from interface:OrderlyShutdownCapableCalled before shutdown begins. Implementations should stop accepting new messages. Can optionally return the number of active messages in process.- Specified by:
- beforeShutdownin interface- OrderlyShutdownCapable
- Returns:
- The number of active messages if available.
 
- 
afterShutdownpublic int afterShutdown()Description copied from interface:OrderlyShutdownCapableCalled after normal shutdown of schedulers, executors etc, and after the shutdown delay has elapsed, but before any forced shutdown of any remaining active scheduler/executor threads.Can optionally return the number of active messages still in process.- Specified by:
- afterShutdownin interface- OrderlyShutdownCapable
- Returns:
- The number of active messages if available.
 
- 
getComponentTypeDescription copied from class:IntegrationObjectSupportSubclasses may implement this method to provide component type information.- Specified by:
- getComponentTypein interface- NamedComponent
- Overrides:
- getComponentTypein class- MessagingGatewaySupport
 
- 
getIntegrationPatternTypeDescription copied from interface:IntegrationPatternReturn a pattern type this component implements.- Specified by:
- getIntegrationPatternTypein interface- IntegrationPattern
- Overrides:
- getIntegrationPatternTypein class- MessagingGatewaySupport
- Returns:
- the IntegrationPatternTypethis component implements.
 
- 
validate
- 
isReadableChecks if the request has a readable body (not a GET, HEAD, or OPTIONS request).- Parameters:
- httpMethod- the HTTP method to check
- Returns:
- true or false if HTTP request can contain the body
 
 
-