/*
* Copyright 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.dsl;
import java.util.Collection;
import java.util.Collections;
import java.util.LinkedList;
import java.util.List;
import org.springframework.integration.dsl.ComponentsRegistration;
import org.springframework.integration.dsl.MessageHandlerSpec;
import org.springframework.integration.jpa.core.JpaExecutor;
import org.springframework.integration.jpa.outbound.JpaOutboundGateway;
import org.springframework.integration.jpa.support.JpaParameter;
import org.springframework.integration.jpa.support.parametersource.ParameterSourceFactory;
/**
* The base {@link MessageHandlerSpec} for JPA Outbound endpoints.
*
* @param <S> the target {@link JpaBaseOutboundEndpointSpec} implementation type.
*
* @author Artem Bilan
*
* @since 5.0
*/
public abstract class JpaBaseOutboundEndpointSpec<S extends JpaBaseOutboundEndpointSpec<S>>
extends MessageHandlerSpec<S, JpaOutboundGateway>
implements ComponentsRegistration {
private final List<JpaParameter> jpaParameters = new LinkedList<>();
protected final JpaExecutor jpaExecutor; // NOSONAR
protected JpaBaseOutboundEndpointSpec(JpaExecutor jpaExecutor) {
this.jpaExecutor = jpaExecutor;
this.jpaExecutor.setJpaParameters(this.jpaParameters);
this.target = new JpaOutboundGateway(this.jpaExecutor);
}
/**
* Specify the class type which is being used for retrieving entities from the database.
* @param entityClass the entity {@link Class} to use
* @return the spec
*/
public S entityClass(Class<?> entityClass) {
this.jpaExecutor.setEntityClass(entityClass);
return _this();
}
/**
* Specify a JPA query to perform persistent operation.
* @param jpaQuery the JPA query to use.
* @return the spec
*/
public S jpaQuery(String jpaQuery) {
this.jpaExecutor.setJpaQuery(jpaQuery);
return _this();
}
/**
* Specify a native SQL query to perform persistent operation.
* @param nativeQuery the native SQL query to use.
* @return the spec
*/
public S nativeQuery(String nativeQuery) {
this.jpaExecutor.setNativeQuery(nativeQuery);
return _this();
}
/**
* Specify a name a named JPQL based query or a native SQL query.
* @param namedQuery the name of the pre-configured query.
* @return the spec
*/
public S namedQuery(String namedQuery) {
this.jpaExecutor.setNamedQuery(namedQuery);
return _this();
}
/**
* Specify a {@link ParameterSourceFactory} to populate query parameters at runtime against request message.
* @param parameterSourceFactory the {@link ParameterSourceFactory} to use.
* @return the spec
*/
public S parameterSourceFactory(ParameterSourceFactory parameterSourceFactory) {
this.jpaExecutor.setParameterSourceFactory(parameterSourceFactory);
return _this();
}
/**
* Add a value for indexed query parameter.
* @param value the value for query parameter by index
* @return the spec
*/
public S parameter(Object value) {
return parameter(new JpaParameter(value, null));
}
/**
* Add a value for named parameter in the query.
* @param name the name of the query parameter
* @param value the value for query parameter by name
* @return the spec
*/
public S parameter(String name, Object value) {
return parameter(new JpaParameter(name, value, null));
}
/**
* Add a SpEL expression for indexed parameter in the query.
* @param expression the SpEL expression for query parameter by index
* @return the spec
*/
public S parameterExpression(String expression) {
return parameter(new JpaParameter(null, expression));
}
/**
* Add a SpEL expression for named parameter in the query.
* @param name the name of the query parameter
* @param expression the SpEL expression for query parameter by name
* @return the spec
*/
public S parameterExpression(String name, String expression) {
return parameter(new JpaParameter(name, null, expression));
}
public S parameter(JpaParameter jpaParameter) {
this.jpaParameters.add(jpaParameter);
return _this();
}
/**
* Indicates that whether only the payload of the passed in {@code Message} will be
* used as a source of parameters. The is 'true' by default because as a default a
* {@link org.springframework.integration.jpa.support.parametersource.BeanPropertyParameterSourceFactory}
* implementation is used for the sqlParameterSourceFactory property.
* @param usePayloadAsParameterSource the {@code boolean} flag to indicate if use
* {@code payload} as a source of parameter values or not.
* @return the spec
*/
public S usePayloadAsParameterSource(Boolean usePayloadAsParameterSource) {
this.jpaExecutor.setUsePayloadAsParameterSource(usePayloadAsParameterSource);
return _this();
}
@Override
public Collection<Object> getComponentsToRegister() {
return Collections.singletonList(this.jpaExecutor);
}
}