001/*
002 * Licensed to the Apache Software Foundation (ASF) under one
003 * or more contributor license agreements. See the NOTICE file
004 * distributed with this work for additional information
005 * regarding copyright ownership. The ASF licenses this file
006 * to you under the Apache License, Version 2.0 (the
007 * "License"); you may not use this file except in compliance
008 * with the License. You may obtain a copy of the License at
009 *
010 * http://www.apache.org/licenses/LICENSE-2.0
011 *
012 * Unless required by applicable law or agreed to in writing,
013 * software distributed under the License is distributed on an
014 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
015 * KIND, either express or implied. See the License for the
016 * specific language governing permissions and limitations
017 * under the License.
018 */
019package org.apache.commons.weaver.privilizer;
020
021import java.lang.annotation.ElementType;
022import java.lang.annotation.Target;
023
024/**
025 * Indicates that a certain set of method calls should be "blueprint privilized," i.e.,
026 * their method bodies should be (recursively) copied for privileged invocation
027 * per the privilizer policy with which the blueprint privilizer weaver is invoked.
028 */
029@Target(ElementType.TYPE)
030public @interface Privilizing {
031    /**
032     * Models calls to blueprint methods defined on a specific class.
033     */
034    public @interface CallTo {
035        /**
036         * The class owning one or more blueprint method.
037         */
038        Class<?> value();
039
040        /**
041         * The names of the blueprint methods.
042         */
043        String[] methods() default { };
044    }
045
046    /**
047     * List of blueprint calls.
048     */
049    CallTo[] value();
050}