01: /**
02: * EasyBeans
03: * Copyright (C) 2006 Bull S.A.S.
04: * Contact: easybeans@ow2.org
05: *
06: * This library is free software; you can redistribute it and/or
07: * modify it under the terms of the GNU Lesser General Public
08: * License as published by the Free Software Foundation; either
09: * version 2.1 of the License, or any later version.
10: *
11: * This library is distributed in the hope that it will be useful,
12: * but WITHOUT ANY WARRANTY; without even the implied warranty of
13: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14: * Lesser General Public License for more details.
15: *
16: * You should have received a copy of the GNU Lesser General Public
17: * License along with this library; if not, write to the Free Software
18: * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
19: * USA
20: *
21: * --------------------------------------------------------------------------
22: * $Id: ItfSecurityRoles.java 1970 2007-10-16 11:49:25Z benoitf $
23: * --------------------------------------------------------------------------
24: */package org.ow2.easybeans.tests.common.ejbs.base.security;
25:
26: import java.security.Principal;
27:
28: import javax.annotation.security.DenyAll;
29: import javax.annotation.security.PermitAll;
30: import javax.annotation.security.RolesAllowed;
31:
32: /**
33: * Verifies the different types of security polices.
34: * @author Gisele Pinheiro Souza
35: * @author Eduardo Studzinski Estima de Castro
36: *
37: */
38: public interface ItfSecurityRoles {
39:
40: /**
41: * Method with the police permiteAll.
42: */
43: @PermitAll
44: void permitAllAttribute();
45:
46: /**
47: * Method with the police denyAll.
48: */
49: @DenyAll
50: void denyAllAttribute();
51:
52: /**
53: * Method that can be accessed only by the mainrole and the secondaryrole.
54: */
55: @RolesAllowed(value={"mainrole","secondaryrole"})
56: void permitTwoRoles();
57:
58: /**
59: * Method that can be accessed only by the mainrole.
60: */
61: @RolesAllowed(value={"mainrole"})
62: void permitOneRole();
63:
64: /**
65: * Test the Roles declared on the bean class.
66: * This has to be inherited by the method if nothing is set.
67: */
68: void permitRolesOnBean();
69:
70: /**
71: * Calls a method in other bean that returns the callerPrincipal. It
72: * compares its caller with the caller returned. The caller for the two
73: * methods must be the same.
74: * @return true if the bean caller and the bean callee are called by the
75: * same role, false otherwise.
76: */
77: boolean testCallerPrincipal();
78:
79: /**
80: * Compares the role in the parameter with the caller in role.
81: * @param role the role name.
82: * @return true if the caller has the role in the parameter, false
83: * otherwise.
84: */
85: boolean isCallerinRole(final String role);
86:
87: /**
88: * Returns the bean caller principal.
89: * @return the caller principal.
90: */
91: Principal getCallerPrincipal();
92:
93: }
|