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

src.com.ibm.as400.access.AFPResource Maven / Gradle / Ivy

///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: AFPResource.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-2000 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

import java.io.IOException;
import java.beans.PropertyVetoException;

/**
 * The AFPResource class represents a system AFP resource.
 * An instance of this class can be used to manipulate an individual
 * IBM i AFP resource.
 *
 * See AFP Resource Attributes for
 * valid attributes.
 *
 **/

public class AFPResource extends PrintObject
implements java.io.Serializable
{
    static final long serialVersionUID = 4L;

    public static final String  STR_FNTRSC  = "FNTRSC";
    public static final String  STR_FORMDF  = "FORMDF";
    public static final String  STR_OVL     = "OVL";
    public static final String  STR_PAGDFN  = "PAGDFN";
    public static final String  STR_PAGSEG  = "PAGSEG";
    private static final String PATH        = "path";

    // constructor used internally (not externalized since it takes
    // an ID code point)
    AFPResource(AS400 system, NPCPIDAFPResource id, NPCPAttribute attrs)
    {
        super(system, id, attrs, NPConstants.RESOURCE);
    }


    /**
     * Constructs an AFPResource object. The system and the
     * integrated file system name of the AFP resource must be set
     * later. This constructor is provided for visual application
     * builders that support JavaBeans. It is not intended for use
     * by application programmers.
     *
     * @see PrintObject#setSystem
     * @see #setPath
     **/
    public AFPResource()
    {
        super(null, null, NPConstants.RESOURCE);

        // Because of this constructor we will need to check the
        // run time state of AFPResource objects.
    }



    /**
     * Constructs an AFPResource object. It uses the system and
     * resource name that identify it on that system.
     * The system referenced by system must be at V3R7 or later to
     * support using AFP resources.
     *
     * @param system The system on which this AFP resource exists.
     * @param resourceName The integrated file system name of the AFP resource. The format of
     * the resource string must be in the format of "/QSYS.LIB/libname.LIB/resourcename.type".
     * Valid values for type include FNTRSC, FORMDF, OVL, PAGSEG, and PAGDFN.
     *
     **/
    public AFPResource(AS400 system,
                       String resourceName)
    {
        super(system, buildIDCodePoint(resourceName), null, NPConstants.RESOURCE);

        // The base class constructor checks for null system.
        // QSYSObjectPathName() checks for a null resourceName.
    }



    private static NPCPIDAFPResource buildIDCodePoint(String IFSResourceName)
    {
        QSYSObjectPathName ifsPath = new QSYSObjectPathName(IFSResourceName);

        return new NPCPIDAFPResource(ifsPath.getObjectName(),
                                     ifsPath.getLibraryName(),
                                     ifsPath.getObjectType());
    }


    /**
     * Chooses the appropriate implementation.
     **/
    void chooseImpl()
    throws IOException, AS400SecurityException
    {
        // We need to get the system to connect to...
        AS400 system = getSystem();
        if (system == null) {
            Trace.log( Trace.ERROR, "Attempt to use AFPResource before setting system." );
            throw new ExtendedIllegalStateException("system",
                                    ExtendedIllegalStateException.PROPERTY_NOT_SET);
        }

        impl_ = (PrintObjectImpl) system.loadImpl2("com.ibm.as400.access.AFPResourceImplRemote",
                                                   "com.ibm.as400.access.AFPResourceImplProxy");
        super.setImpl();
    }



    /**
      * Returns an input stream that can be used to read the contents of the
      * AFP resource.
      *
      * @return The input stream object that can be used to read the contents
      *         of this AFP resource.
      * @exception AS400Exception If the system returns an error message.
      * @exception AS400SecurityException If a security or authority error occurs.
      * @exception ErrorCompletingRequestException If an error occurs before the request completed.
      * @exception IOException If an error occurs while communicating with the system.
      * @exception InterruptedException If this thread is interrupted.
      * @exception RequestNotSupportedException If the requested function is not supported because
      *                                         the system operating system is not at the correct level.
      **/
    public PrintObjectInputStream getInputStream()
        throws AS400Exception,
               AS400SecurityException,
               ErrorCompletingRequestException,
               IOException,
               InterruptedException,
               RequestNotSupportedException
    {
        PrintObjectInputStream is = new PrintObjectInputStream(this, null);
        return is;
    }



    /**
     * Returns the name of the AFP resource.
     *
     * @return The name of the AFP resource.
     **/
    public String getName()
    {
        NPCPID IDCodePoint = getIDCodePoint();

        if( IDCodePoint == null ) {
            return PrintObject.EMPTY_STRING; // ""
        } else {
            return IDCodePoint.getStringValue(ATTR_RSCNAME);
        }
    }



    /**
     * Returns the integrated file system pathname of the AFP resource.
     *
     * @return The integrated file system pathname of the AFP resource.
     **/
    public String getPath()
    {
        // the type of an AFP resource is stored as an INT so we
        // use the special getResourceType() method to get that

        NPCPID IDCodePoint = getIDCodePoint();

        if( IDCodePoint == null ) {
            return PrintObject.EMPTY_STRING; // ""
        } else {
            return QSYSObjectPathName.toPath(
              IDCodePoint.getStringValue(ATTR_RSCLIB),   // library name
              IDCodePoint.getStringValue(ATTR_RSCNAME),  // resource name
              ((NPCPIDAFPResource)(IDCodePoint)).getResourceType() ); // type as String
        }
    }



    /**
     * Sets the integrated file system pathname of the AFP resource.
     *
     * @param path The integrated file system name of the AFP resource. The format of
     * the resource string must be in the format of "/QSYS.LIB/libname.LIB/resourcename.type".
     * Valid values for type include FNTRSC, FORMDF, OVL, PAGSEG, and PAGDFN.
     *
     * @exception PropertyVetoException If the change is vetoed.
     **/
    public void setPath(String path)
      throws PropertyVetoException
    {
        if( path == null )
        {
            Trace.log( Trace.ERROR, "Parameter 'path' is null" );
            throw new NullPointerException( PATH );
        }

        // check for connection...
        if (impl_ != null) {
            Trace.log(Trace.ERROR, "Cannot set property 'path' after connect.");
            throw new ExtendedIllegalStateException( PATH , ExtendedIllegalStateException.PROPERTY_NOT_CHANGED );
        }

        String oldPath = getPath();

        // Tell any vetoers about the change. If anyone objects
        // we let the PropertyVetoException propagate back to
        // our caller.
        vetos.fireVetoableChange( PATH, oldPath, path );

        // no one vetoed, make the change
        setIDCodePoint(buildIDCodePoint(path));

        // Notify any property change listeners
        changes.firePropertyChange( PATH, oldPath, path );
    }

} // end AFPResource class




© 2015 - 2025 Weber Informatics LLC | Privacy Policy