/** * Set the applySequence flag to the specified value. Defaults to {@code true}. * @param applySequence the applySequence. * @return the endpoint spec. * @see AbstractMessageSplitter#setApplySequence(boolean) */ public SplitterEndpointSpec<S> applySequence(boolean applySequence) { this.handler.setApplySequence(applySequence); return _this(); }
@Override @SuppressWarnings("unchecked") protected final Object handleRequestMessage(Message<?> message) { Object result = this.splitMessage(message); boolean reactive = getOutputChannel() instanceof ReactiveStreamsSubscribableChannel; setAsync(reactive); sequenceSize = obtainSizeIfPossible(iterable); if (reactive) { flux = Flux.fromIterable(iterable); sequenceSize = obtainSizeIfPossible(iter); if (reactive) { flux = Flux.fromIterable(() -> iter); if (willAddHeaders(message)) { messageHeaders = new HashMap<>(messageHeaders); addHeaders(message, messageHeaders); object -> createBuilder(object, headers, correlationId, sequenceNumber.getAndIncrement(), sequenceSize);
private AbstractIntegrationMessageBuilder<?> createBuilder(Object item, Map<String, Object> headers, Object correlationId, int sequenceNumber, int sequenceSize) { AbstractIntegrationMessageBuilder<?> builder; if (item instanceof Message) { builder = getMessageBuilderFactory().fromMessage((Message<?>) item); } else if (item instanceof AbstractIntegrationMessageBuilder) { builder = (AbstractIntegrationMessageBuilder<?>) item; } else { builder = getMessageBuilderFactory().withPayload(item); } builder.copyHeadersIfAbsent(headers); if (this.applySequence) { builder.pushSequenceDetails(correlationId, sequenceNumber, sequenceSize); } return builder; }
@Override protected AbstractMessageSplitter createHandler() { AbstractMessageSplitter splitterHandler; Expression expression = properties.getExpression(); if (expression != null) { splitterHandler = new ExpressionEvaluatingSplitter(expression); } else { String charset = properties.getCharset(); Boolean markers = properties.getFileMarkers(); if(markers != null || charset != null) { if (markers == null) { markers = false; } FileSplitter splitter = new FileSplitter(true, markers, properties.getMarkersJson()); if (charset != null) { splitter.setCharset(Charset.forName(charset)); } splitterHandler = splitter; } else { DefaultMessageSplitter splitter = new DefaultMessageSplitter(); splitter.setDelimiters(properties.getDelimiters()); splitterHandler = splitter; } } splitterHandler.setOutputChannel(channels.output()); splitterHandler.setApplySequence(properties.isApplySequence()); return splitterHandler; }
@Override protected final void handleRequestMessage(Message<?> message, ReplyMessageHolder replyHolder) { Object result = this.splitMessage(message); if (result == null) { return; } Object correlationId = (message.getHeaders().getCorrelationId() != null) ? message.getHeaders().getCorrelationId(): message.getHeaders().getId(); if (result instanceof Collection) { Collection<?> items = (Collection<?>) result; int sequenceNumber = 0; int sequenceSize = items.size(); for (Object item : items) { this.addReply(replyHolder, item, correlationId, ++sequenceNumber, sequenceSize); } } else if (result.getClass().isArray()) { Object[] items = (Object[]) result; int sequenceNumber = 0; int sequenceSize = items.length; for (Object item : items) { this.addReply(replyHolder, item, correlationId, ++sequenceNumber, sequenceSize); } } else { this.addReply(replyHolder, result, correlationId, 1, 1); } }
@Override @SuppressWarnings("unchecked") protected final Object handleRequestMessage(Message<?> message) { Object result = this.splitMessage(message); boolean reactive = getOutputChannel() instanceof ReactiveStreamsSubscribableChannel; setAsync(reactive); sequenceSize = obtainSizeIfPossible(iterable); if (reactive) { flux = Flux.fromIterable(iterable); sequenceSize = obtainSizeIfPossible(iter); if (reactive) { flux = Flux.fromIterable(() -> iter); if (willAddHeaders(message)) { messageHeaders = new HashMap<>(messageHeaders); addHeaders(message, messageHeaders); object -> createBuilder(object, headers, correlationId, sequenceNumber.getAndIncrement(), sequenceSize);
@Override protected void postProcessReplyProducer(AbstractMessageProducingHandler handler) { super.postProcessReplyProducer(handler); if (!(handler instanceof AbstractMessageSplitter)) { Assert.isNull(this.applySequence, "Cannot set applySequence if the referenced bean is " + "an AbstractReplyProducingMessageHandler, but not an AbstractMessageSplitter"); Assert.isNull(this.delimiters, "Cannot set delimiters if the referenced bean is not an " + "an AbstractReplyProducingMessageHandler, but not an AbstractMessageSplitter"); } else { AbstractMessageSplitter splitter = (AbstractMessageSplitter) handler; if (this.delimiters != null) { Assert.isInstanceOf(DefaultMessageSplitter.class, splitter, "The 'delimiters' property is only available for a Splitter definition where no 'ref', " + "'expression', or inner bean has been provided."); ((DefaultMessageSplitter) splitter).setDelimiters(this.delimiters); } if (this.applySequence != null) { splitter.setApplySequence(this.applySequence); } } }
private AbstractIntegrationMessageBuilder<?> createBuilder(Object item, Map<String, Object> headers, Object correlationId, int sequenceNumber, int sequenceSize) { AbstractIntegrationMessageBuilder<?> builder; if (item instanceof Message) { builder = getMessageBuilderFactory().fromMessage((Message<?>) item); } else if (item instanceof AbstractIntegrationMessageBuilder) { builder = (AbstractIntegrationMessageBuilder<?>) item; } else { builder = getMessageBuilderFactory().withPayload(item); } builder.copyHeadersIfAbsent(headers); if (this.applySequence) { builder.pushSequenceDetails(correlationId, sequenceNumber, sequenceSize); } return builder; }
String applySequenceValue = this.beanFactory.resolveEmbeddedValue(applySequence); if (StringUtils.hasText(applySequenceValue)) { splitter.setApplySequence(Boolean.parseBoolean(applySequenceValue));
/** * Set the applySequence flag to the specified value. Defaults to {@code true}. * @param applySequence the applySequence. * @return the endpoint spec. * @see AbstractMessageSplitter#setApplySequence(boolean) */ public SplitterEndpointSpec<S> applySequence(boolean applySequence) { this.handler.setApplySequence(applySequence); return _this(); }
/** * Set the applySequence flag to the specified value. Defaults to {@code true}. * @param applySequence the applySequence. * @return the endpoint spec. * @see AbstractMessageSplitter#setApplySequence(boolean) */ public SplitterEndpointSpec<S> applySequence(boolean applySequence) { this.handler.setApplySequence(applySequence); return _this(); }
/** * Set the applySequence flag to the specified value. Defaults to {@code true}. * @param applySequence the applySequence. * @return the endpoint spec. * @see AbstractMessageSplitter#setApplySequence(boolean) */ public SplitterEndpointSpec<S> applySequence(boolean applySequence) { this.handler.setApplySequence(applySequence); return _this(); }
@Override protected void postProcessReplyProducer(AbstractMessageProducingHandler handler) { super.postProcessReplyProducer(handler); if (!(handler instanceof AbstractMessageSplitter)) { Assert.isNull(this.applySequence, "Cannot set applySequence if the referenced bean is " + "an AbstractReplyProducingMessageHandler, but not an AbstractMessageSplitter"); Assert.isNull(this.delimiters, "Cannot set delimiters if the referenced bean is not an " + "an AbstractReplyProducingMessageHandler, but not an AbstractMessageSplitter"); } else { AbstractMessageSplitter splitter = (AbstractMessageSplitter) handler; if (this.delimiters != null) { Assert.isInstanceOf(DefaultMessageSplitter.class, splitter, "The 'delimiters' property is only available for a Splitter definition where no 'ref', " + "'expression', or inner bean has been provided."); ((DefaultMessageSplitter) splitter).setDelimiters(this.delimiters); } if (this.applySequence != null) { splitter.setApplySequence(this.applySequence); } } }
String applySequenceValue = this.beanFactory.resolveEmbeddedValue(applySequence); if (StringUtils.hasText(applySequenceValue)) { splitter.setApplySequence(Boolean.parseBoolean(applySequenceValue));