Skip to content

Latest commit

 

History

History
 
 

cdi-decorator

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

cdi-decorator: Demostrates CDI Decorator

Author: Ievgen Shulga
Level: Intermediate
Technologies: CDI, JSF
Summary: The cdi-decorator quickstart demonstrates the use of a CDI Decorator to intercept bean methods and modify the business logic.
Target Product: WildFly
Source: https://github.com/wildfly/quickstart/

What is it?

The cdi-decorator quickstart demonstrates the use of CDI Decorator in Red Hat JBoss Enterprise Application Platform.

It represents a common decorator design pattern. We take a class and we wrap decorator class around it. When we call the class, we always pass through the surrounding decorator class before we reach the inner class. In this example, the decorator class simply changes the staff bonus from '100' to '200' and the staff position from 'Java Developer' to 'Team Lead'. It then logs a message to the server console.

By default, all decorators are disabled, so application will run without using decorator. We need to enable our decorator in the 'beans.xml' descriptor to make it work.

System requirements

The application this project produces is designed to be run on Red Hat JBoss Enterprise Application Platform 7 or later.

All you need to build this project is Java 8.0 (Java SDK 1.8) or later and Maven 3.1.1 or later. See Configure Maven for WildFly 10 to make sure you are configured correctly for testing the quickstarts.

Use of WILDFLY_HOME

In the following instructions, replace WILDFLY_HOME with the actual path to your WildFly installation. The installation path is described in detail here: Use of WILDFLY_HOME and JBOSS_HOME Variables.

Start the WildFly Server

  1. Open a command prompt and navigate to the root of the WildFly directory.

  2. The following shows the command line to start the server:

     For Linux:   WILDFLY_HOME/bin/standalone.sh
     For Windows: WILDFLY_HOME\bin\standalone.bat
    

Build and Deploy the Quickstart

  1. Make sure you have started the WildFly server as described above.

  2. Open a command prompt and navigate to the root directory of this quickstart.

  3. Type this command to build and deploy the archive:

     mvn clean install wildfly:deploy
    
  4. This will deploy target/wildfly-cdi-decorator.war to the running instance of the server.

Access the application

The application will be running at the following URL: http://localhost:8080/wildfly-cdi-decorator.

You can specify decorator of the bean in the WEB-INF/beans.xml file by doing one of the following:

  1. You can add a decorators tag and specify a decorator class.
  2. You can specify a different decorator class name in the decorators tag.

For this example, uncomment the <decorators> tag in the WEB-INF/beans.xml file and redeploy the application. When you access the application, you will see changed information from web-browser and following in the server log: CDI decorator method was called!

In order to switch back to the default implementation, comment the 'decorators' block in the WEB-INF/beans.xml file and redeploy the quickstart.

Undeploy the Archive

  1. Make sure you have started the WildFly server as described above.

  2. Open a command prompt and navigate to the root directory of this quickstart.

  3. When you are finished testing, type this command to undeploy the archive:

     mvn wildfly:undeploy
    

Run the Quickstart in Red Hat JBoss Developer Studio or Eclipse

You can also start the server and deploy the quickstarts or run the Arquillian tests from Eclipse using JBoss tools. For general information about how to import a quickstart, add a WildFly server, and build and deploy a quickstart, see Use JBoss Developer Studio or Eclipse to Run the Quickstarts

Debug the Application

If you want to debug the source code of any library in the project, run the following command to pull the source into your local repository. The IDE should then detect it.

mvn dependency:sources