/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You 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. */ package org.apache.wicket.authroles.authorization.strategies.role.annotations; import java.lang.annotation.Documented; import java.lang.annotation.ElementType; import java.lang.annotation.Inherited; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; /** * Groups a set (technically an array) of {@link AuthorizeInstantiation}s for page authorization. * * This offers the ability to instantiate a page based on combined permissions / roles required. It * represents an AND relationship between the included permissions / roles. * * This can be used like this: * * <pre> * @AuthorizeInstantiations(ruleset = { @AuthorizeInstantiation("ADMIN"), * @AuthorizeInstantiation("MANAGER") }) * public class ForAdministrativeManagers extends WebPage * { * public ForAdministrativeManagers() * { * super(); * } * } * </pre> * * @see org.apache.wicket.authorization.IAuthorizationStrategy * @see AnnotationsRoleAuthorizationStrategy * @see AuthorizeInstantiation * @see AuthorizeInstantiations * @author René Dieckmann (rene.dieckmann@menoto.de) */ @Retention(RetentionPolicy.RUNTIME) @Target({ ElementType.TYPE }) @Documented @Inherited public @interface AuthorizeInstantiations { /** * The combined ruleset. * * @return the combined ruleset */ AuthorizeInstantiation[] ruleset(); }