Chapter 2. Creating Enterprise Bean Projects
2.1. Create an EJB Archive Project Using Red Hat CodeReady Studio
This task describes how to create an Enterprise JavaBeans (EJB) project in Red Hat CodeReady Studio.
Prerequisites
- A server and server runtime for JBoss EAP have been configured in Red Hat CodeReady Studio.
Create an EJB Project in Red Hat CodeReady Studio
- Open the New EJB Project wizard. - Navigate to the File menu, select New, then select Project.
- When the New Project wizard appears, select EJB/EJB Project and click Next. - Figure 2.1. New EJB Project Wizard 
 
- Enter the following details: - Project name: The name of the project that appears in Red Hat CodeReady Studio, and also the default file name for the deployed JAR file.
- Project location: The directory where the project files will be saved. The default is a directory in the current workspace.
- Target runtime: This is the server runtime used for the project. This will need to be set to the same JBoss EAP runtime used by the server that you will be deploying to.
- EJB module version: This is the version of the EJB specification that your enterprise beans will comply with. Red Hat recommends using 3.2.
- Configuration: This allows you to adjust the supported features in your project. Use the default configuration for your selected runtime. - Click Next to continue. 
 
- The Java project configuration screen allows you to add directories containing Java source files and specify the directory for the output of the build. - Leave this configuration unchanged and click Next. 
- In the EJB Module settings screen, check Generate ejb-jar.xml deployment descriptor if a deployment descriptor is required. The deployment descriptor is optional in EJB 3.2 and can be added later if required. - Click Finish and the project is created and will be displayed in the Project Explorer. - Figure 2.2. Newly Created EJB Project in the Project Explorer 
- To add the project to the server for deployment, right-click on the target server in the Servers tab and choose Add and Remove. - In the Add and Remove dialog, select the resource to deploy from the Available column and click the Add button. The resource will be moved to the Configured column. Click Finish to close the dialog. - Figure 2.3. Add and Remove Dialog 
You now have an EJB project in Red Hat CodeReady Studio that can build and deploy to the specified server.
If no enterprise beans are added to the project then Red Hat CodeReady Studio will display the warning stating An EJB module must contain one or more enterprise beans. This warning will disappear once one or more enterprise beans have been added to the project.
2.2. Create an EJB Archive Project in Maven
This task demonstrates how to create a project using Maven that contains one or more enterprise beans packaged in a JAR file.
Prerequisites
- Maven is already installed.
- You understand the basic usage of Maven.
Create an EJB Archive Project in Maven
- Create the Maven project: An EJB project can be created using Maven’s archetype system and the - ejb-javaee7archetype. To do this run the- mvncommand with parameters as shown:- mvn archetype:generate -DarchetypeGroupId=org.codehaus.mojo.archetypes -DarchetypeArtifactId=ejb-javaee7 - $ mvn archetype:generate -DarchetypeGroupId=org.codehaus.mojo.archetypes -DarchetypeArtifactId=ejb-javaee7- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Maven will prompt you for the - groupId,- artifactId,- versionand- packagefor your project.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
						Add your enterprise beans: Write your enterprise beans and add them to the project under the src/main/javadirectory in the appropriate sub-directory for the bean’s package.
- 
						Build the project: To build the project, run the mvn packagecommand in the same directory as thepom.xmlfile. This will compile the Java classes and package the JAR file. The built JAR file is named-.jarand is placed in thetarget/directory.
You now have a Maven project that builds and packages a JAR file. This project can contain enterprise beans and the JAR file can be deployed to an application server.
2.3. Create an EAR Project Containing an EJB Project
This task describes how to create a new enterprise archive (EAR) project in Red Hat CodeReady Studio that contains an EJB project.
Prerequisites
- A server and server runtime for JBoss EAP have been set up.
Create an EAR Project Containing an EJB Project
- Open the New Java EE EAR Project Wizard. - Navigate to the File menu, select New, then select Project.
- When the New Project wizard appears, select Java EE/Enterprise Application Project and click Next.
 - Figure 2.4. New EAR Application Project Wizard 
- Enter the following details: - Project name: The name of the project that appears in Red Hat CodeReady Studio, and also the default file name for the deployed EAR file.
- Project location: The directory where the project files will be saved. The default is a directory in the current workspace.
- Target runtime: This is the server runtime used for the project. This will need to be set to the same JBoss EAP runtime used by the server that you will be deploying to.
- EAR version: This is the version of the Java Enterprise Edition specification that your project will comply with. Red Hat recommends using Java EE 8.
- Configuration: This allows you to adjust the supported features in your project. Use the default configuration for your selected runtime. - Click Next to continue. 
 
- Add a new EJB module. - New modules can be added from the Enterprise Application page of the wizard. To add a new EJB Project as a module follow the steps below: - Click New Module, uncheck Create Default Modules checkbox, select the Enterprise Java Bean and click Next. The New EJB Project wizard appears.
- The New EJB Project wizard is the same as the wizard used to create new standalone EJB Projects and is described in Create an EJB Archive Project Using Red Hat CodeReady Studio. - The minimum details required to create the project are: - Project name
- Target runtime
- EJB module version
- Configuration - All the other steps of the wizard are optional. Click Finish to complete creating the EJB Project. - The newly created EJB project is listed in the Java EE module dependencies and the checkbox is checked. 
 
 
- Optionally, add an - application.xmldeployment descriptor.- Check the Generate application.xml deployment descriptor checkbox if one is required. 
- Click Finish. - Two new projects will appear: the EJB project and the EAR project. 
- Add the build artifact to the server for deployment. - Open the Add and Remove dialog by right-clicking in the Servers tab on the server you want to deploy the built artifact to in the server tab and then select Add and Remove. - Select the EAR resource to deploy from the Available column and click the Add button. The resource will be moved to the Configured column. Click Finish to close the dialog. 
Figure 2.5. Add and Remove Dialog
You now have an Enterprise Application Project with a member EJB Project. This will build and deploy to the specified server as a single EAR deployment containing an EJB subdeployment.
2.4. Add a Deployment Descriptor to an EJB Project
An EJB deployment descriptor can be added to an EJB project that was created without one. To do this, follow the procedure below.
Prerequisites
- You have a EJB project in Red Hat CodeReady Studio to which you want to add an EJB deployment descriptor.
Add a Deployment Descriptor to an EJB Project
- Open the project in Red Hat CodeReady Studio.
- Add a deployment descriptor. - Right-click on the Deployment Descriptor folder in the project view and select Generate Deployment Descriptor tab. - Figure 2.6. Adding a Deployment Descriptor - The new file, - ejb-jar.xml, is created in- ejbModule/META-INF/. Double-click on the Deployment Descriptor folder in the project view to open this file.
 
     
     
     
     
    