This repository has been archived by the owner on Nov 27, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 6
/
split.camel-component.yaml
142 lines (142 loc) · 9.66 KB
/
split.camel-component.yaml
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
apiVersion: camel.apache.org/v1alpha1
kind: EIP-BRANCH
metadata:
name: split
annotations:
camel.apache.org/kamelet.icon: ""
camel.apache.org/provider: "Kaoto Bridge"
camel.apache.org/kamelet.group: "Knative"
kaoto.io/minbranches: "1"
kaoto.io/maxbranches: "1"
labels:
camel.apache.org/kamelet.type: "action"
spec:
definition:
title: "Split"
description: "Use a Splitter to break out the composite message into a series of individual messages, each containing data related to one item."
properties:
expression:
title: Expression
description: "Expression of how to split the message body, such as as-is, using a tokenizer, or using a xpath."
type: object
example: '${body}'
simple:
title: "Simple Expression"
description: "Expression of how to split the message body, such as as-is, using a tokenizer, or using a xpath."
type: string
constant:
title: "Constant Expression"
description: "Expression of how to split the message body, such as as-is, using a tokenizer, or using a xpath."
type: string
jq:
title: "Jq Expression"
description: "Expression of how to split the message body, such as as-is, using a tokenizer, or using a xpath."
type: string
jsonpath:
title: "JSON Path Expression"
description: "Expression of how to split the message body, such as as-is, using a tokenizer, or using a xpath."
type: string
delimiter:
title: Delimiter
description: "Delimiter used in splitting messages. Can be turned off using the value false. The default value is ','."
type: string
aggregationStrategy:
title: Aggregation Strategy
description: "Sets a reference to the AggregationStrategy to be used to assemble the replies from the split messages, into a single outgoing message from the Splitter. By default Camel will use the original incoming message to the splitter (leave it unchanged). You can also use a POJO as the AggregationStrategy."
type: object
aggregationStrategyMethodName:
title: Aggregation Strategy Method Name
description: "This option can be used to explicit declare the method name to use, when using POJOs as the AggregationStrategy."
type: string
aggregationStrategyMethodAllowNull:
title: Aggregation Strategy Method Allow Null
description: "If this option is false then the aggregate method is not used if there was no data to enrich. If this option is true then null values is used as the oldExchange (when no data to enrich), when using POJOs as the AggregationStrategy."
type: boolean
parallelAggregate:
title: Parallel Aggregate
description: "If enabled then the aggregate method on AggregationStrategy can be called concurrently. Notice that this would require the implementation of AggregationStrategy to be implemented as thread-safe. By default this is false meaning that Camel synchronizes the call to the aggregate method. Though in some use-cases this can be used to archive higher performance when the AggregationStrategy is implemented as thread-safe."
type: boolean
parallelProcessing:
title: Parallel Processing
description: "If enabled then processing each split messages occurs concurrently. Note the caller thread will still wait until all messages has been fully processed, before it continues. It’s only processing the sub messages from the splitter which happens concurrently."
type: boolean
streaming:
title: Streaming
description: "When in streaming mode, then the splitter splits the original message on-demand, and each split message is processed one by one. This reduces memory usage as the splitter do not split all the messages first, but then we do not know the total size, and therefore the org.apache.camel.Exchange#SPLIT_SIZE is empty. In non-streaming mode (default) the splitter will split each message first, to know the total size, and then process each message one by one. This requires to keep all the split messages in memory and therefore requires more memory. The total size is provided in the org.apache.camel.Exchange#SPLIT_SIZE header. The streaming mode also affects the aggregation behavior. If enabled then Camel will process replies out-of-order, e.g. in the order they come back. If disabled, Camel will process replies in the same order as the messages was split."
type: boolean
stopOnException:
title: Stop On Exception
description: "Will now stop further processing if an exception or failure occurred during processing of an org.apache.camel.Exchange and the caused exception will be thrown. Will also stop if processing the exchange failed (has a fault message) or an exception was thrown and handled by the error handler (such as using onException). In all situations the splitter will stop further processing. This is the same behavior as in pipeline, which is used by the routing engine. The default behavior is to not stop but continue processing till the end."
type: boolean
timeout:
title: Timeout
description: "Sets a total timeout specified in millis, when using parallel processing. If the Splitter hasn’t been able to split and process all the sub messages within the given timeframe, then the timeout triggers and the Splitter breaks out and continues. Notice if you provide a TimeoutAwareAggregationStrategy then the timeout method is invoked before breaking out. If the timeout is reached with running tasks still remaining, certain tasks for which it is difficult for Camel to shut down in a graceful manner may continue to run. So use this option with a bit of care."
type: string
executorService:
title: Executor Service
description: "To use a custom Thread Pool to be used for parallel processing. Notice if you set this option, then parallel processing is automatically implied, and you do not have to enable that option as well."
type: object
onPrepare:
title: On Prepare
description: "Uses the Processor when preparing the org.apache.camel.Exchange to be sent. This can be used to deep-clone messages that should be sent, or any custom logic needed before the exchange is sent."
type: object
shareUnitOfWork:
title: Share Unit of Work
description: "Shares the org.apache.camel.spi.UnitOfWork with the parent and each of the sub messages. Splitter will by default not share unit of work between the parent exchange and each split exchange. This means each split exchange has its own individual unit of work."
type: boolean
description:
title: Description
description: "Sets the description of this node."
type: object
tokenize:
title: "Tokenize"
description: "Tokenize object."
type: object
token:
title: "Token"
description: "The (start) token to use as tokenizer, for example you can use the new line token. You can use simple language as the token to support dynamic tokens."
type: string
endToken:
title: "End Token"
description: "The end token to use as tokenizer if using start/end token pairs. You can use simple language as the token to support dynamic tokens."
type: string
inheritNamespaceTagName:
title: "Inherit Namespace Tag Name"
description: "To inherit namespaces from a root/parent tag name when using XML You can use simple language as the tag name to support dynamic names."
type: string
headerName:
title: "Header Name"
description: "Name of header to tokenize instead of using the message body."
type: string
regex:
title: "Regex"
description: "If the token is a regular expression pattern. The default value is false."
type: boolean
xml:
title: "XML"
description: "Whether the input is XML messages. This option must be set to true if working with XML payloads."
type: boolean
includeTokens:
title: "Include Tokens"
description: "The end token to use as tokenizer if using start/end token pairs. You can use simple language as the token to support dynamic tokens."
type: string
endToken:
title: "End Token"
description: "Whether to include the tokens in the parts when using pairs The default value is false."
type: string
group:
title: "Group"
description: "To group N parts together, for example to split big files into chunks of 1000 lines. You can use simple language as the group to support dynamic group sizes."
type: string
groupDelimiter:
title: "Group Delimiter"
description: "Sets the delimiter to use when grouping. If this has not been set then token will be used as the delimiter."
type: string
skipFirst:
title: "Skip First"
description: "To skip the very first element."
type: boolean
trim:
title: "Trim"
description: "Whether to trim the value to remove leading and trailing whitespaces and line breaks."
type: boolean