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

org.infinispan.api.annotations.indexing.GeoCoordinates Maven / Gradle / Ivy

The newest version!
package org.infinispan.api.annotations.indexing;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Repeatable;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

import org.hibernate.search.engine.environment.bean.BeanRetrieval;
import org.hibernate.search.mapper.pojo.mapping.definition.annotation.processing.PropertyMapping;
import org.hibernate.search.mapper.pojo.mapping.definition.annotation.processing.PropertyMappingAnnotationProcessorRef;
import org.hibernate.search.mapper.pojo.mapping.definition.annotation.processing.TypeMapping;
import org.hibernate.search.mapper.pojo.mapping.definition.annotation.processing.TypeMappingAnnotationProcessorRef;
import org.infinispan.api.common.annotations.indexing._private.GeoCoordinatesProcessor;
import org.infinispan.api.annotations.indexing.model.Point;

/**
 * Defines a {@link Point} binding from a type or a property
 * to a {@link Point} field representing a point on earth.
 * 

* If the longitude and latitude information is hosted on two different properties, * {@code @GeoCoordinates} must be used on the entity (class level). * The {@link Latitude} and {@link Longitude} annotations must mark the properties. *


 * @GeoCoordinates(name="home")
 * public class User {
 *     @Latitude
 *     public Double getHomeLatitude() { ... }
 *     @Longitude
 *     public Double getHomeLongitude() { ... }
 * }
 * 
*

* Alternatively, {@code @GeoCoordinates} can be used on a property of type {@link Point}: *


 * public class User {
 *     @GeoCoordinates
 *     public Point getHome() { ... }
 * }
 * 
*

* Infinispan version of {@link org.hibernate.search.mapper.pojo.bridge.builtin.annotation.GeoPointBinding} * * @since 14.0 */ @Retention(RetentionPolicy.RUNTIME) @Target({ElementType.METHOD, ElementType.FIELD, ElementType.TYPE}) @Documented @Repeatable(GeoCoordinates.List.class) @TypeMapping(processor = @TypeMappingAnnotationProcessorRef(type = GeoCoordinatesProcessor.class, retrieval = BeanRetrieval.CONSTRUCTOR)) @PropertyMapping(processor = @PropertyMappingAnnotationProcessorRef(type = GeoCoordinatesProcessor.class, retrieval = BeanRetrieval.CONSTRUCTOR)) public @interface GeoCoordinates { /** * The name of the index field holding spatial information. *

* If {@code @Point} is hosted on a property, defaults to the property name. * If {@code @Point} is hosted on a class, the name must be provided. * * @return the field name */ String fieldName() default ""; /** * @return Whether projections are enabled for this field. * @see Basic#projectable() */ boolean projectable() default false; /** * @return Whether this field should be sortable. * @see Basic#sortable() */ boolean sortable() default false; /** * @return The name of the marker this spatial should look into * when looking for the {@link Latitude} and {@link Longitude} markers. */ String marker() default ""; @Retention(RetentionPolicy.RUNTIME) @Target({ElementType.METHOD, ElementType.FIELD, ElementType.TYPE}) @Documented @interface List { GeoCoordinates[] value(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy