modified pom and some classes
This commit is contained in:
@@ -2,13 +2,16 @@ package com.release11;
|
||||
|
||||
import com.mysql.cj.jdbc.MysqlDataSource;
|
||||
import org.apache.activemq.ActiveMQConnectionFactory;
|
||||
import org.apache.activemq.command.ActiveMQMapMessage;
|
||||
import org.apache.camel.*;
|
||||
import org.apache.camel.builder.RouteBuilder;
|
||||
import org.apache.camel.component.jms.JmsComponent;
|
||||
import org.apache.camel.impl.DefaultCamelContext;
|
||||
import org.apache.camel.support.SimpleRegistry;
|
||||
import org.apache.log4j.BasicConfigurator;
|
||||
import org.apache.camel.converter.jaxb.JaxbDataFormat;
|
||||
|
||||
import javax.xml.bind.*;
|
||||
|
||||
|
||||
public class Main {
|
||||
|
||||
@@ -27,6 +30,24 @@ public class Main {
|
||||
source.setPassword("admin");
|
||||
SimpleRegistry registry = new SimpleRegistry();
|
||||
registry.bind("source", MysqlDataSource.class, source);
|
||||
|
||||
|
||||
//jax.marshal(Exchange ,jax,);
|
||||
//registry.bind("jax", JaxbDataFormat.class, XMLDataFormat);
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
CamelContext context = new DefaultCamelContext(registry);
|
||||
BasicConfigurator.configure();
|
||||
ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://10.101.111.19:8088");
|
||||
@@ -34,16 +55,16 @@ public class Main {
|
||||
connectionFactory.setPassword("admin");
|
||||
context.addComponent("activemq", JmsComponent.jmsComponentAutoAcknowledge(connectionFactory));
|
||||
|
||||
DAO myFunctions = new DAO();
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
context.addRoutes(new RouteBuilder() {
|
||||
@Override
|
||||
public void configure() throws Exception {
|
||||
|
||||
JaxbDataFormat XMLDataFormat = new JaxbDataFormat();
|
||||
//XMLDataFormat.setSchemaLocation("/home/igor/Documents/Jacek/jacek-and-igor/src/main/resources/material.xsd");
|
||||
XMLDataFormat.setContextPath("generated");
|
||||
JAXBContext jaxbContext = JAXBContext.newInstance(generated.MaterialType.class);
|
||||
XMLDataFormat.setContext(jaxbContext);
|
||||
|
||||
from("direct:start")
|
||||
.setBody(constant("SELECT * FROM material"))
|
||||
.to("jdbc:source")
|
||||
@@ -56,16 +77,56 @@ public class Main {
|
||||
.to("jdbc:source?useHeadersAsParameters=true");
|
||||
|
||||
from("activemq:queue:material")
|
||||
.enrich("direct:getPackages",new MyAggregator())
|
||||
.enrich("direct:getPackages", new MyAggregator())
|
||||
.to("activemq:queue:materialPackage")
|
||||
.to("log:?level=INFO&showBody=true");
|
||||
|
||||
from("direct:test")
|
||||
.setBody(constant("SELECT * FROM material LIMIT 1"))
|
||||
.to("jdbc:source")
|
||||
.split(body())
|
||||
.to("activemq:queue:materialTest");
|
||||
|
||||
from("activemq:queue:materialTest")
|
||||
.marshal(XMLDataFormat)
|
||||
.to("activemq:queue:test");
|
||||
|
||||
|
||||
|
||||
from("direct:pretty")
|
||||
.setBody(constant("<?xml version='1.0'?>" +
|
||||
"<material>\n" +
|
||||
" <material_number>7</material_number>\n" +
|
||||
" <material_type>A1</material_type>\n" +
|
||||
" <material_name>LEGO 17272</material_name>\n" +
|
||||
" <description>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.</description>\n" +
|
||||
" <is_deleted>false</is_deleted>\n" +
|
||||
" <packages>\n" +
|
||||
" <package_number>11988</package_number>\n" +
|
||||
" <ean>80975098498590834</ean>\n" +
|
||||
" <unit_of_measure>pcs</unit_of_measure>\n" +
|
||||
" <dimension>17x17x17</dimension>\n" +
|
||||
" <description>Lorem ipsum dolor sit amet, consectetur adipiscing elit</description>\n" +
|
||||
" </packages>\n" +
|
||||
" <packages>\n" +
|
||||
" <package_number>118</package_number>\n" +
|
||||
" <ean>877854875843774</ean>\n" +
|
||||
" <unit_of_measure>pcs</unit_of_measure>\n" +
|
||||
" <dimension>20x20x20</dimension>\n" +
|
||||
" </packages>\n" +
|
||||
"</material>\n"))
|
||||
.unmarshal()
|
||||
.jaxb("generated")
|
||||
.to("activemq:queue:test")
|
||||
.to("log:?level=INFO&showBody=true");
|
||||
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
context.start();
|
||||
ProducerTemplate template = context.createProducerTemplate();
|
||||
template.sendBody("direct:start", null);
|
||||
template.sendBody("direct:pretty", null);
|
||||
Thread.sleep(1000);
|
||||
//template.setDefaultEndpointUri("activemq:queue:material");
|
||||
|
||||
|
||||
@@ -3,6 +3,8 @@
|
||||
|
||||
<xs:complexType name="package">
|
||||
<xs:sequence>
|
||||
<xs:element name="id" type="xs:int"/>
|
||||
<xs:element name="material_id" type="xs:int"/>
|
||||
<xs:element name="package_number" type="xs:int"/>
|
||||
<xs:element name="ean" type="xs:string"/>
|
||||
<xs:element name="unit_of_measure" type="xs:string"/>
|
||||
@@ -11,7 +13,7 @@
|
||||
</xs:sequence>
|
||||
</xs:complexType>
|
||||
|
||||
<xs:simpleType name="material_type" final="restriction">
|
||||
<xs:simpleType name="material_typeType" final="restriction">
|
||||
<xs:restriction base="xs:string">
|
||||
<xs:enumeration value="A1"/>
|
||||
<xs:enumeration value="A2"/>
|
||||
@@ -27,8 +29,9 @@
|
||||
|
||||
<xs:complexType name="materialType">
|
||||
<xs:sequence>
|
||||
<xs:element name="id" type="xs:int"/>
|
||||
<xs:element name="material_number" type="xs:int"/>
|
||||
<xs:element name="material_type" type="material_type"/>
|
||||
<xs:element name="material_type" type="material_typeType"/>
|
||||
<xs:element name="material_name" type="xs:string"/>
|
||||
<xs:element name="description" type="xs:string"/>
|
||||
<xs:element name="is_deleted" type="xs:boolean"/>
|
||||
|
||||
Reference in New Issue
Block a user