Storage
This module handles storage of IM objects into a repository.
Properties
Property | Default Value | Description |
---|---|---|
| true | If set to |
| Unix: /var/pricefx/integration Windows, macOS: user home dir | Directory where the files are stored. |
| fs | Selects the type of storage:
Storage choice is independent from the application logic. |
Storage Implementation
There are multiple storage options driven by the property integration.configuration.type
. When the application starts, all objects are loaded from the repository.
The following object types can be stored:
Type | Path/Key | Description |
---|---|---|
Filters | filters | Filters definitions. |
Routes | routes | Routes definitions. One route per file. |
Mappers | mappers | Mappers definitions. |
Connections | connections | Connections definitions. |
Properties | config | application.properties with properties. It is marked as a property source for Spring. |
Certificates | certs | Certificates definitions. |
Classes | classes | Custom classes subjected to rules. Currently supported Groovy classes. |
FileSystem storage
This storage implementation will store the objects in the file system into a directory specified by the property integration.configuration.base-directory
.
S3 storage
This storage implementation will store the objects into AWS S3 buckets. By default, it will put each object type into their own bucket. For the S3 storage to work properly, you need to set the property integration.aws.enabled=true
and the credentials – for details see How to Connect to AWS in IM.
The implementation assumes it has access to the file system temporary folder.
NoOp storage
This storage will not store objects into any repository (objects will be kept in memory only). This implementation will only kick in when integration.configuration.enabled=false
.
Groovy Classes
Note that this functionality is in an early development stage and might contain serious bugs.
If standardized Groovy scripts are not sufficient for your use case, you can load classes dynamically. IM will compile the class, link it via the class loader, store it as a Spring bean (singleton) and provide it to Camel.
If some of the classes fail to find/compile/validate/bind, the class will be skipped and an error will be logged.
Limitations
You must provide uncompiled .groovy classes.
Classes cannot use dependencies outside of the IM scope. This is due to the fact that the class is dynamically compiled with IM classpath.
Approach is tested for Camel routes and Spring beans.
You must implement one of the interfaces:
org.apache.camel.Processor
org.apache.camel.AggregationStrategy
net.pricefx.integration.csv.schema.validators.Validator
If all requirements are met, this is the log output for successful loading of a class:
10:31:20.596 [pool-1-thread-1] INFO n.p.i.c.task.LoadClassObjectsTask - Class loading task started. Going to load 1 classes: [/tmp/junit17404521069772355861/junit738258571191905368/MyGroovyProcessor.groovy]
10:31:21.013 [pool-1-thread-1] INFO o.a.s.c.u.s.b.BouncyCastleSecurityProviderRegistrar - getOrCreateProvider(BC) created instance of org.bouncycastle.jce.provider.BouncyCastleProvider
10:31:21.991 [main] INFO n.p.integration.util.SpringUtils - New bean registered: [myJavaProcessor] with definition: Generic bean: class [MyGroovyProcessor]; scope=; abstract=false; lazyInit=null; autowireMode=0; dependencyCheck=0; autowireCandidate=true; primary=false; factoryBeanName=null; factoryMethodName=null; initMethodName=null; destroyMethodName=null
10:31:21.995 [main] INFO n.p.i.configuration.BeanLoader - All [1] classes were loaded. Loaded classes: [/tmp/junit17404521069772355861/junit738258571191905368/MyGroovyProcessor.groovy]
10:31:21.996 [main] INFO n.p.i.configuration.BeanLoader - Done loading 1 classes with 0 errors.
Example
Let’s have one Groovy class.
Groovy [MyGroovyProcessor.groovy]:
import org.apache.camel.Exchange
import org.apache.camel.Processor
class MyGroovyProcessor implements Processor {
@Override
void process(Exchange exchange) throws Exception {
println "Groovy executed!"
}
}
Directory content:
mst@michal-desktop:/var/pricefx/integration/integration-manager/classes$ ll
total 16
drwxrwxr-x 2 mst mst 4096 Jun 4 14:13 ./
drwxrwxr-x 9 mst mst 4096 Jun 2 10:43 ../
-rw-rw-r-- 1 mst mst 327 Jun 4 14:08 MyGroovyProcessor.groovy
Route:
When the app starts, these are the relevant parts of the logs:
Route execution output:
IntegrationManager version 5.8.0