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

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[] 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[] 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