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

src.com.ibm.as400.security.auth.AS400Principal Maven / Gradle / Ivy

There is a newer version: 11.1
Show newest version
package com.ibm.as400.security.auth;

///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                                 
//                                                                             
// Filename: AS400Principal.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-2003 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////
import com.ibm.as400.access.AS400;
import com.ibm.as400.access.AS400Exception;
import com.ibm.as400.access.AS400SecurityException;
import com.ibm.as400.access.ConnectionDroppedException;
import com.ibm.as400.access.ErrorCompletingRequestException;
import com.ibm.as400.access.ExtendedIllegalStateException;
import com.ibm.as400.access.InternalErrorException;
import com.ibm.as400.access.ObjectDoesNotExistException;
import com.ibm.as400.access.Trace;
import com.ibm.as400.access.User;
import java.beans.PropertyChangeListener;
import java.beans.PropertyChangeSupport;
import java.beans.PropertyVetoException;
import java.beans.VetoableChangeListener;
import java.beans.VetoableChangeSupport;
import java.io.IOException;
import java.io.Serializable;
import java.io.UnsupportedEncodingException;
import java.security.Principal;
import java.util.Vector;
/**
 * The AS400Principal class provides an abstract superclass
 * for representations of IBM i system security-related
 * identities.
 *
 * 

Typical IBM i system Principals include, but are not * necessarily limited to, user profiles. * */ public abstract class AS400Principal implements Principal, Serializable { static final long serialVersionUID = 4L; private transient PropertyChangeSupport changes_ = new PropertyChangeSupport(this); private transient VetoableChangeSupport vetos_ = new VetoableChangeSupport(this); private transient Vector credentialListeners_ = new Vector(); private AS400 system_ = null; /** * Constructs an AS400Principal object. * */ public AS400Principal() { super(); initTransient(); } /** * Constructs an AS400Principal object. * *

The system property is set to the * specified value. * * @param system * The IBM i system associated with the principal. * */ public AS400Principal(AS400 system) { this(); try { setSystem(system); } catch (PropertyVetoException pve) { AuthenticationSystem.handleUnexpectedException(pve); } } /** * Adds a PropertyChangeListener. * *

The specified listener's propertyChange * method will be called each time the value of a * bound property is changed. * * @param listener * The PropertyChangeListener. * * @see #removePropertyChangeListener * */ public void addPropertyChangeListener(PropertyChangeListener listener) { if (listener == null) { Trace.log(Trace.ERROR, "Parameter 'listener' is null."); throw new NullPointerException("listener"); } changes_.addPropertyChangeListener(listener); } /** * Adds a VetoableChangeListener. * *

The specified listener's vetoableChange * method will be called each time the value of a * constrained property is changed. * * @param listener * The VetoableChangeListener. * * @see #removeVetoableChangeListener * */ public void addVetoableChangeListener(VetoableChangeListener listener) { if (listener == null) { Trace.log(Trace.ERROR, "Parameter 'listener' is null."); throw new NullPointerException("listener"); } vetos_.addVetoableChangeListener(listener); } /** * Report a bound property update to any registered listeners. * * @param propertyName * The programmatic name of the property that was changed. * * @param oldValue * The old value of the property. * * @param newValue * The new value of the property. * */ void firePropertyChange(String propertyName, Object oldValue, Object newValue) { changes_.firePropertyChange(propertyName, oldValue, newValue); } /** * Report a vetoable property update to any registered listeners. * * @param propertyName * The programmatic name of the property that was changed. * * @param oldValue * The old value of the property. * * @param newValue * The new value of the property. * * @exception PropertyVetoException * If the recipient wishes the property change to be rolled back. * */ void fireVetoableChange(String propertyName, Object oldValue, Object newValue) throws PropertyVetoException { vetos_.fireVetoableChange(propertyName, oldValue, newValue); } /** * Returns the name commonly used to refer to the principal. * *

Default behavior for the superclass is to return the * user profile name * * @return * The principal's name. * */ public String getName() { return getUserProfileName(); } /** * Returns the AS400 system object for the principal. * * @return * The AS400 system for the principal; * null if not assigned. * */ public AS400 getSystem() { return system_; } /** * Returns an IBM i system User object based on the * user profile name and * system associated with * the principal. * *

The system property must be set and a * valid userProfileName must be identified by * the principal prior to requesting the user. * * @return * The com.ibm.as400.access.User object. * * @exception ExtendedIllegalStateException * If a required property is not set. * @exception AS400Exception * If the IBM i system returns an error message. * @exception AS400SecurityException * If a security or authority error occurs. * @exception ConnectionDroppedException * If the connection is dropped unexpectedly. * @exception ErrorCompletingRequestException * If an error occurs before the request is completed. * @exception InterruptedException * If this thread is interrupted. * @exception IOException * If an error occurs while communicating with the system. * @exception ObjectDoesNotExistException * If the system object does not exist. * @exception UnsupportedEncodingException * If the character encoding is not supported. * */ public User getUser() throws AS400Exception, AS400SecurityException, ConnectionDroppedException, ErrorCompletingRequestException, InterruptedException, ObjectDoesNotExistException, IOException, UnsupportedEncodingException { if (getSystem() == null) { Trace.log(Trace.ERROR, "Required property 'system' not set."); throw new ExtendedIllegalStateException( ExtendedIllegalStateException.PROPERTY_NOT_SET); } return new User(getSystem(), getUserProfileName()); } /** * Returns the name of a user profile associated with * the thread when work is performed on * behalf of the principal. * * @return * A String containing the name; empty if not applicable. * */ public String getUserProfileName() { return ""; } /** * Initializes transient data. * *

Subclasses should override as necessary to * initialize additional class-specific data. * */ void initTransient() { } /** * Overrides the ObjectInputStream.readObject() method in order to return any * transient parts of the object to there properly initialized state. * * By calling ObjectInputStream.defaultReadObject() we restore the state of * any non-static and non-transient variables. We then continue on to * restore the state (as necessary) of the remaining varaibles. * * @param in * The input stream from which to deserialize the object. * * @exception ClassNotFoundException * If the class being deserialized is not found. * * @exception IOException * If an error occurs while communicating with the system. * */ private void readObject(java.io.ObjectInputStream in) throws ClassNotFoundException, java.io.IOException { in.defaultReadObject(); initTransient(); } /** * Removes the specified listener from the internal list. * *

Does nothing if the listener is not in the list. * * @param listener * The PropertyChangeListener. * * @see #addPropertyChangeListener * */ public void removePropertyChangeListener(PropertyChangeListener listener) { changes_.removePropertyChangeListener(listener); } /** * Removes the specified listener from the internal list. * *

Does nothing if the listener is not in the list. * * @param listener * The VetoableChangeListener. * * @see #addVetoableChangeListener * */ public void removeVetoableChangeListener(VetoableChangeListener listener) { vetos_.removeVetoableChangeListener(listener); } /** * Sets the AS400 system object for the principal. * * @param system * The AS400 system object. * * @exception PropertyVetoException * If the change is vetoed. * */ public void setSystem(AS400 system) throws PropertyVetoException { AS400 old = getSystem(); fireVetoableChange("system", old, system); system_ = system; firePropertyChange("system", old, system); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy