ATG products are packaged as a number of separate application modules. Application modules exist in the ATG installation as a set of directories defined by a manifest file.
To create a new module, follow the below steps :
How to create an ATG ear ?
To create an ATG ear module, your web.xml should contain some basic elements. To use ATG platform functionality, a web application needs to start Nucleus by invoking NucleusServlet. So it should be included in the web.xml to load on start up.
<servlet>
<servlet-name>NucleusServlet</servlet-name>
<servlet-class>atg.nucleus.servlet.NucleusServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
Also the following tag lib alias name should be given to call the dsp tags.
<taglib>
<taglib-uri>/dspTaglib</taglib-uri>
<taglib-location>/WEB-INF/tld/dspjspTaglib1_0.tld</taglib-location>
</taglib>
To create a new module, follow the below steps :
- Create a module directory within your ATG installation.
- Create a META-INF directory within the module directory. Note that this directory must be named META-INF.
- Create a manifest file named MANIFEST.MF and include it in the META-INF directory for the module. The manifest contains the meta-data describing the module.
- A module located at <ATG2007.1dir>/MyModule is named MyModule and a module located at <ATG2007.1dir>/CustomModules/MyModule is named CustomModules.MyModule.
- Within the subdirectory that holds the module, any number of files may reside in any desired order. These files are the module resources (EAR files for J2EE applications, WAR files for web applications, EJB-JAR files for Enterprise JavaBeans, JAR files of Java classes, platform-dependent libraries, HTML documentation, configuration files,...)
Manifest-Version: 1.0
ATG-Config-Path: config/
ATG-Required: mycomp.my-commerce mycomp.my-search-query
ATG-J2EE: j2ee-apps/my-estore
ATG-EAR-Module: j2ee-apps/my-estore
ATG-Class-Path: lib
- ATG-Required --> A space-delimited set of module names. Here we will define the other modules that need to be included in this module. When the application is started up, the module’s manifest is processed after the manifests of the modules that the module depends on. Note that in most cases, you should set this attribute to include the out of the box module DSS. DSS has ATG required DPS and DPS module has DAS.
- ATG-Config-Path --> Check the ATG-Config-Path for the property files for this module.
- ATG-Class-Path --> The ATG platform adds the ATG-Class-Path value to the beginning of the EAR file’s classpath as each module is processed. Paths are relative to the module’s root directory.
How to create an ATG ear ?
To create an ATG ear module, your web.xml should contain some basic elements. To use ATG platform functionality, a web application needs to start Nucleus by invoking NucleusServlet. So it should be included in the web.xml to load on start up.
<servlet>
<servlet-name>NucleusServlet</servlet-name>
<servlet-class>atg.nucleus.servlet.NucleusServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
Also the following tag lib alias name should be given to call the dsp tags.
<taglib>
<taglib-uri>/dspTaglib</taglib-uri>
<taglib-location>/WEB-INF/tld/dspjspTaglib1_0.tld</taglib-location>
</taglib>
To assemble the ATG application, we can use the "runAssembler.bat" available @ ATG\ATG2007.1\home\bin\runAssembler.bat location. The basic syntax of the command follows this format : runAssembler earfilename –m module-list . Each EAR file built by runAssembler includes the following J2EE modules:
You can create two types of EAR files with the ATG application assembler, development and standalone. Both types contain all ATG classes needed for the application. The primary difference is in where the configuration files for Nucleus components are stored. In development mode, the application draws its Nucleus configuration information from the ATG installation folders. In standalone mode, the application stores its configuration in the EAR file itself.
The main differences between development-mode and standalone-mode EAR files are found in the WEB-INF/ATG-INF directory of the atg_bootstrap.war J2EE module. In this directory, both types of EAR files have a file called dynamo.env, which defines Dynamo environment properties. In a development-mode EAR, the dynamo.env file contains the following entry, which tells the application to get its configuration from the .properties and XML files in the ATG installation : atg.dynamo.use-install=true. So in development-mode you can make configuration changes without having to rebuild the EAR file.
- atg_bootstrap_ejb.jar: This module contains a single session EJB. The EJB’s class loader is used to load the ATG classes needed by the application.
- atg_bootstrap.war: This module starts up Nucleus and runs the DAF servlet pipeline and the DAS servlet pipeline (for JHTML).
- The EAR file can optionally include Dynamo Administration, which is packaged as a web application named atg_admin.war and you must specify the DafEar.Admin module when you run the application assembler to include Dynamo Administration.
You can create two types of EAR files with the ATG application assembler, development and standalone. Both types contain all ATG classes needed for the application. The primary difference is in where the configuration files for Nucleus components are stored. In development mode, the application draws its Nucleus configuration information from the ATG installation folders. In standalone mode, the application stores its configuration in the EAR file itself.
The main differences between development-mode and standalone-mode EAR files are found in the WEB-INF/ATG-INF directory of the atg_bootstrap.war J2EE module. In this directory, both types of EAR files have a file called dynamo.env, which defines Dynamo environment properties. In a development-mode EAR, the dynamo.env file contains the following entry, which tells the application to get its configuration from the .properties and XML files in the ATG installation : atg.dynamo.use-install=true. So in development-mode you can make configuration changes without having to rebuild the EAR file.
very good explanation...Thanks ..Thomas
ReplyDeleteGreat information for starters. I appreciate you work for us. Thanks a lot!
ReplyDeleteReally Good explanation Mr.Thomas. Thanks
ReplyDeletenice
ReplyDelete