All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.kaczmarzyk.spring.data.jpa.domain.ComparableSpecification Maven / Gradle / Ivy

Go to download

An alternative API for filtering data with Spring MVC and Spring Data JPA. This library provides a custom HandlerMethodArgumentResolver that transforms HTTP parameters into a Specification object ready to use with Spring Data repositories.

There is a newer version: 3.1.0
Show newest version
/**
 * Copyright 2014-2022 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 net.kaczmarzyk.spring.data.jpa.domain;

import net.kaczmarzyk.spring.data.jpa.utils.Converter;
import net.kaczmarzyk.spring.data.jpa.utils.QueryContext;

import javax.persistence.criteria.*;
import java.util.Arrays;
import java.util.Objects;

/**
 * 

Base class for Comparable comparisons..

* *

Supports multiple field types: strings, numbers, booleans, enums, dates.

* * @author Tomasz Kaczmarzyk * @author TP Diffenbach */ public abstract class ComparableSpecification extends PathSpecification { private static final long serialVersionUID = 1L; private String comparedTo; private Converter converter; public ComparableSpecification(QueryContext queryContext, String path, String[] httpParamValues, Converter converter) { super(queryContext, path); if (httpParamValues == null || httpParamValues.length != 1) { throw new IllegalArgumentException("expected one http-param, but was " + Arrays.toString(httpParamValues)); } this.comparedTo = httpParamValues[0]; this.converter = converter; } @SuppressWarnings({ "unchecked", "rawtypes" }) @Override public Predicate toPredicate(Root root, CriteriaQuery query, CriteriaBuilder cb) { Expression rootPath = path(root); Class typeOnPath = rootPath.getJavaType(); return makePredicate(cb, (Expression) rootPath, (Comparable) converter.convert(comparedTo, typeOnPath)); // the line below actually works (!), if Y doesn't need to extend Comparable. --tpd //return this.makePredicate(cb, rootPath.as(typeOnPath.asSubclass(typeOnPath)), // converter.convert(comparedTo, typeOnPath)); // the line below DOES work, but using the casts above is probably more efficient. //return this.makePredicate(cb, rootPath.as(typeOnPath.asSubclass(Comparable.class)), // (Comparable) converter.convert(comparedTo, typeOnPath)); } protected abstract > Predicate makePredicate(CriteriaBuilder cb, Expression x, Y y); @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; if (!super.equals(o)) return false; ComparableSpecification that = (ComparableSpecification) o; return Objects.equals(comparedTo, that.comparedTo) && Objects.equals(converter, that.converter); } @Override public int hashCode() { return Objects.hash(super.hashCode(), comparedTo, converter); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy