1 /* 2 * Copyright 2002 by 3 * <a HREF="http://www.coridan.com">Coridan</a> 4 * <a HREF="mailto: support@coridan.com ">support@coridan.com</a> 5 * 6 * The contents of this file are subject to the Mozilla Public License Version 7 * 1.1 (the "License"); you may not use this file except in compliance with the 8 * License. You may obtain a copy of the License at 9 * http://www.mozilla.org/MPL/ 10 * 11 * Software distributed under the License is distributed on an "AS IS" basis, 12 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License 13 * for the specific language governing rights and limitations under the 14 * License. 15 * 16 * The Original Code is "MantaRay" (TM). 17 * 18 * The Initial Developer of the Original Code is Shirley Sasson. 19 * Portions created by the Initial Developer are Copyright (C) 2006 20 * Coridan Inc. All Rights Reserved. 21 * 22 * Contributor(s): all the names of the contributors are added in the source 23 * code where applicable. 24 * 25 * Alternatively, the contents of this file may be used under the terms of the 26 * LGPL license (the "GNU LESSER GENERAL PUBLIC LICENSE"), in which case the 27 * provisions of LGPL are applicable instead of those above. If you wish to 28 * allow use of your version of this file only under the terms of the LGPL 29 * License and not to allow others to use your version of this file under 30 * the MPL, indicate your decision by deleting the provisions above and 31 * replace them with the notice and other provisions required by the LGPL. 32 * If you do not delete the provisions above, a recipient may use your version 33 * of this file under either the MPL or the GNU LESSER GENERAL PUBLIC LICENSE. 34 35 * 36 * This library is free software; you can redistribute it and/or modify it 37 * under the terms of the MPL as stated above or under the terms of the GNU 38 * Lesser General Public License as published by the Free Software Foundation; 39 * either version 2.1 of the License, or any later version. 40 * 41 * This library is distributed in the hope that it will be useful, but WITHOUT 42 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 43 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public 44 * License for more details. 45 */ 46 47 package org.mr.kernel.security.impl; 48 49 import org.mr.kernel.security.MantaSecurityException; 50 import org.mr.kernel.security.authorization.ACLKeyEntry; 51 import org.mr.kernel.security.authorization.AuthorizationValue; 52 53 /** 54 * This interface defines the security actions that are required from the ACL atorage. 55 * For each ACL atorage type (for example, LDAP) there will be an implementation that 56 * actually performs the actions using the specific storage. 57 * 58 * @version 1.0 59 * @since Mar 22, 2006 60 * @author Shirley Sasson 61 * 62 */ 63 public interface ACLStorageConnector { 64 65 /** 66 * This method is used to check whether the given ACLKeyEntry represents an authorized entry in the 67 * ACL storage. 68 * 69 * @param keyEntry 70 * the entry to authorize with the ACL storage 71 * @return an AuthorizationValue object holding the authorization information 72 */ 73 public AuthorizationValue isAuthorized(ACLKeyEntry keyEntry) throws MantaSecurityException; 74 75 /** 76 * This method is used to retrieve the group of user from the ACL storage. 77 * 78 * @param username 79 * the user to search its group 80 * @return the group of the user 81 */ 82 public String getGroupOfUser(String username) throws MantaSecurityException; 83 } 84