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

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

There is a newer version: 20.0.8
Show newest version
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename:  AS400CertificateVldlUtil.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-2004 International Business Machines Corporation and
// others.  All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

import java.beans.Beans;
import java.beans.PropertyVetoException;
import java.util.EventListener;
import java.io.InterruptedIOException;
import java.io.IOException;
import java.net.UnknownHostException;
import java.util.Vector;


/**
   

The AS400CertificateVldlUtil class provides the implementation of the methods for accessing certificates in an IBM i validation list object. **/ public class AS400CertificateVldlUtil extends AS400CertificateUtil implements java.io.Serializable { private static final String CLASSNAME = "com.ibm.as400.access.AS400CertificateVldlUtil"; static { if (Trace.traceOn_) Trace.logLoadPath(CLASSNAME); } static final long serialVersionUID = 4L; /** * The validation list class implementation, either native or remote. **/ transient AS400CertificateVldlUtilImpl vldlImpl_ = null; /** * Constructs an AS400CertificateVldlUtil object. **/ public AS400CertificateVldlUtil() { } /** * Constructs an AS400CertificateVldlUtil object. * * @param system The system on which the validation list exists. * @param path The fully qualified integrated file system path name of the validation list. For example, /QSYS.LIB/MYLIB.LIB/MYVLDL.VLDL. */ public AS400CertificateVldlUtil(AS400 system, String path) { super(system, path); if (!(objectType_.equalsIgnoreCase("VLDL")) || objectName_.length() > 10) { throw new ExtendedIllegalArgumentException("path (" + path + ")", ExtendedIllegalArgumentException.PATH_NOT_VALID); } } /** Connect() Determines the type of implementation that will be used. System and Path parameters are committed at this time. **/ void connect() throws IOException { // Ensure that the system has been set. if (system_ == null) { Trace.log(Trace.ERROR, "Parameter 'system' is null at connect."); throw new ExtendedIllegalStateException("system", ExtendedIllegalStateException.PROPERTY_NOT_SET); } // Ensure that the path has been set. if (ifsPathName_ == null) { Trace.log(Trace.ERROR, "Parameter 'path' is null."); throw new ExtendedIllegalStateException("ifsPathName", ExtendedIllegalStateException.PROPERTY_NOT_SET); } // Determine if we are running on the server or some remote system. vldlImpl_ = (com.ibm.as400.access.AS400CertificateVldlUtilImpl) system_.loadImpl( "com.ibm.as400.access.AS400CertificateVldlUtilImplNative", "com.ibm.as400.access.AS400CertificateVldlUtilImplRemote"); impl_ = (com.ibm.as400.access.AS400CertificateUtilImpl) system_.loadImpl( "com.ibm.as400.access.AS400CertificateUtilImplNative", "com.ibm.as400.access.AS400CertificateUtilImplRemote"); //update vldl and base class impl references vldlImpl_.system_ = system_; impl_.system_ = system_; Converter conv = new Converter(system_.getCcsid(), system_); // @C1A vldlImpl_.setConverter(conv); // @C0C @C1C impl_.setConverter(conv); // Set the connection flag, commits system and path parameters. connected_ = true; } /** * Add the certificate to the repository. Throws an ExtendedIOException if the certificate is already a member of the repository. * * @param certificate The complete ASN.1 X.509 certificate to be added to the validation list. * @exception AS400SecurityException If a security or authority error occurs. * @exception ErrorCompletingRequestException If an error occurs before the request is completed. * @exception ExtendedIllegalArgumentException If invalid certificate. * @exception ExtendedIOException If certificate already added and other IBM i certificate access errors. * @exception InterruptedException If this thread is interrupted. * @exception IOException If an error occurs while communicating with the system. * @exception ObjectDoesNotExistException If the IBM i object does not exist. */ public void addCertificate(byte[] certificate) throws AS400SecurityException, ErrorCompletingRequestException, ExtendedIOException, InterruptedException, IOException, ObjectDoesNotExistException { int rc; if (null == certificate) { Trace.log(Trace.ERROR, "Parameter 'certificate' is null."); throw new NullPointerException("certificate"); } if (isConnected() == false) connect(); //makes either remote or local call rc = vldlImpl_.calladdCertificate(certificate, certificate.length, ifsPathName_, ifsPathName_.length()); if (rc != SUCCESS) { throwException(vldlImpl_.cpfError_, ifsPathName_, rc); } fireAdd(); } /** * Determines if the certificate is in the validation list. * * @param certificate The ASN.1 encoded X.509 certificate to search for in the validation list. * * @return true if the certificate is found in the validation list; false otherwise. * * @exception AS400SecurityException If a security or authority error occurs. * @exception ErrorCompletingRequestException If an error occurs before the request is completed. * @exception ExtendedIllegalArgumentException If invalid certificate. * @exception ExtendedIOException If other IBM i certificate access errors. * @exception InterruptedException If this thread is interrupted. * @exception IOException If an error occurs while communicating with the system. * @exception ObjectDoesNotExistException If the IBM i object does not exist. */ public boolean checkCertificate(byte[] certificate) throws AS400SecurityException, ErrorCompletingRequestException, ExtendedIOException, InterruptedException, IOException, ObjectDoesNotExistException { int rc; if (null == certificate) { Trace.log(Trace.ERROR, "Parameter 'certificate' is null."); throw new NullPointerException("certificate"); } if (isConnected() == false) connect(); //makes either remote or local call rc = vldlImpl_.callcheckCertificate( certificate, certificate.length, ifsPathName_, ifsPathName_.length(), 1); if (rc != SUCCESS) { throwException(vldlImpl_.cpfError_, ifsPathName_, rc); } return ((vldlImpl_.present_ == 1) ? true : false); } /** * Determines if a certificate matching the handle exists in the validation list. * * @param certificateHandle The IBM i certificate handle matching the certificate. * * @return true if a certificate matching the handle is found in the validation list; false otherwise. * * @exception AS400SecurityException If a security or authority error occurs. * @exception ErrorCompletingRequestException If an error occurs before the request is completed. * @exception ExtendedIllegalArgumentException If invalid certificate handle. * @exception ExtendedIOException If other IBM i certificate access errors. * @exception InterruptedException If this thread is interrupted. * @exception IOException If an error occurs while communicating with the system. * @exception ObjectDoesNotExistException If the IBM i object does not exist. */ public boolean checkCertificateByHandle(byte[] certificateHandle) throws AS400SecurityException, ErrorCompletingRequestException, ExtendedIOException, InterruptedException, IOException, ObjectDoesNotExistException { int rc; if (null == certificateHandle) { Trace.log(Trace.ERROR, "Parameter 'certificateHandle' is null."); throw new NullPointerException("certificateHandle"); } if (isConnected() == false) connect(); //makes either remote or local call rc = vldlImpl_.callcheckCertificate( certificateHandle, certificateHandle.length, ifsPathName_, ifsPathName_.length(), 2); if (rc != SUCCESS) { throwException(vldlImpl_.cpfError_, ifsPathName_, rc); } return ((vldlImpl_.present_ == 1) ? true : false); } /** * Deletes the certificate from the validation list. Throws an ExtendedIOException if the certificate is not present in the validation list. * * @param certificate The complete ASN.1 X.509 Certificate to be deleted from the repository. * @exception AS400SecurityException If a security or authority error occurs. * @exception ErrorCompletingRequestException If an error occurs before the request is completed. * @exception ExtendedIllegalArgumentException If invalid certificate. * @exception ExtendedIOException If certificate not found and other IBM i certificate access errors. * @exception InterruptedException If this thread is interrupted. * @exception IOException If an error occurs while communicating with the system. * @exception ObjectDoesNotExistException If the IBM i object does not exist. */ public void deleteCertificate(byte[] certificate) throws AS400SecurityException, ErrorCompletingRequestException, ExtendedIOException, InterruptedException, IOException, ObjectDoesNotExistException { int rc; if (null == certificate) { Trace.log(Trace.ERROR, "Parameter 'certificate' is null."); throw new NullPointerException("certificate"); } if (isConnected() == false) connect(); //makes either remote or local call rc = vldlImpl_.calldeleteCertificate( certificate, certificate.length, ifsPathName_, ifsPathName_.length(), 1); if (rc != SUCCESS) { throwException(vldlImpl_.cpfError_, ifsPathName_, rc); } fireDelete(); } /** * Deletes the certificate matching the certificate handle from the validation list. Throws ExtendedIOException if the certificate is not present in the repository. * * @param certificateHandle The IBM i certificate handle matching the certificate to be deleted from the repository. * @exception AS400SecurityException If a security or authority error occurs. * @exception ErrorCompletingRequestException If an error occurs before the request is completed. * @exception ExtendedIllegalArgumentException If invalid certificate handle. * @exception ExtendedIOException If certificate not found and other IBM i certificate access errors. * @exception InterruptedException If this thread is interrupted. * @exception IOException If an error occurs while communicating with the system. * @exception ObjectDoesNotExistException If the IBM i object does not exist. */ public void deleteCertificateByHandle(byte[] certificateHandle) throws AS400SecurityException, ErrorCompletingRequestException, ExtendedIOException, InterruptedException, IOException, ObjectDoesNotExistException { int rc; if (null == certificateHandle) { Trace.log(Trace.ERROR, "Parameter 'certificateHandle' is null."); throw new NullPointerException("certificateHandle"); } if (isConnected() == false) connect(); //makes either remote or local call rc = vldlImpl_.calldeleteCertificate( certificateHandle, certificateHandle.length, ifsPathName_, ifsPathName_.length(), 2); if (rc != SUCCESS) { throwException(vldlImpl_.cpfError_, ifsPathName_, rc); } fireDelete(); } /** * Lists certificates which match the specified attributes are copied from the validation list into the specified user space. * The validation list is not locked during the listCertificates operation. * Certificates are stored into the user space with CERT0100 format. See the IBM i QsyListVldlCertificates (QSYLSTVC) and QsyListUserCertificates (QSYLSTUC) API's for further information. * * @param certificateAttributes The list of attributes the certificate should match. * A value of null places all certificates from the validation list into the user space. * An empty String or empty byte array search attribute will search for certificates that do not have this attribute. * For example, SUBJECT_ORGANIZATION = new String("") will search for certificates without the subject organization field. * Null search attributes are ignored. * @param userSpaceName The fully qualified integrated file system path name of the user space to put the list results, for example, /QSYS.LIB/MYLIB.LIB/MYUSRSPC.USRSPC. The 10 char IBM i library of the user space may also be specified as %CURLIB% or %LIBL%. * See {@link com.ibm.as400.access.QSYSObjectPathName QSYSObjectPathName} * * @return The number of certificates found. * * @exception AS400SecurityException If a security or authority error occurs. * @exception ErrorCompletingRequestException If an error occurs before the request is completed. * @exception ExtendedIllegalArgumentException If invalid search attributes or input parameter. * @exception ExtendedIOException If IBM i certificate access error. * @exception InterruptedException If this thread is interrupted. * @exception IOException If an error occurs while communicating with the system. * @exception ObjectDoesNotExistException If the IBM i object does not exist. */ public int listCertificates( AS400CertificateAttribute[] certificateAttributes, String userSpaceName) throws AS400SecurityException, ErrorCompletingRequestException, ExtendedIOException, InterruptedException, IOException, ObjectDoesNotExistException { int rc; String as400usrSpaceName; if (isConnected() == false) connect(); //orders and saves the user's search attrs boolean[] parmsEntered = setSearchAttributes(certificateAttributes); //get usrSpaceName in IBM i format. check for nonnull values. as400usrSpaceName = getAS400UserSpaceName(userSpaceName); //makes either remote or local call rc = vldlImpl_.calllistCertificates( ifsPathName_, ifsPathName_.length(), as400usrSpaceName, parmsEntered, as400AttrS_, as400AttrB_); if (rc != SUCCESS) { throwException(vldlImpl_.cpfError_, ifsPathName_, rc); } return vldlImpl_.numberCertificatesFound_; } /** Sets the path for the validation list. @param path The fully qualified integrated file system path name of the validation list. @exception PropertyVetoException If the change is vetoed. **/ public void setPath(String path) throws PropertyVetoException { String libName; String objectName; String objectType; // check parm if (path == null) { Trace.log(Trace.ERROR, "Parameter 'path' is null."); throw new NullPointerException("path"); } QSYSObjectPathName ifs = new QSYSObjectPathName(path); libName = ifs.getLibraryName(); objectName = ifs.getObjectName(); objectType = ifs.getObjectType(); if (null == libName || null == objectName || objectName.length() > 10 || !(objectType.equalsIgnoreCase("VLDL")) ) { throw new ExtendedIllegalArgumentException("path", ExtendedIllegalArgumentException.PATH_NOT_VALID); } // Set path the first time. if (ifsPathName_ == null) { ifsPathName_ = path; libName_ = libName; objectName_ = objectName; objectType_ = objectType; } else { // If system property is set, make sure we have not already connected. if (system_ != null) { if (isConnected() ) { Trace.log(Trace.ERROR, "Parameter 'path' is not changed (Connected=true)."); throw new ExtendedIllegalStateException("path", ExtendedIllegalStateException.PROPERTY_NOT_CHANGED); } } // Remember the current path value. String oldPath = ifsPathName_; // Fire a vetoable change event for the path. vetos_.fireVetoableChange("path", oldPath, path); // Update the path value. ifsPathName_ = path; libName_ = libName; objectName_ = objectName; objectType_ = objectType; // Fire the property change event. changes_.firePropertyChange("path", oldPath, path); } } } // End of AS400CertificateVldlUtil class





© 2015 - 2025 Weber Informatics LLC | Privacy Policy