awips2/edexOsgi/com.raytheon.uf.edex.plugin.text/res/spring/text-ingest.xml
2022-05-05 12:34:50 -05:00

156 lines
6.2 KiB
XML

<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://camel.apache.org/schema/spring
http://camel.apache.org/schema/spring/camel-spring.xsd">
<bean class="com.raytheon.uf.common.logback.appender.ThreadBasedAppender" factory-method="registerThreadPattern">
<constructor-arg value="text" />
<constructor-arg value="Ingest.Text.*" />
</bean>
<bean id="textDecoder" class="com.raytheon.uf.edex.plugin.text.TextDecoder">
<property name="pluginName" value="text" />
<property name="decoderMode" value="STD" />
</bean>
<bean id="textDistRegistry" factory-bean="distributionSrv"
factory-method="register">
<constructor-arg value="text" />
<constructor-arg value="jms-durable:queue:Ingest.Text"/>
</bean>
<bean id="textHandleoupDistRegistry" factory-bean="handleoupDistributionSrv"
factory-method="register">
<constructor-arg value="text" />
<constructor-arg value="jms-durable:queue:Ingest.Text"/>
</bean>
<!-- verify text product info for site, spawns in separate thread to not delay start up -->
<bean id="textVersionPurge" class="com.raytheon.uf.edex.plugin.text.TextVersionPurge" depends-on="textRegistered"/>
<bean id="fxaBloatMonitor" class="com.raytheon.uf.edex.database.health.DatabaseBloatMonitor">
<constructor-arg>
<bean class="com.raytheon.uf.edex.database.health.PostgresBloatDao">
<constructor-arg value="fxa"/>
</bean>
</constructor-arg>
</bean>
<bean factory-bean="dbMonitorRegistry" factory-method="registerMonitor">
<constructor-arg value="fxaBloatMonitor" />
<constructor-arg ref="fxaBloatMonitor" />
</bean>
<camelContext id="text-camel"
xmlns="http://camel.apache.org/schema/spring"
errorHandlerRef="errorHandler">
<!--
Text routes.
If an internal route (see ContextManager.INTERNAL_ENDPOINT_TYPES) is being sent data from another internal
route in the same context it needs to come after the route that sends it data for proper startup/shutdown order.
-->
<route id="textUndecodedIngestRoute">
<from uri="jms-durable:queue:Ingest.Text?concurrentConsumers=2" />
<setHeader name="pluginName">
<constant>text</constant>
</setHeader>
<doTry>
<pipeline>
<bean ref="stringToFile" />
<bean ref="textDecoder" method="decodeFile" />
<bean ref="processUtil" method="log"/>
<multicast>
<to uri="direct:textSerializeRoute" />
<to uri="direct-vm:stageNotification"/>
</multicast>
</pipeline>
<doCatch>
<exception>java.lang.Throwable</exception>
<to uri="log:text?level=INFO"/>
</doCatch>
</doTry>
</route>
<route id="textDirectDecodedIngestRoute">
<from uri="direct-vm:textDirectDecodedIngestRoute" />
<setHeader name="pluginName">
<constant>text</constant>
</setHeader>
<doTry>
<pipeline>
<bean ref="textDecoder" method="writeTextProduct" />
<bean ref="processUtil" method="log"/>
<multicast>
<to uri="direct:textSerializeRoute" />
<to uri="direct-vm:stageNotification"/>
</multicast>
</pipeline>
<doCatch>
<exception>java.lang.Throwable</exception>
<to uri="log:text?level=INFO"/>
</doCatch>
</doTry>
</route>
<route id="textDirectUndecodedIngestRoute">
<from uri="direct-vm:textDirectUndecodedIngestRoute" />
<setHeader name="pluginName">
<constant>text</constant>
</setHeader>
<doTry>
<pipeline>
<bean ref="textDecoder" method="decode" />
<bean ref="processUtil" method="log"/>
<multicast>
<to uri="direct:textSerializeRoute" />
<to uri="direct-vm:stageNotification"/>
</multicast>
</pipeline>
<doCatch>
<exception>java.lang.Throwable</exception>
<to uri="log:text?level=INFO"/>
</doCatch>
</doTry>
</route>
<route id="textSerializationRoute">
<from uri="direct:textSerializeRoute" />
<split streaming="true" >
<method ref="textDecoder" method="separator" />
<bean ref="textDecoder" method="transformToSimpleString" />
<bean ref="serializationUtil" method="transformToThrift"/>
<to uri="jms-generic:topic:edex.alarms.msg?timeToLive=60000" />
</split>
</route>
<route id="textToStageNotificationRoute">
<from uri="jms-durable:queue:textToStageNotification" />
<bean ref="textDecoder" method="transformStringToTextRecord" />
<to uri="direct-vm:stageNotification"/>
</route>
</camelContext>
<camelContext id="clustered-text-camel"
xmlns="http://camel.apache.org/schema/spring"
errorHandlerRef="errorHandler">
<!-- TextPurge route -->
<route id="textPurgeRoute">
<from uri="timer://textPurge?period=60s" />
<doTry>
<bean ref="textVersionPurge" method="purgeAfosIds"/>
<doCatch>
<exception>java.lang.Throwable</exception>
<to uri="log:purge?level=ERROR"/>
</doCatch>
</doTry>
</route>
</camelContext>
<bean factory-bean="contextManager" factory-method="registerClusteredContext">
<constructor-arg ref="clustered-text-camel" />
</bean>
</beans>