src.com.ibm.as400.security.auth.AuthenticationSystem Maven / Gradle / Ivy
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: AuthenticationSystem.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.
//
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.security.auth;
import java.beans.PropertyVetoException;
import com.ibm.as400.access.AS400;
import com.ibm.as400.access.AS400Exception;
import com.ibm.as400.access.AS400Message;
import com.ibm.as400.access.InternalErrorException;
import com.ibm.as400.access.Trace;
// Common point of access for system information used during authentication of server principals and credentials.
class AuthenticationSystem
{
private static AS400 system_ = null;
private static boolean onAS400_ = false;
static
{
try
{
AuthenticationSystem.system_ = new AS400();
AuthenticationSystem.system_.setGuiAvailable(false);
}
catch (PropertyVetoException e)
{
handleUnexpectedException(e);
}
try
{
String osName = System.getProperty("os.name");
Trace.log(Trace.DIAGNOSTIC, "Detected os.name: " + osName);
if (osName != null && osName.equalsIgnoreCase("OS/400")) AuthenticationSystem.onAS400_ = true;
}
catch (SecurityException e)
{
Trace.log(Trace.WARNING, "Error retrieving os.name:", e);
}
}
// This class is not intended to be instantiated.
private AuthenticationSystem()
{
}
// Logs trace information and throws an InternalErrorException.
// @param t The unexpected throwable.
static void handleUnexpectedException(Throwable t)
{
Trace.log(Trace.ERROR, "Unexpected Exception:", t);
if (t instanceof AS400Exception)
{
AS400Message[] messageList = ((AS400Exception)t).getAS400MessageList();
for (int msg = 0; msg < messageList.length; msg++)
Trace.log(Trace.ERROR, messageList[msg].toString());
}
InternalErrorException iee = new InternalErrorException(InternalErrorException.UNEXPECTED_EXCEPTION);
iee.initCause(t);
throw iee;
}
// Indicates if the given IBM i system and its user ID match the current environment.
// @return true if matched; false otherwise.
static boolean isLocal(AS400 system)
{
return system.isLocal() && system.getUserId().trim().equalsIgnoreCase(new AS400().getUserId());
}
// Returns a system object representing the local host. This value is cached so that the same instance is returned on subsequent calls.
// @return The system object.
static AS400 localHost()
{
return AuthenticationSystem.system_;
}
// Resets services for the local host; ignored if not running on an IBM i system. Since the cached system is always intended to represent the current system and user, it is always affected when a swap occurs. A reset is also required to allow the correct evaluation of when to use native optimizations.
static void resetLocalHost()
{
// Ignore if not running on IBM i.
if (!AuthenticationSystem.onAS400_) return;
// Reset services for the cached system started under the old identity.
try
{
// Disconnect and reset the state of the system object.
AuthenticationSystem.system_.resetAllServices();
// Reset the system user ID & password to force re-resolve.
AuthenticationSystem.system_.setUserId("");
AuthenticationSystem.system_.setPassword("");
// Request a service port to take system out of unset state.
AuthenticationSystem.system_.getServicePort(AS400.SIGNON);
}
catch (PropertyVetoException e)
{
handleUnexpectedException(e);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy