FileDocCategorySizeDatePackage
JCRMIPermissions.javaAPI DocphoneME MR2 API (J2ME)2990Wed May 02 18:00:38 BST 2007com.sun.satsa.acl

JCRMIPermissions.java

/*
 *   
 *
 * Copyright  1990-2007 Sun Microsystems, Inc. All Rights Reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER
 * 
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License version
 * 2 only, as published by the Free Software Foundation.
 * 
 * This program is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * General Public License version 2 for more details (a copy is
 * included at /legal/license.txt).
 * 
 * You should have received a copy of the GNU General Public License
 * version 2 along with this work; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 * 02110-1301 USA
 * 
 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
 * Clara, CA 95054 or visit www.sun.com if you need additional
 * information or have any questions.
 */

package com.sun.satsa.acl;

/**
 * This class represents a set of JCRMI permissions.
 */
public class JCRMIPermissions extends ACLPermissions {

    /**
     * Constructs new object.
     * @param parent parent ACFile object.
     */
    public JCRMIPermissions(ACSlot parent) {
        super(parent);
    }

    /**
     * Verifies that the MIDlet have permission for this remote method.
     * @param className the name of class.
     * @param method method name and signature.
     * @throws SecurityException if access denied
     */
    public void checkPermission(String className, String method) {

        if (type == ALLOW) {
            return;
        }
        if (type == DISALLOW) {
            throw new SecurityException("Access denied");
        }

        for (int i = 0; i < permissions.size(); i++) {

            JCRMIPermission p = (JCRMIPermission) permissions.elementAt(i);
            if (p.checkAccess(className, method)) {
                return;
            }
        }
        throw new SecurityException("Access denied: " + className +
                " " + method);
    }

    /**
     * Initializes internal variables, verifies that operation is
     * supported and permitted, returns method name and signature for
     * given PIN operation.
     * @param pinID PIN identifier.
     * @param unblockID unblocking PIN identifier.
     * @param action PIN operation.
     * @param className the name of class.
     * @return method name and signature.
     * @throws java.lang.SecurityException if access denied
     */
    public String preparePIN(int pinID, int unblockID, int action,
                             String className) {

        checkPINOperation(pinID, unblockID, action);
        String result = (String) getPINCommand(pinID, action);
        if (result == null) {
            throw new SecurityException();
        }
        checkPermission(className, result);
        return result;
    }
}