/*
* Copyright 2002-2016 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.springframework.integration.jpa.inbound;
import org.springframework.integration.context.IntegrationObjectSupport;
import org.springframework.integration.core.MessageSource;
import org.springframework.integration.jpa.core.JpaExecutor;
import org.springframework.messaging.Message;
import org.springframework.util.Assert;
/**
* Polling message source that produces messages from the result of the provided:
*
* <ul>
* <li>entityClass</li>
* <li>JpQl Select Query</li>
* <li>Sql Native Query</li>
* <li>JpQl Named Query</li>
* <li>Sql Native Named Query</li>
* </ul>
*
* After the objects have been polled, it also possibly to either:
*
* executes an update after the select possibly to updated the state of selected records
*
* <ul>
* <li>executes an update (per retrieved object or for the entire payload)</li>
* <li>delete the retrieved object</li>
* </ul>
*
* @author Amol Nayak
* @author Gunnar Hillert
*
* @since 2.2
*
*/
public class JpaPollingChannelAdapter extends IntegrationObjectSupport implements MessageSource<Object> {
private final JpaExecutor jpaExecutor;
/**
* Constructor taking a {@link JpaExecutor} that provide all required JPA
* functionality.
*
* @param jpaExecutor Must not be null.
*/
public JpaPollingChannelAdapter(JpaExecutor jpaExecutor) {
super();
Assert.notNull(jpaExecutor, "jpaExecutor must not be null.");
this.jpaExecutor = jpaExecutor;
}
/**
* Check for mandatory attributes
*/
@Override
protected void onInit() throws Exception {
super.onInit();
this.jpaExecutor.setBeanFactory(this.getBeanFactory());
}
/**
* Uses {@link JpaExecutor#poll()} to executes the JPA operation.
*
* If {@link JpaExecutor#poll()} returns null, this method will return
* <code>null</code>. Otherwise, a new {@link Message} is constructed and returned.
*/
public Message<Object> receive() {
final Object payload = this.jpaExecutor.poll();
if (payload == null) {
return null;
}
return this.getMessageBuilderFactory().withPayload(payload).build();
}
@Override
public String getComponentType() {
return "jpa:inbound-channel-adapter";
}
}