com.yahoo.elide.annotation.SharePermission Maven / Gradle / Ivy
/*
* Copyright 2016, Yahoo Inc.
* Licensed under the Apache License, Version 2.0
* See LICENSE file in project root for terms.
*/
package com.yahoo.elide.annotation;
import com.yahoo.elide.security.checks.Check;
import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
import static java.lang.annotation.ElementType.PACKAGE;
import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
/**
* A permission that is checked whenever an object is loaded without the context of a lineage and assigned
* to a relationship or collection.
*/
@Target({TYPE, PACKAGE})
@Retention(RUNTIME)
@Inherited
public @interface SharePermission {
/**
* Any one of these checks must pass.
*
* @return the array of check classes
* @deprecated as of 2.2, use {@link #expression()} instead.
*/
@Deprecated
Class extends Check>[] any() default {};
/**
* All of these checks must pass.
*
* @return the array of check classes
* @deprecated as of 2.2, use {@link #expression()} instead.
*/
@Deprecated
Class extends Check>[] all() default {};
/**
* An expression of checks that will be parsed via ANTLR. For example:
* {@code @SharePermission(expression="Prefab.Role.All")} or
* {@code @SharePermission(expression="Prefab.Role.All and Prefab.Role.UpdateOnCreate")}
*
* All of {@linkplain com.yahoo.elide.security.checks.prefab the built-in checks} are name-spaced as
* {@code Prefab.CHECK} without the {@code Check} suffix
*
* @return the expression string to be parsed
*/
String expression() default "";
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy