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

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

There is a newer version: 20.0.8
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: JavaProgram.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.access;

import java.io.IOException;
import java.io.Serializable;
import java.io.UnsupportedEncodingException;
import java.util.Calendar;
import java.util.Date;

/**
Represents an IBM i Java program.   This class is supported
only when connecting to systems running IBM i V5R1 or higher, and is not supported beyond IBM i 7.1.

In the context of this discussion, a "Java program" is the IBM i executable object that is created when the CRTJVAPGM (Create Java Program) CL command is run against a class, JAR, or ZIP file.
Using the JavaProgram class, you can obtain the following information about an IBM i Java program:

  • Adopted authority profile
  • File change date
  • File owner
  • Java program creation date
  • Release program was created for
  • Licensed Internal Code options
  • Number of attached java programs
  • Number of classes
  • Number of classes with current java programs
  • Number of classes without current java programs
  • Number of classes with errors
  • Optimization level
  • Path used
  • Performance Collection Enabled flag
  • Performance Collection type
  • Profiling data status
  • Size of attached java programs
  • Use adopted authority


An Example using the JavaProgram class:
// Create a JavaProgram object to refer to a specific Java program.
AS400 system = new AS400("MYSYSTEM", "MYUSERID", "MYPASSWORD");
JavaProgram javaProgram = new JavaProgram(system, "/home/mydir/HelloWorld.class");

// Get the optimization. int optimization = javaProgram.getOptimizationLevel();
// Get the file owner. String owner = javaProgram.getFileOwner();
**/ public class JavaProgram implements Serializable { static final long serialVersionUID = -209990140140936884L; private boolean loaded_ = false; // Have we retrieved values from the system yet? private AS400 system_; private String path_; private String fileOwner_; private Date fileChangeDate_; private Date javaProgramCreationDate_; private int numberOfAttachedPrograms_; private int numberOfClassesWithJavaPrograms_; private int numberOfClassesWithoutPrograms_; private int numberOfClassesWithErrors_; private int numberOfClasses_; private int optimizationLevel_; private String performanceCollectionEnabledFlag_; private String performanceCollectionType_; private boolean useAdoptedAuthority_; private String adoptedAuthorityProfile_; private int sizeOfAttachedPrograms_; private String javaProgramVersion_; private String profilingDataStatus_; private String LICoptions_; /** Constant indicating that the profile to use when the use adopted authority field is set is *USER. **/ public static final String ADOPTED_AUTHORITY_PROFILE_USER = "*USER"; /** Constant indicating that the profile to use when the use adopted authority field is set is *OWNER. **/ public static final String ADOPTED_AUTHORITY_PROFILE_OWNER = "*OWNER"; /** Constant indicating the type of performance collection is *ENTRYEXIT. **/ public static final String PERFORMANCE_COLLECTION_TYPE_ENTRYEXIT = "*ENTRYEXIT"; /** Constant indicating the type of performance collection is *FULL. **/ public static final String PERFORMANCE_COLLECTION_TYPE_FULL = "*FULL"; /** Constant indicating that profile data collection is not enabled for the the Java program(s). **/ public static final String PROFILING_DATA_STATUS_NOCOL = "*NOCOL"; /** Constant indicating that profile data collection is enabled for the attached Java program(s). **/ public static final String PROFILING_DATA_STATUS_COL = "*COL"; /** Constant indicating that profile data has been applied to the attached Java program(s). **/ public static final String PROFILING_DATA_STATUS_APY = "*APY"; /** Creates a JavaProgram **/ public JavaProgram() { } /** Creates a JavaProgram @param system The system. @param path The path. This can specify any class, jar, or zip file. **/ public JavaProgram(AS400 system, String path) { setSystem(system); setPath(path); } private void checkVRM() throws UnsupportedOperationException { try { // See if the system VRM is higher than IBM i 7.1. if (getSystem() != null && getSystem().getVRM() > 0x00070100) { Trace.log(Trace.ERROR, "JavaProgram is not supported beyond IBM i 7.1."); throw new UnsupportedOperationException("JavaProgram"); } } catch (UnsupportedOperationException e) { throw e; } catch (Exception e) { if (Trace.isTraceOn()) Trace.log(Trace.ERROR, "Error when checking system VRM.", e); UnsupportedOperationException throwException = new UnsupportedOperationException(e.getMessage()); try { throwException.initCause(e); } catch (Throwable t) {} throw throwException; } } /** Returns the name of the system. @return system name **/ public AS400 getSystem() { return system_; } /** Returns the path to a class, jar, or zip file used to create the Java program. @return path **/ public String getPath() { return path_; } /** Returns the profile to use when the "Use Adopted Authority" field is set. @return the profile to use. Possible values are:
  • {@link #ADOPTED_AUTHORITY_PROFILE_USER ADOPTED_AUTHORITY_PROFILE_USER}
  • {@link #ADOPTED_AUTHORITY_PROFILE_OWNER ADOPTED_AUTHORITY_PROFILE_OWNER}
* @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public String getAdoptedAuthorityProfile() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if (!loaded_) refresh(); if(adoptedAuthorityProfile_.equals("0")) return ADOPTED_AUTHORITY_PROFILE_USER; else return ADOPTED_AUTHORITY_PROFILE_OWNER; } /** Returns the date and time the file was last modified or changed. @return the last-changed date and time * @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public Date getFileChangeDate() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); return (Date)fileChangeDate_.clone(); } /** Returns the name of the owner of the file. The string is in job CCSID @return the file owner * @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public String getFileOwner() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); return fileOwner_; } /** Returns the date and time the Java program was created for the file. @return the creation date * @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public Date getJavaProgramCreationDate() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); return (Date)javaProgramCreationDate_.clone(); } /** Returns the IBM i version the Java program was created for. @return the version * @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public String getJavaProgramVersion() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); return javaProgramVersion_; } /** Returns the number of classes. @return the number of classes. * @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public int getNumberOfClasses() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); return numberOfClasses_; } /** Returns the number of classes with representations up-to-date in the attached Java programs. @return the number of classes with current java programs. * @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public int getNumberOfClassesWithCurrentJavaPrograms() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); return numberOfClassesWithJavaPrograms_; } /** Returns the number of classes containing errors. @return the number of classes with errors. * @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public int getNumberOfClassesWithErrors() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); return numberOfClassesWithErrors_; } /** Returns the number of classes with representations out-of-date. @return the number of classes without current java programs. * @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public int getNumberOfClassesWithoutCurrentJavaPrograms() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); return numberOfClassesWithoutPrograms_; } /** Returns the number of Java prgroams attached to the .class or .jar/sip file. @return the number of programs * @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public int getNumberOfAttachedPrograms() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); return numberOfAttachedPrograms_; } /** Returns the optimization level used to create the java program. @return the optimization level. Possible values are:
  • 0
  • 10
  • 20
  • 30
  • 40
* @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public int getOptimizationLevel() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); return optimizationLevel_; } /** Returns whether or not performance collection is enabled. @return the performance collection enabled flag. Possible values are:
  • 0 - "NONE
  • 1 - on
* @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public String getPerformanceCollectionEnabledFlag() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); return performanceCollectionEnabledFlag_; } /** Returns the type of performance collection if the performance collection flag is set. @return the type of performance collection. Possible values are:
  • {@link #PERFORMANCE_COLLECTION_TYPE_ENTRYEXIT PERFORMANCE_COLLECTION_TYPE_ENTRYEXIT}
  • {@link #PERFORMANCE_COLLECTION_TYPE_FULL PERFORMANCE_COLLECTION_TYPE_FULL}
* @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public String getPerformanceCollectionType() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); if(performanceCollectionType_.equals("0")) return PERFORMANCE_COLLECTION_TYPE_ENTRYEXIT; else return PERFORMANCE_COLLECTION_TYPE_FULL; } /** Returns whether or not the used adopted authority is set. @return true if the use adopted authority is set, false otherwise * @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public boolean isUseAdoptedAuthority() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); return useAdoptedAuthority_; } /** Returns the size in kilobytes of all the attached java programs. @return the size * @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public int getSizeOfAttachedJavaPrograms() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); return sizeOfAttachedPrograms_; } /** Returns whether profiling data is enabled or applied. @return whether profiling data is enabled or applied. Possible values are:
  • {@link #PROFILING_DATA_STATUS_NOCOL PROFILING_DATA_STATUS_NOCOL}
  • {@link #PROFILING_DATA_STATUS_COL PROFILING_DATA_STATUS_COL}
  • {@link #PROFILING_DATA_STATUS_APY PROFILING_DATA_STATUS_APY}
* @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public String getProfilingDataStatus() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); if(profilingDataStatus_.equals("0")) return PROFILING_DATA_STATUS_NOCOL; else if(profilingDataStatus_.equals("1")) return PROFILING_DATA_STATUS_COL; else return PROFILING_DATA_STATUS_APY; } /** Returns the LIC options string specified when the java program was last modified. @return the LIC options. * @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 InterruptedException If this thread is interrupted. * @throws IOException If an error occurs while communicating with the system. * @throws ObjectDoesNotExistException If the object does not exist. **/ public String getLICOptions() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if(!loaded_) refresh(); return LICoptions_; } /** Refreshes all the values for this PTF by retrieving them from the system. * @throws AS400Exception If an error occurs. * @throws AS400SecurityException If a security or authority error occurs. * @throws ConnectionDroppedException If the connection is dropped. * @throws ErrorCompletingRequestException If an error occurs before the request is completed. * @throws InterruptedException If this thread is interrupted. * @throws ObjectDoesNotExistException If the object does not exist. * @throws IOException If an error occurs while communicating with the system. * @throws UnsupportedEncodingException If the Character Encoding is not supported. **/ public void refresh() throws AS400Exception, AS400SecurityException, ConnectionDroppedException, ErrorCompletingRequestException, InterruptedException, ObjectDoesNotExistException, IOException, UnsupportedEncodingException { checkVRM(); int ccsid = system_.getCcsid(); ConvTable conv = ConvTable.getTable(ccsid, null); int len=4096; ProgramParameter[] parms = new ProgramParameter[15]; parms[0] = new ProgramParameter(len); // receiver variable parms[1] = new ProgramParameter(BinaryConverter.intToByteArray(len)); // length of receiver variable parms[2] = new ProgramParameter(conv.stringToByteArray("RJPI0100")); // format name parms[3] = new ProgramParameter(0); //Class list receiver variable parms[4] = new ProgramParameter(BinaryConverter.intToByteArray(0)); //Length of class list receiver variable parms[5] = new ProgramParameter(conv.stringToByteArray("RJPC0100")); //format of class list receiver variable parms[6] = new ProgramParameter(conv.stringToByteArray(path_)); //path name parms[7] = new ProgramParameter(BinaryConverter.intToByteArray(path_.length())); //length of path name parms[8] = new ProgramParameter(conv.stringToByteArray(" ")); //classpath parms[9] = new ProgramParameter(BinaryConverter.intToByteArray(0)); //length of classpath parms[10] = new ProgramParameter(0); //classpath used receiver variable parms[11] = new ProgramParameter(BinaryConverter.intToByteArray(0)); //length of classpath used receiver variable parms[12] = new ProgramParameter(BinaryConverter.intToByteArray(1)); //status of calsses to return in the class list parms[13] = new ProgramParameter(conv.stringToByteArray("*PGM")); //JDK version parms[14] = new ProgramParameter(BinaryConverter.intToByteArray(0)); // error code ProgramCall pc = new ProgramCall(system_, "/QSYS.LIB/QJVAMAT.PGM", parms); // Assumption of thread-safety defaults to false, or to the value of the "threadSafe" system property (if it has been set). //pc.setThreadSafe(false); if (!pc.run()) { throw new AS400Exception(pc.getMessageList()); } byte[] output = parms[0].getOutputData(); //int bytesReturned = BinaryConverter.byteArrayToInt(output, 0); //int bytesAvailable = BinaryConverter.byteArrayToInt(output, 4); fileOwner_ = conv.byteArrayToString(output, 8, 10); String d = conv.byteArrayToString(output, 18, 13); // Parse the "file change" date if (d.trim().length() == 13) { Calendar cal = AS400Calendar.getGregorianInstance(); cal.clear(); cal.set(Integer.parseInt(d.substring(0,3)) + 1900, // year Integer.parseInt(d.substring(3,5))-1, // month is zero-based Integer.parseInt(d.substring(5,7)), // day Integer.parseInt(d.substring(7,9)), // hour Integer.parseInt(d.substring(9,11)), // minute Integer.parseInt(d.substring(11,13))); // second fileChangeDate_ = cal.getTime(); } else { fileChangeDate_ = null; } d = conv.byteArrayToString(output, 31, 13); //Parse the "Java program creation" date if (d.trim().length() == 13) { Calendar cal = AS400Calendar.getGregorianInstance(); cal.clear(); cal.set(Integer.parseInt(d.substring(0,3)) + 1900, // year Integer.parseInt(d.substring(3,5))-1, // month is zero-based Integer.parseInt(d.substring(5,7)), // day Integer.parseInt(d.substring(7,9)), // hour Integer.parseInt(d.substring(9,11)), // minute Integer.parseInt(d.substring(11,13))); // second javaProgramCreationDate_ = cal.getTime(); } else { javaProgramCreationDate_ = null; } numberOfAttachedPrograms_ = BinaryConverter.byteArrayToInt(output, 44); numberOfClassesWithJavaPrograms_ = BinaryConverter.byteArrayToInt(output, 48); numberOfClassesWithoutPrograms_ = BinaryConverter.byteArrayToInt(output, 52); numberOfClassesWithErrors_ = BinaryConverter.byteArrayToInt(output, 56); numberOfClasses_ = BinaryConverter.byteArrayToInt(output, 60); optimizationLevel_ = BinaryConverter.byteArrayToInt(output, 64); performanceCollectionEnabledFlag_ = conv.byteArrayToString(output, 68, 1); performanceCollectionType_ = conv.byteArrayToString(output, 69, 1); String useAdopAuthority = conv.byteArrayToString(output, 70, 1); adoptedAuthorityProfile_ = conv.byteArrayToString(output, 71, 1); sizeOfAttachedPrograms_ = BinaryConverter.byteArrayToInt(output, 72); String version = Integer.toString( (output[76] & 0xff ) + 0x100, 16 /* radix */ ) .substring( 1 ); //get version String release = Integer.toString( (output[77] & 0xff ) + 0x100, 16 /* radix */ ) .substring( 1 ); //get release and modification javaProgramVersion_ = getVersion((version + release).toCharArray()); profilingDataStatus_ = Byte.toString(output[78]); int offsetToLICOptions = BinaryConverter.byteArrayToInt(output, 80); int lengthOfLIC = BinaryConverter.byteArrayToInt(output, 84); int lengthOfAvailableLIC = BinaryConverter.byteArrayToInt(output, 88); LICoptions_ = conv.byteArrayToString(output, offsetToLICOptions, lengthOfLIC); if(useAdopAuthority.equals("0")) useAdoptedAuthority_ = false; else useAdoptedAuthority_ = true; loaded_= true; } /** Gets the IBM i version. **/ private String getVersion(char[] version) { String v = "V"; String r = "R"; String m = "M"; if(version[0] != '0') v += version[0]; v += version[1]; r += version[2]; m += version[3]; return v+r+m; } /** Sets the name of the system to search for a Java Program. @param system The system **/ public void setSystem(AS400 system) { if(loaded_) throw new ExtendedIllegalStateException("propertiesFrozen", ExtendedIllegalStateException.PROPERTY_NOT_CHANGED); if(system == null) throw new NullPointerException("system"); system_ = system; } /** Sets the qualified path name to use. @param path - the qualified path name. **/ public void setPath(String path) { if(loaded_) throw new ExtendedIllegalStateException("propertiesFrozen", ExtendedIllegalStateException.PROPERTY_NOT_CHANGED); if (path == null) throw new NullPointerException("path"); path_ = path; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy