src.com.ibm.as400.security.auth.AuthenticationSystem Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jt400 Show documentation
Show all versions of jt400 Show documentation
The Open Source version of the IBM Toolbox for Java
///////////////////////////////////////////////////////////////////////////////
//
// 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