org.apache.tools.ant.taskdefs.optional.ejb
public class WebsphereDeploymentTool extends GenericDeploymentTool
deployment
. This step can be performed by the websphere
element as part of the jar generation process. If the switch
ejbdeploy
is on, the ejbdeploy tool from the websphere toolset
is called for every ejb-jar. Unfortunately, this step only works, if you
use the ibm jdk. Otherwise, the rmic (called by ejbdeploy) throws a
ClassFormatError. Be sure to switch ejbdeploy off, if run ant with
sun jdk.
Nested Class Summary | |
---|---|
static class | WebsphereDeploymentTool.DBVendor
Enumerated attribute with the values for the database vendor types
|
Field Summary | |
---|---|
static String | PUBLICID_EJB11 |
static String | PUBLICID_EJB20 |
protected static String | SCHEMA_DIR |
protected static String | WAS_BND |
protected static String | WAS_CMP_MAP |
protected static String | WAS_CMP_SCHEMA |
protected static String | WAS_EXT |
Method Summary | |
---|---|
protected void | addVendorFiles(Hashtable ejbFiles, String baseName)
Add any vendor specific files which should be included in the EJB Jar. |
Path | createWASClasspath() Get the classpath to the websphere classpaths |
protected ClassLoader | getClassLoaderFromJar(File classjar)
Helper method invoked by isRebuildRequired to get a ClassLoader for a
Jar File passed to it.
|
protected DescriptorHandler | getDescriptorHandler(File srcDir) |
protected String | getOptions()
Gets the options for the EJB Deploy operation
|
protected DescriptorHandler | getWebsphereDescriptorHandler(File srcDir) |
protected boolean | isRebuildRequired(File genericJarFile, File websphereJarFile)
Helper method to check to see if a websphere EBJ1.1 jar needs to be
rebuilt using ejbdeploy. |
void | setCodegen(boolean codegen)
Flag, default false, to only generate the deployment
code, do not run RMIC or Javac
|
void | setDbname(String dbName)
Sets the name of the Database to create; optional.
|
void | setDbschema(String dbSchema)
Sets the name of the schema to create; optional.
|
void | setDbvendor(WebsphereDeploymentTool.DBVendor dbvendor) Sets the DB Vendor for the Entity Bean mapping ; optional.
|
void | setEjbdeploy(boolean ejbdeploy)
Decide, wether ejbdeploy should be called or not;
optional, default true.
|
void | setEJBdtd(String inString)
Setter used to store the location of the Sun's Generic EJB DTD. |
void | setKeepgeneric(boolean inValue)
This controls whether the generic file used as input to
ejbdeploy is retained; optional, default false. |
void | setNewCMP(boolean newCMP)
Set the value of the newCMP scheme. |
void | setNoinform(boolean noinform)
Flag to disable informational messages; optional, default false.
|
void | setNovalidate(boolean novalidate)
Flag to disable the validation steps; optional, default false.
|
void | setNowarn(boolean nowarn)
Flag to disable warning and informational messages; optional, default false.
|
void | setOldCMP(boolean oldCMP)
Set the value of the oldCMP scheme. |
void | setQuiet(boolean quiet)
Flag, default true, to only output error messages.
|
void | setRebuild(boolean rebuild)
Set the rebuild flag to false to only update changes in the jar rather
than rerunning ejbdeploy; optional, default true. |
void | setRmicoptions(String options)
Set the rmic options.
|
void | setSuffix(String inString)
String value appended to the basename of the deployment
descriptor to create the filename of the WebLogic EJB
jar file. |
void | setTempdir(String tempdir)
The directory, where ejbdeploy will write temporary files;
optional, defaults to '_ejbdeploy_temp'. |
void | setTrace(boolean trace)
Flag to enable internal tracing when set, optional, default false.
|
void | setUse35(boolean attr)
Flag to use the WebSphere 3.5 compatible mapping rules ; optional, default false.
|
void | setWASClasspath(Path wasClasspath) |
void | validateConfigured()
Called to validate that the tool parameters have been configured. |
protected void | writeJar(String baseName, File jarFile, Hashtable files, String publicId)
Method used to encapsulate the writing of the JAR file. |
Parameters: classjar java.io.File representing jar file to get classes from.
Returns: String
The way websphere ejbdeploy works is it creates wrappers for the publicly defined methods as they are exposed in the remote interface. If the actual bean changes without changing the the method signatures then only the bean classfile needs to be updated and the rest of the websphere jar file can remain the same. If the Interfaces, ie. the method signatures change or if the xml deployment descriptors changed, the whole jar needs to be rebuilt with ejbdeploy. This is not strictly true for the xml files. If the JNDI name changes then the jar doesnt have to be rebuild, but if the resources references change then it does. At this point the websphere jar gets rebuilt if the xml files change at all.
Parameters: genericJarFile java.io.File The generic jar file. websphereJarFile java.io.File The websphere jar file to check to see if it needs to be rebuilt.
Parameters: codegen option
Parameters: dbName name of the database
Parameters: dbSchema name of the schema
Parameters: ejbdeploy
Parameters: inString the string to use as the DTD location.
Parameters: inValue either 'true' or 'false'.
Parameters: noinform if true disables informational messages
Parameters: novalidate option
Parameters: nowarn option
UNKNOWN: ignore="true"
Parameters: quiet option
Parameters: options
Parameters: inString the string to use as the suffix.
Parameters: trace
Parameters: attr