All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ibm.as400.access.UserPermission Maven / Gradle / Ivy

There is a newer version: 20.0.8
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: UserPermission.java
//                                                                             
// The source code contained herein is licensed under the IBM Public License   
// Version 1.0, which has been approved by the Open Source Initiative.         
// Copyright (C) 1997-2001 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;

/**
 * Represents the authority of a specific user.
 * Instances of UserPermission are returned by {@link Permission#getUserPermission(String) Permission.getUserPermission()}
**/
public class UserPermission 
       implements  Cloneable,
                   Serializable
{
    static final long serialVersionUID = 4L;

    /**
     * Constant indicating that no operation has been done.
    **/
    final static int COMMIT_NONE = -1;

    /**
     * Constant indicating that this user has just been added.
    **/
    final static int COMMIT_ADD = 0;

    /**
     * Constant indicating that this item has been changed for the object.
    **/
    final static int COMMIT_REMOVE = 1;

    /**
     * Constant indicating that this user has just been removed.
    **/
    final static int COMMIT_CHANGE = 2;

    /**
     * Constant indicating that this user permission has just been set from authorization list.
    **/
    final static int COMMIT_FROM_AUTL = 3;

    /**
     * Constant indicating that this user is neither a user nor a group.
     * It may be a *PUBLIC, *NTWIRF, or *NTWEFF.
    **/
    public final static int GROUPINDICATOR_SPECIALVALUE = 0;

    /**
     * Constant indicating that this user profile is a user.
    **/
    public final static int GROUPINDICATOR_USER = 1;

    /**
     * Constant indicating that this user profile is a group.
    **/
    public final static int GROUPINDICATOR_GROUP = 2;

    // Basic authorities mapping to detailed authorities.
    final static boolean[][] basicAutMapping = {
                            {true, true, true, true, true,
                             true, true, true, true, true  },
                            {false,false,false,false,false,
                             false,false,false,false,false },
                            {true, false,false,false,false,
                             true, false,false,false,true  },
                            {true, false,false,false,false,
                             true, true, true, true, true  }
                             };

    //Constant indicating basic authority type.
    final static int BASIC_USER_DEF = -1;
    final static int BASIC_ALL = 0;
    final static int BASIC_EXCLUDE = 1;
    final static int BASIC_USE = 2;
    final static int BASIC_CHANGE = 3;

    //Constant indicating data authority type.
    final static int DATA_READ = 5;
    final static int DATA_ADD = 6;
    final static int DATA_UPDATE = 7;
    final static int DATA_DELETE = 8;
    final static int DATA_EXECUTE = 9; 

    //Constant indicating object authority type.
    final static int OBJECT_OPERATION = 0;
    final static int OBJECT_MANAGEMENT = 1;
    final static int OBJECT_EXIST = 2;
    final static int OBJECT_ALTER = 3;
    final static int OBJECT_REFERENCE = 4;

    //Authorities information.
    boolean[] authorities_;

    //Data authority information.
    String dataAuthority_;

    //Object authority informatin.
    int objectAuthority_;
    
    // Authorization list management flag.
    private boolean autListMgt_;
    
    // Commit flag
    private int committed_;
    
    // The value indicating whether this user profile is a user 
    // profile or a group profile.
    private int groupIndicator_;

    // User profile name.
    private String userName_;

    // Indicates whether the user is from authorization list.
    private boolean fromAuthorizationList_;

    /**
     * Constructs a UserPermission object.
     * @param userProfileName The name of the user profile.
     *
    **/
    UserPermission(String userProfileName)
    {
        authorities_ = new boolean[10];
        for(int i=0;i
     *     
  • -1 COMMIT_NONE means no change and any operation to the object. *
  • 0 COMMIT_ADD means this user permission which was added * to the object has not been committed. *
  • 1 COMMIT_REMOVE means this user permission which was * removed from the object has not been committed. *
  • 2 COMMIT_CHANGE means the changes of the content have * not committed. * * @see #setCommitted **/ int getCommitted() { return committed_; } /** * Returns the value indicating if the user profile is a group profile. * @return The value indicating if the user profile is a group profile. * **/ public int getGroupIndicator() { return groupIndicator_; } /** * Returns the user profile name for this permission. * @return The user profile name for this permission. * **/ public String getUserID() { return userName_; } /** * Indicates whether the user permission is from authorization list. * @return true if the user is from authorization list; * false otherwise. **/ public boolean isFromAuthorizationList() { return fromAuthorizationList_; } /** * Indicates whether the user has the authority of authorization list management. * It is valid only for the object which is an authorization list. * @return true if the user has the authority of authorization list * management; false otherwise. * **/ public boolean isAuthorizationListManagement() { return autListMgt_; } /** * Serialization support. **/ private void readObject(ObjectInputStream s) throws ClassNotFoundException, IOException { s.defaultReadObject(); s.readObject(); } /** * Sets the authority of authorization list management. * It is valid only for the object which is an authorizaiton list. * @param autListMgt true if the user has the authority * of authorization list management; false otherwise. * **/ public synchronized void setAuthorizationListManagement(boolean autListMgt ) { autListMgt_ = autListMgt; if (getCommitted() == COMMIT_NONE) { setCommitted(COMMIT_CHANGE); } return; } /** * Sets the committed signal. * @param commit The committed signal. * @see #getCommitted() **/ void setCommitted(int commit) { committed_ = commit; return; } /** * Sets the permission of user as coming from an authorization list. * This is valid only if the user is *PUBLIC and the authorization list * exists. If set to true, all of the other authorities will be set to false. * If any of the other authorities are set to true, * this value is automatically set to false. * @param fromAutList true if the user is from the authorization list; * false otherwise. * **/ public synchronized void setFromAuthorizationList(boolean fromAutList) { if (fromAuthorizationList_ == fromAutList) return; if (fromAutList == true) { fromAuthorizationList_ = fromAutList; for(int i=0;i




  • © 2015 - 2025 Weber Informatics LLC | Privacy Policy