com.infusers.core.search.util.SpecificationUtility Maven / Gradle / Ivy
package com.infusers.core.search.util;
import java.util.ArrayList;
import java.util.Date;
import org.hibernate.query.SemanticException;
import com.infusers.core.search.ISpecificationModel;
import com.infusers.core.search.SpecificationConfigElement;
import jakarta.persistence.criteria.CriteriaBuilder;
import jakarta.persistence.criteria.Expression;
import jakarta.persistence.criteria.Predicate;
import jakarta.persistence.criteria.Root;
public class SpecificationUtility {
public static String getSearchLikeString(final String searchString) {
final String likeSearchString;
if (!searchString.contains("%")) {
likeSearchString = "%"+searchString.toLowerCase()+"%";
}
else {
likeSearchString = searchString.toLowerCase();
}
return likeSearchString;
}
public static Predicate createPredicate(Root root, CriteriaBuilder criteriaBuilder,
SpecificationConfigElement element, final String searchString, final String likeSearchString)
{
if(element==null) {
return null;
}
if(element.getSourceDataType() == String.class) {
return createPredicateString(root, criteriaBuilder, element.getFieldName(), searchString, likeSearchString);
}
else if(element.getSourceDataType() == Boolean.class) {
return createPredicateBoolean(root, criteriaBuilder, element.getFieldName(), searchString, likeSearchString);
}
else if(element.getSourceDataType() == Date.class) {
return createPredicateDate(root, criteriaBuilder, element.getFieldName(), searchString, likeSearchString);
}
else if(element.getSourceDataType() == Long.class) {
return createPredicateLong(root, criteriaBuilder, element.getFieldName(), searchString, likeSearchString);
}
return null;
}
public static Predicate createPredicateBoolean(Root root, CriteriaBuilder criteriaBuilder,
final String fieldName, final String searchString, final String likeSearchString)
{
if(searchString!=null && !searchString.isEmpty()) {
try {
boolean searchBoolean = Boolean.getBoolean(searchString);
return criteriaBuilder.equal(root.get(fieldName), searchBoolean);
}
catch(Exception e) {
//
}
}
return null;
}
public static Predicate createPredicateDate(Root root, CriteriaBuilder criteriaBuilder,
final String fieldName, final String searchString, final String likeSearchString)
{
if(searchString!=null && !searchString.isEmpty()) {
Expression dateStringExpr = criteriaBuilder.function("TO_CHAR", String.class, root.get("createdAt"), criteriaBuilder.literal("YYYY-MM-DD HH:MI:SS"));
return criteriaBuilder.like(dateStringExpr, likeSearchString);
}
return null;
}
public static Predicate createPredicateString(Root root, CriteriaBuilder criteriaBuilder,
final String fieldName, final String searchString, final String likeSearchString)
{
try {
if (searchString != null && !searchString.isEmpty()) {
return criteriaBuilder.like(criteriaBuilder.lower(root.get(fieldName)), likeSearchString);
}
}
catch(SemanticException e) {
System.out.println("SpecificationUtility.createPredicateString()--> exception : "+e.getMessage());
}
return null;
}
public static Predicate createPredicateLong(Root root, CriteriaBuilder criteriaBuilder,
final String fieldName, final String searchString, final String likeSearchString)
{
Long searchLong = 0L;
try {
searchLong = Long.parseLong(searchString);
}
catch(Exception e) {
//
}
if(searchLong!=null && searchLong.intValue()!=0) {
return criteriaBuilder.like(root.get(fieldName).as(String.class), likeSearchString);
}
return null;
}
public static Predicate joinPredicateMultipleOr(CriteriaBuilder criteriaBuilder, ArrayList predicateListOr) {
Predicate predicateSearch = null;
int count = predicateListOr!=null ? predicateListOr.size() : 0;
for(int i=0;i
© 2015 - 2025 Weber Informatics LLC | Privacy Policy