com.arangodb.springframework.annotation.Relations Maven / Gradle / Ivy
/*
* DISCLAIMER
*
* Copyright 2017 ArangoDB GmbH, Cologne, Germany
*
* 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.
*
* Copyright holder is ArangoDB GmbH, Cologne, Germany
*/
package com.arangodb.springframework.annotation;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
* @author Mark Vollmary
*
*/
@Retention(RetentionPolicy.RUNTIME)
@Target({ ElementType.FIELD })
public @interface Relations {
public enum Direction {
ANY, OUTBOUND, INBOUND
}
Class>[] edges();
/**
* @return edges and vertices returned by this query will start at the traversal depth of min (thus edges and
* vertices below will not be returned). If not specified, it defaults to 1. The minimal possible value is
* 0.
*/
int minDepth() default 1;
/**
* @return up to max length paths are traversed. If omitted, max defaults to min. Thus only the vertices and edges
* in the range of min are returned. max can not be specified without min.
*/
int maxDepth() default 1;
/**
* @return follow outgoing, incoming, or edges pointing in either direction in the traversal
*/
Direction direction() default Direction.ANY;
/**
* @return whether the entity should be loaded lazy
*/
boolean lazy() default false;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy