-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtransactions.groovy
More file actions
81 lines (69 loc) · 2.81 KB
/
transactions.groovy
File metadata and controls
81 lines (69 loc) · 2.81 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
@GrabConfig(systemClassLoader=true)
@Grapes([
@Grab(group='org.apache.camel', module='camel-core', version='4.8.1'),
@Grab(group='org.apache.camel', module='camel-jdbc', version='4.8.1'),
@Grab(group='org.apache.camel', module='camel-file', version='4.8.1'),
@Grab(group='org.apache.camel', module='camel-spring', version='4.8.1'),
@Grab(group='org.springframework', module='spring-jdbc', version='5.3.39'),
@Grab(group='org.xerial', module='sqlite-jdbc', version='3.47.1.0'),
@Grab(group='org.apache.commons', module='commons-dbcp2', version='2.13.0'),
@Grab(group='ch.qos.logback', module='logback-classic', version='1.5.12')
])
import org.apache.camel.CamelContext
import org.apache.camel.impl.DefaultCamelContext
import org.apache.camel.builder.RouteBuilder
import org.apache.commons.dbcp2.BasicDataSource
import org.springframework.transaction.PlatformTransactionManager
import org.springframework.jdbc.datasource.DataSourceTransactionManager
import org.apache.camel.spring.spi.SpringTransactionPolicy
def dbUrl = "jdbc:sqlite:transactions.db"
def dbDriver = "org.sqlite.JDBC"
def dataSource = new BasicDataSource(driverClassName: dbDriver, url: dbUrl)
CamelContext camelContext = new DefaultCamelContext()
camelContext.registry.bind("transactions_db", dataSource)
// @Autowired
// TransactionManager transactionManager
PlatformTransactionManager transactionManager = new DataSourceTransactionManager(dataSource)
camelContext.registry.bind("transactionManager", transactionManager)
def transactionPolicy = new SpringTransactionPolicy(transactionManager: transactionManager)
camelContext.registry.bind("PROPAGATION_REQUIRED", transactionPolicy)
def createTable = """
create table if not exists transactions (
id integer primary key autoincrement,
description text,
status text
);
"""
dataSource.connection.prepareStatement(createTable).execute()
camelContext.addRoutes(new RouteBuilder() {
@Override
void configure() {
onException(Exception)
.maximumRedeliveries(3)
.redeliveryDelay(2000)
.handled(true)
.to("log:error")
.to("file://errors")
from("file://input?noop=true")
.log('Procesando archivo: ${headers}')
.transacted("PROPAGATION_REQUIRED")
.process { exchange ->
def body = exchange.in.getBody(String)
if(body.contains("FAIL"))
throw new RuntimeException("ERROR SIMULADO")
}
.process { exchange ->
def body = exchange.in.getBody(String)
def sql = "INSERT INTO transactions(description, status) VALUES ('${body}', 'SUCCESS')"
exchange.in.setBody(sql)
}
.to('file://insertions?fileName=data-${date:now:dd-MM-yyyyHH:mm:ss}.txt')
//.to("jms:queue:insertions")
.to("jdbc:transactions_db")
}
})
camelContext.start()
addShutdownHook {
camelContext.stop()
}
synchronized(this) { this.wait() }