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

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

///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: SpooledFile.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.io.ObjectInputStream;
import java.io.UnsupportedEncodingException;

/**
 * Represents a spooled file.
 * You can use an instance of this class to manipulate an individual
 * spooled file (hold, release, delete, send, read, and so on).
 * To create new spooled files on the system, use the
 * {@link SpooledFileOutputStream SpooledFileOutputStream} class.
 *
 * See Spooled File Attributes for
 * valid attributes.
 *
 * @see PrintObjectInputStream
 * @see PrintObjectPageInputStream
 * @see PrintObjectTransformedInputStream
 **/

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

    transient boolean fMsgRetrieved_  = false;

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


    // We have decide that spooled files are too transient to be JavaBeans.


    /**
     * Constructs a SpooledFile object. It uses the specified system and
     * spooled file attributes that identify it on that system.
     *
     * @param system The system on which this spooled file exists.
     * @param name The name of the spooled file.
     * @param number The number of the spooled file.
     * @param jobName The name of the job that created the spooled file.
     * @param jobUser The user who created the spooled file.
     * @param jobNumber The number of the job that created the spooled file.
     *
     **/
    public SpooledFile(AS400 system,
                       String name,
                       int    number,
                       String jobName,
                       String jobUser,
                       String jobNumber)
    {
        super(system,
              new NPCPIDSplF(name,
                             number,
                             jobName,
                             jobUser,
                             jobNumber),
              null,
              NPConstants.SPOOLED_FILE);

        // base class constructor checks for null system.
        if (name == null)
        {
            Trace.log(Trace.ERROR, "Parameter 'name' is null.");
            throw new NullPointerException("name");
        }

        if (number < -1)    // (changed from 1 to -1 to allow 0(=*ONLY) and -1(=*LAST))
        {
            Trace.log(Trace.ERROR, "Parameter 'number' is less than -1.");
            throw new ExtendedIllegalArgumentException(
                "number(" + number + ")",
                ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
        }

        if (jobName == null)
        {
            Trace.log(Trace.ERROR, "Parameter 'jobName' is null.");
            throw new NullPointerException("jobName");
        }

        if (jobUser == null)
        {
            Trace.log(Trace.ERROR, "Parameter 'jobUser' is null.");
            throw new NullPointerException("jobUser");
        }

        if (jobNumber == null)
        {
            Trace.log(Trace.ERROR, "Parameter 'jobNumber' is null.");
            throw new NullPointerException("jobNumber");
        }
    }
    
    // Alternate constructor for spooled files detached from jobs
    /**
     * Constructs a SpooledFile object. It uses the specified system and
     * spooled file attributes that identify it on that system.
     *
     * @param system The system on which this spooled file exists.
     * @param name The name of the spooled file.
     * @param number The number of the spooled file.
     * @param jobName The name of the job that created the spooled file.
     * @param jobUser The user who created the spooled file.
     * @param jobNumber The number of the job that created the spooled file.
     * @param jobSysName The name of the system where the spooled file was created.
     * @param createDate The date the spooled file was created on the system.
     * 
* The date is encoded in a character string with the following format, * CYYMMDD where: *
    *
  • C is the Century, where 0 indicates years 19xx and 1 indicates years 20xx *
  • YY is the Year *
  • MM is the Month *
  • DD is the Day *
* @param createTime The time the spooled file was created on the system. *
* The time is encoded in a character string with the following format, * HHMMSS where: *
    *
  • HH - Hour *
  • MM - Minutes *
  • SS - Seconds *
**/ public SpooledFile(AS400 system, String name, int number, String jobName, String jobUser, String jobNumber, String jobSysName, String createDate, String createTime) { super(system, new NPCPIDSplF(name, number, jobName, jobUser, jobNumber, jobSysName, createDate, createTime), null, NPConstants.SPOOLED_FILE); // base class constructor checks for null system. if (name == null) { Trace.log(Trace.ERROR, "Parameter 'name' is null."); throw new NullPointerException("name"); } if (number < -1) // (changed from 1 to -1 to allow 0(=*ONLY) and -1(=*LAST)) { Trace.log(Trace.ERROR, "Parameter 'number' is less than -1."); throw new ExtendedIllegalArgumentException( "number(" + number + ")", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID); } if (jobName == null) { Trace.log(Trace.ERROR, "Parameter 'jobName' is null."); throw new NullPointerException("jobName"); } if (jobUser == null) { Trace.log(Trace.ERROR, "Parameter 'jobUser' is null."); throw new NullPointerException("jobUser"); } if (jobNumber == null) { Trace.log(Trace.ERROR, "Parameter 'jobNumber' is null."); throw new NullPointerException("jobNumber"); } if (jobSysName == null) { Trace.log(Trace.ERROR, "Parameter 'jobSysName' is null."); throw new NullPointerException("jobSysName"); } if (createDate == null) { Trace.log(Trace.ERROR, "Parameter 'createDate' is null."); throw new NullPointerException("createDate"); } if (createTime == null) { Trace.log(Trace.ERROR, "Parameter 'createTime' is null."); throw new NullPointerException("createTime"); } } /** Replies to the message that caused the spooled file to wait. * * @param reply The string that contains the reply for the message. * The default reply can be obtained by calling * the getMessage() method, and then calling the * getDefaultReply() method on the message object that is returned. * Other possible replies are given in the message help, * which can also be retrieved from the message object returned * on the getMessage() method. * * @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 is * 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 is not at the correct level. **/ public void answerMessage(String reply) throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException, RequestNotSupportedException { if (impl_ == null) chooseImpl(); ((SpooledFileImpl) impl_).answerMessage(reply); // update the spooled file attributes attrs = impl_.getAttrValue(); fMsgRetrieved_ = ((SpooledFileImpl) impl_).getFMsgRetrieved(); } /** * Chooses the 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 SpooledFile before setting system." ); throw new ExtendedIllegalStateException("system", ExtendedIllegalStateException.PROPERTY_NOT_SET); } impl_ = (SpooledFileImpl) system.loadImpl2("com.ibm.as400.access.SpooledFileImplRemote", "com.ibm.as400.access.SpooledFileImplProxy"); // The connectService(AS400.PRINT) is done in setImpl() // in the Printobject class. super.setImpl(); } /** * Creates a copy of the spooled file this (SpooledFile) object represents. The * new spooled file is created on the same output queue and on the same system * as the original spooled file. A reference to the new spooled file is returned. * @return SpooledFile * * @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 is 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 is not at the correct level. **/ public SpooledFile copy() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException, RequestNotSupportedException { String name = getStringAttribute(ATTR_OUTPUT_QUEUE); OutputQueue outq = new OutputQueue(getSystem(), name); SpooledFile sf = copy(outq); return sf; } /** * Creates a copy of the spooled file this object represents. The * new spooled file is created on the specified output queue. * A reference to the new spooled file is returned. * * @param outputQueue The output queue location to create the new version of the * original spooled file. The spooled file will be created to the first * position on this output queue. The output queue and this spooled * file must reside on the same system. * @return SpooledFile * * @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 is 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 is not at the correct level. **/ public SpooledFile copy(OutputQueue outputQueue) throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException, RequestNotSupportedException { // choose implementations if (impl_ == null) { chooseImpl(); } if (outputQueue.getImpl() == null) { outputQueue.chooseImpl(); } NPCPIDSplF spID = ((SpooledFileImpl) impl_).copy((OutputQueueImpl)outputQueue.getImpl()); try { spID.setConverter((new Converter(getSystem().getCcsid(), getSystem())).impl); } catch (UnsupportedEncodingException e) { if (Trace.isTraceErrorOn()) { Trace.log(Trace.ERROR, "Error initializing converter for spooled file."); } } SpooledFile sf = new SpooledFile(getSystem(), spID, null); return sf; } /** * Deletes the spooled file on the system. * * @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 is completed. * @exception IOException If an error occurs while communicating with the system. * @exception InterruptedException If this thread is interrupted. **/ public void delete() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException { if (impl_ == null) chooseImpl(); ((SpooledFileImpl) impl_).delete(); } /** * Returns an input stream that can be used to read the contents of the * spooled file. * This method will fail with an AS400Exception if the spooled file is * still being created (ATTR_SPLFSTATUS is *OPEN). * Note that the bytes are returned untransformed, that is, as they are * stored on the server. To transform the bytes into other forms, use * {@link #getPageInputStream getPageInputStream} or * {@link #getTransformedInputStream getTransformedInputStream}. * * @return The input stream object that can be used to read the contents * of this spooled file. * @exception AS400Exception If system returns an error message. * @exception AS400SecurityException If a security or authority error occurs. * @exception ErrorCompletingRequestException If an error occurs before the request is 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 is not at the * correct level. * @see #getPageInputStream * @see #getTransformedInputStream **/ public PrintObjectInputStream getInputStream() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException, RequestNotSupportedException { PrintObjectInputStream is = new PrintObjectInputStream(this, null); return is; } /** * Returns an input stream that can be used to read the contents of the * spooled file. * This method will fail with an AS400Exception if the spooled file is * still being created (ATTR_SPLFSTATUS is *OPEN). * Note that the bytes are returned untransformed, that is, as they are * stored on the server. To transform the bytes into other forms, use * {@link #getPageInputStream getPageInputStream} or * {@link #getTransformedInputStream getTransformedInputStream}. * @param ppl print parameter list * * @return The input stream object that can be used to read the contents * of this spooled file. * @exception AS400Exception If system returns an error message. * @exception AS400SecurityException If a security or authority error occurs. * @exception ErrorCompletingRequestException If an error occurs before the request is 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 is not at the * correct level. * @see #getPageInputStream * @see #getTransformedInputStream **/ public PrintObjectInputStream getInputStream(PrintParameterList ppl) throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException, RequestNotSupportedException { PrintObjectInputStream is = new PrintObjectInputStream(this, ppl); return(is); } /** * @param acifB * @return PrintObjectInputStream * @throws AS400Exception If an error occurs. * @throws AS400SecurityException If a security or authority error occurs. * @throws ErrorCompletingRequestException If an error occurs before the request is completed. * @throws IOException If an error occurs while communicating with the system. * @throws InterruptedException If this thread is interrupted. * @throws RequestNotSupportedException If the request is not supported. * @deprecated Use getAFPInputStream() instead. * @see #getAFPInputStream **/ public PrintObjectInputStream getInputACIFMergedStream(boolean acifB) throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException, RequestNotSupportedException { String acifS; // possible open options that we could use - // acifB == true then process ACIF merged data // else normal processing if (acifB){ acifS = "Y"; } else acifS = "N"; PrintObjectInputStream is = new PrintObjectInputStream(this, null, acifS); return is; } /** * Returns an input stream that can be used to read the contents of an * AFP spooled file. The external resources referenced by the original * AFP spooled file will be included in this input stream. If you don't want * the external resources included use * {@link #getInputStream getInputStream} or * {@link #getPageInputStream getPageInputStream}. * This method will fail with an AS400Exception if the spooled file is * still being created (ATTR_SPLFSTATUS is *OPEN) or if the spooled file * doesn't contain AFDS data ie. ATTR_PRTDEVTYPE is not *AFPDS. * * @return The input stream object that can be used to read the contents * of this spooled file. * @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 is 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. * @see #getInputStream * @see #getPageInputStream **/ public PrintObjectInputStream getAFPInputStream() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException, RequestNotSupportedException { PrintObjectInputStream is = new PrintObjectInputStream(this, null, "Y"); return is; } /** * Returns the name of the job that created the spooled file. * @return The job name. **/ public String getJobName() { NPCPID IDCodePoint = getIDCodePoint(); if( IDCodePoint == null ) { return EMPTY_STRING; // "" } else { return IDCodePoint.getStringValue(ATTR_JOBNAME); } } /** * Returns the number of the job that created the spooled file. * @return The job number. **/ public String getJobNumber() { NPCPID IDCodePoint = getIDCodePoint(); if( IDCodePoint == null ) { return EMPTY_STRING; // "" } else { return IDCodePoint.getStringValue(ATTR_JOBNUMBER); } } /** * Returns the ID of the user that created the spooled file. * @return The user ID. **/ public String getJobUser() { NPCPID IDCodePoint = getIDCodePoint(); if( IDCodePoint == null ) { return EMPTY_STRING; // "" } else { return IDCodePoint.getStringValue(ATTR_JOBUSER); } } // The next three attributes are added to provide the // decoupled spooled file identity. /** * Returns the name of the system where the spooled file was created. * @return The name of the system where the spooled file was created. **/ public String getJobSysName() { String jobSysName = EMPTY_STRING; NPCPID IDCodePoint = getIDCodePoint(); if (IDCodePoint == null) { return(jobSysName); } else { jobSysName = IDCodePoint.getStringValue(ATTR_JOBSYSTEM); if (jobSysName == null) { try { jobSysName = this.getStringAttribute(ATTR_JOBSYSTEM); } catch (Exception e) { // ignore exceptions, splf may not have this attr. jobSysName = EMPTY_STRING; } } return(jobSysName); } } /** * Returns the date of the spooled file creation. * The date is encoded in the CYYMMDD format. * @return The date (CYYMMDD) of the spooled file creation. **/ public String getCreateDate() { String createDate = EMPTY_STRING; NPCPID IDCodePoint = getIDCodePoint(); if (IDCodePoint == null) { return(createDate); } else { createDate = IDCodePoint.getStringValue(ATTR_DATE); if (createDate == null) { try { createDate = this.getStringAttribute(ATTR_DATE); } catch (Exception e) { // ignore exceptions, splf may not have this attr. createDate = EMPTY_STRING; } } return(createDate); } } /** * Returns the time of spooled file creation. * The time is encoded in the HHMMSS format. * @return The time (HHMMSS) of the spooled file creation. **/ public String getCreateTime() { String createTime = EMPTY_STRING; NPCPID IDCodePoint = getIDCodePoint(); if (IDCodePoint == null) { return(createTime); } else { createTime = IDCodePoint.getStringValue(ATTR_TIME); if (createTime == null) { try { createTime = this.getStringAttribute(ATTR_TIME); } catch (Exception e) { // ignore exceptions, splf may not have this attr. createTime = EMPTY_STRING; } } return(createTime); } } /** * Returns the message that is associated with this spooled file. * A spooled file has a message associated with it if its * ATTR_SPLFSTATUS attribute returns *MESSAGE. * * @return The AS400Message object that contains the message text, * type, severity, id, date, time, and default reply. * @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 is completed. * @exception IOException If an error occurs while communicating with the system. * @exception InterruptedException If this thread is interrupted. **/ public AS400Message getMessage() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException { if (impl_ == null) chooseImpl(); AS400Message msg = ((SpooledFileImpl) impl_).getMessage(); fMsgRetrieved_ = ((SpooledFileImpl) impl_).getFMsgRetrieved(); return msg; } /** * Returns the name of the spooled file. * @return The name of the spooled file. **/ public String getName() { NPCPID IDCodePoint = getIDCodePoint(); if( IDCodePoint == null ) { return EMPTY_STRING; // "" } else { return IDCodePoint.getStringValue(ATTR_SPOOLFILE); } } /** * Returns the number of the spooled file. * @return The number of the spooled file. **/ public int getNumber() { NPCPID IDCodePoint = getIDCodePoint(); if( IDCodePoint == null ) { return 0; } else { return IDCodePoint.getIntValue(ATTR_SPLFNUM).intValue(); } } /** * Returns a page input stream that can be used to read the contents of the * spooled file, one page at a time. *
* See Example using PrintObjectPageInputStream *
* @param pageStreamOptions A print parameter list that contains * parameters for generating the page input stream.
* The following attributes are optional: *
    *
  • ATTR_MFGTYPE - Specifies the manufacturer type and model. *
  • ATTR_WORKSTATION_CUST_OBJECT - Specifies the integrated file system name of * the workstation customization object to be * used. The workstation customizing object * associated with the manufacturer, type, and * model is the default. *
  • ATTR_PAPER_SOURCE_1 - Specifies the paper size of drawer 1. *
  • ATTR_PAPER_SOURCE_2 - Specifies the paper size of drawer 2. *
  • ATTR_VIEWING_FIDELITY - Specifies the fidelity used to process pages. * *
* * @return A page input stream object that can be used to read the contents * of this spooled file, one page at a time. * @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 is completed, or the spooled file format is not supported. * @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 PrintObjectPageInputStream getPageInputStream(PrintParameterList pageStreamOptions) throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException, RequestNotSupportedException { PrintObjectPageInputStream is = new PrintObjectPageInputStream(this, pageStreamOptions); return is; } /** * Returns a transformed input stream that can be used to read the contents of the * spooled file. *
* See Example using PrintObjectTransformedInputStream *
* @param transformOptions A print parameter list that contains * parameters for generating the transformed input stream.
* The following attribute MUST be set: *
    *
  • ATTR_MFGTYPE - Specifies the manufacturer, type, and model. *
* The following attributes are optional: *
    *
  • ATTR_WORKSTATION_CUST_OBJECT - Specifies the integrated file system name of * the workstation customization object to be * used. The workstation customizing object * associated with the manufacturer, type, and * model is the default. *
  • ATTR_PAPER_SOURCE_1 - Specifies the paper size of drawer 1. *
  • ATTR_PAPER_SOURCE_2 - Specifies the paper size of drawer 2. * *
* * @return The transformed input stream object that can be used to read the contents * of the transformed spooled file. * @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 is completed, * or the spooled file format is not supported. * @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 PrintObjectTransformedInputStream getTransformedInputStream(PrintParameterList transformOptions) throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException, RequestNotSupportedException { PrintObjectTransformedInputStream is = new PrintObjectTransformedInputStream(this, transformOptions); return is; } /** * Holds the spooled file. * @param holdType When to hold the spooled file. * May be any of the following values: *
    *
  • *IMMED - The spooled file is held immediately. *
  • *PAGEEND - The spooled file is held at the end of the current page. *
* holdType may be null. If holdType is not specified, the default is * *IMMED. * * @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 is 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 void hold(String holdType) throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException, RequestNotSupportedException { if (impl_ == null) chooseImpl(); ((SpooledFileImpl) impl_).hold(holdType); // update the spooled file attributes attrs = impl_.getAttrValue(); } /** * Moves the spooled file to another output queue or to another * position on the same output queue. * * @param targetSpooledFile The spooled file to move this * spooled file after. The targetSpooledFile and this spooled file * must reside on the same system. * * @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 is 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 void move(SpooledFile targetSpooledFile) throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException, RequestNotSupportedException { if (impl_ == null) chooseImpl(); if (targetSpooledFile.getImpl() == null) { targetSpooledFile.chooseImpl(); } ((SpooledFileImpl) impl_).move((SpooledFileImpl)targetSpooledFile.getImpl()); //update the spooled file attributes attrs = impl_.getAttrValue(); } /** * Moves the spooled file to another output queue. * * @param targetOutputQueue The output queue to move the * spooled file to. The spooled file will be moved to the first * position on this output queue. The output queue and this spooled * file must reside on the same system. * * @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 is 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 void move(OutputQueue targetOutputQueue) throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException, RequestNotSupportedException { if (impl_ == null) chooseImpl(); if (targetOutputQueue.getImpl() == null) { targetOutputQueue.chooseImpl(); } ((SpooledFileImpl) impl_).move((OutputQueueImpl)targetOutputQueue.getImpl()); // update the spooled file attributes attrs = impl_.getAttrValue(); } /** * Moves the spooled file to the first position on the output queue. * @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 is 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 void moveToTop() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException, RequestNotSupportedException { if (impl_ == null) chooseImpl(); ((SpooledFileImpl) impl_).moveToTop(); // update the spooled file attributes attrs = impl_.getAttrValue(); } /** Restores the state of the object from an input stream. This is used when deserializing an object. @param in The input stream. @exception IOException Thrown if an IO error occurs. @exception ClassNotFoundException Thrown if class is not found. **/ private void readObject(ObjectInputStream in) throws IOException, ClassNotFoundException { in.defaultReadObject(); fMsgRetrieved_ = false; } /** * Releases a held spooled file on the system. * @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 is 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 void release() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException, RequestNotSupportedException { if (impl_ == null) chooseImpl(); ((SpooledFileImpl) impl_).release(); // update the spooled file attributes attrs = impl_.getAttrValue(); } /** * Sends the spooled file to another user on the same system or to * a remote system on the network. The equivalent of the system * Send Network Spooled File * (SNDNETSPLF) command will be issued against the spooled file. * * @param sendOptions A print parameter list that contains the * parameters for the send. The following attributes MUST be set: *
    *
  • ATTR_TOUSERID - Specifies the user ID to send the spooled file to. *
  • ATTR_TOADDRESS - Specifies the remote system to send the spooled file to. *
* The following attributes are optional: *
    *
  • ATTR_DATAFORMAT - Specifies the data format in which to transmit the * spooled file. May be either of *RCDDATA or * *ALLDATA. *RCDDATA is the default. *
  • ATTR_VMMVSCLASS - Specifies the VM/MVS SYSOUT class for distributions * sent to a VM host system or to an MVS host system. * May be A to Z or 0 to 9. A is the default. *
  • ATTR_SENDPTY - Specifies the queueing priority used for this spooled file * when it is being routed through a SNADS network. May be * *NORMAL or *HIGH. *NORMAL is the default. *
* * @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 is completed. * @exception IOException If an error occurs while communicating with the system. * @exception InterruptedException If this thread is interrupted. **/ public void sendNet(PrintParameterList sendOptions) throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException { if (impl_ == null) chooseImpl(); ((SpooledFileImpl) impl_).sendNet(sendOptions); } /** * Sends a spooled file to be printed on a remote system. * The equivalent of the Send TCP/IP Spooled File * (SNDTCPSPLF) command will be issued against the spooled file. * This is the system's version of the TCP/IP LPR command. * * @param sendOptions A print parameter list that contains the * parameters for the send. The following attributes MUST be set: *
    *
  • ATTR_RMTSYSTEM - Specifies the remote system to which the print * request will be sent. May be a remote system * name or the special value *INTNETADR. *
  • ATTR_RMTPRTQ - Specifies the name of the destination print queue. *
* The following attributes are optional: *
    *
  • ATTR_DELETESPLF - Specifies whether or not to delete the spooled file * after it has been successfully sent. May be *NO * or *YES. *NO is the default. *
  • ATTR_DESTOPTION - Specifies a destination-dependant option. These options will * be sent to the remote system with the spooled file. *
  • ATTR_DESTINATION - Specifies the type of system to which the spooled file is * being sent. When sending to other IBM i systems, this value * should be *AS/400. May also be *OTHER or *PSF/2. * *OTHER is the default. *
  • ATTR_INTERNETADDR - Specifies the Internet address of the receiving system. *
  • ATTR_MFGTYPE - Specifies the manufacturer, type, and model when transforming print * data from SCS or AFP to ASCII. *
  • ATTR_SCS2ASCII - Specifies whether the print data is to be transformed to * ASCII. May be *NO or *YES. *NO is the default. *
  • ATTR_SEPPAGE - Specifies whether to print the separator page. May be * *NO or *YES. *YES is the default. *
* * @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 is completed. * @exception IOException If an error occurs while communicating with the system. * @exception InterruptedException If this thread is interrupted. **/ public void sendTCP(PrintParameterList sendOptions) throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException { if (impl_ == null) chooseImpl(); ((SpooledFileImpl) impl_).sendTCP(sendOptions); } /** * Sets one or more attributes of the object. See * Spooled File Attributes for * a list of valid attributes that can be changed. * * @param attributes A print parameter list that contains the * attributes to be changed. * * @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 is 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 void setAttributes(PrintParameterList attributes) throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, IOException, InterruptedException, RequestNotSupportedException { if (attributes == null) { Trace.log(Trace.ERROR, "Parameter 'attributes' is null."); throw new NullPointerException("attributes"); } if (impl_ == null) chooseImpl(); ((SpooledFileImpl) impl_).setAttributes(attributes); // we changed the spooled file attributes on the system, // merge those changed attributes into our current attributes // here. if (attrs == null) { attrs = new NPCPAttribute(); } // update the spooled file attributes attrs = impl_.getAttrValue(); } } // SpooledFile class




© 2015 - 2025 Weber Informatics LLC | Privacy Policy