Create new JBoss Tools Documentation Jira issue

This will launch the Jboss Tools Jira page - to complete your feedback please login if needed, and submit the Jira.

JBoss.orgCommunity Documentation

Smooks Dev Tools Reference Guide

Version: 1.1.0.CR1

November 2008


1. Introduction
1.1. Key Features of Smooks Tools
1.2. What is Smooks?
1.3. What is Smooks Tools?
1.4. How to install Smooks dev tools?
2. Quick Start
2.1. Download Smooks Java-to-Java Example
2.2. Mapping rules
2.3. Smooks Configuration File Wizard
2.4. Smooks Editor
2.4.1. Adding the input data
2.4.2. Adding the target Bean
2.5. Mapping
3. Smooks Design Page
3.1. Selector generate dialog
3.2. Smooks Parse Type
3.3. Import Smooks Configuration page
3.4. File selection
4. Smooks Source Editor Page
4.1. XML Source Editor
4.2. Error underlining in Graphical Editor
4.3. Smooks Configuration File Validator

This chapter gives you a short introduction to Smooks, Smooks tools and its installation.

First, have a look at the key features of Smooks tools:

The Smooks tools was included by the JBoss Tools since 3.0.0 Beta1 version. You can download the JBoss Tools from JBoss download site.

Smooks tools (JBoss Tools) run with the latest Eclipse and other required plug-ins (GEF, EMF, etc.).

You should download the latest IDE for Java EE developers from Eclipse site. It contains many plug-ins ( GEF, EMF, etc. ) required by Smooks dev tools.

Now let's progress to more advanced topics.

This "Quick Start" will show how to use the Smooks tools to create/edit the Smooks configuration file for Java2Java data transformation.

This chapter gives you a brief understanding of the Smooks tools.

Visit smooks examples page to download the "java-to-java" example project.

Tip:

The example project is based on Maven, we suggest you to create a new eclipse Java project, copy the example code and .jar files from the example project and paste them into the eclipse Java project.

At the begining of working with Smooks tools, we need to understand the Java-to-Java mapping rules of this example. The transform input Java class is example.sourcemodel.Order , its structure looks like this :


Let's describe the structure of example.sourcemodel.Order in short:

  • Order class contains a Header class and a List class.

  • The Header class has customerName,customerNumber,priority as properties.

  • In Order class the objects of the OrderItem class are stored in the List.

  • OrderItem has price,productId,quantity as its properties.

Let's look at the transform target Java class : LineOrder.

On the screen below you can see its structure:


  • LineOrder class contains 3 properties:customerId,customerName,priority and an array of lineItems.

  • The Header class has customerName,customerNumber,priority as its properties.

  • OrderItem objects are stored in a List.

Now it's the time to define the mapping rules to transform the input source java class to the target java class:

  • Each instance of the Order class should be mapped with an instance of the LineOrder class.

  • The value of customerName of the Header class should be assigned to the customerName property of a LineOrder instance.

  • The value of customerNumber of the Header class should be assigned to the customerId property of a LineOrder instance.

  • The value of priority of the Header class should be assigned to the priority property of LineOrder instance.

  • For the orderitems List of the Order instance, it's necessary to map a new lineItems array instance of LineOrder , and each OrderItem instance in the orderItems List should be transformed to a LineItem instance, those instances will be put into the lineItems array.

  • The value of productId of the OrderItem instance should be assigned to the 'productCode' of LineItem.

  • The value of price of OrderItem should be assigned to the unitPrice of LineItem.

When all the wizard steps are passed, a new Smooks Configuration file is created and the Smooks Configuration Editor will be opened automatically:


On the bottom of this editor there are 5 tabs, they are : Overview, Reader, Message Filter, Graph, Source.

After adding the input data, let's switch to the Message Filter page:


Click the Add button, the Add Child wizard page will be shown, let's select the Java Binding v1.2 -> Bean v1.2 and click OK to add the Bean :


Then we can find on the Message Filter page the Bean v1.2 item added, click on it ,a Bean v1.2 section should appear to the right of the page. The section represents a GUI for editing Bean v1.2 properties:


You should input lineOrder as the Bean's id in the "Bean Id" field.Then you should click Browse button near the Class textfield and select LineOrder as the Bean's class.

Note

When you enter a value for the Class text field, you can type 'Alt + /' and the content assist pop dialog will be shown, so it's will increase the efficiency. If 'Alt + /' doesn't work, try to use the 'Ctrl + space'('Key Assist' of Eclipse).

Let's click the Add Binding link at the bottom of this page, it will show a dialog to ask the binding of what Bean properties you will prefer to add. Select all and click OK, you will see a list of Binding elements added under the Bean item.

Then you should add an array of beans called lineItems and a Bean LineItem.These two classes and Id values are:

Array Bean:

  • BeanId : lineItems;

  • Class : example.trgmodel.LineItem[]

LineItem Bean :

  • BeanId : lineItem;

  • Class : example.trgmodel.LineItem

Note

In Smooks , to be an array of Beans , the class value should end with '[]'. This means that this bean is an array type.

To finish this work, use the Add Binding link to add all the bindings for the Bean.

How to map the java class just added?

First, you should know what to transform:

Make sense? You should open Design tab and click Add button. In opened Add Child Wizard,please, select Add Smooks Resource>Java Binding>Bindings.

First of all, you should bind Order to LineOrder. To do this one Bindings Item should be added to the Resource List.


Click on it and you should see Bindings Section to the right of Message Filtering Resources.Write lineOrder in the Bean id field.

Select example.trgmodel.LineOrder in the Class field and example.srcmodel.Order in the Name field.Your Smooks Configuration Editor should look like this:


Now you should bind two values "customerNumber" property of the Order#header to the "customerId" property of LineOrder.To do this right click your just created Bindings Item >Add Smooks Resource>Value .


Note:

Please, remember that the root nodes of the source data and target data *MUST* be connected.

This rule is not only for Java-to-Java, but also is relevant for XML-to-Java

Do the same operation with the other properties in this and other classes.

It's also necessary to bind orderItems property of the Order to lineItems property of LineOrder.The difference from the previous steps is that the orderItems is presented by the list of Order and lineItems is the massive of LineItem .To do the binding,you should use Wiring Item.First you should create a new Binding item. This is a configuration that allows you to construct an object graph .Select example.trgmodel.LineItem[] in the Class field and orderItems in the Name field,in bean Id write lineItems. Your Smooks Configuration Editor should look like this:


Then you should right click lineOrder binding item >Add Smooks Resource>Wiring.Select lineItem in Bean id Ref.

The final step is to add new Wiring item to lineOrder Binding.In the Bean id Ref select lineItems and in Property select lineItems.

Now, you should save the file and the Smooks tools generate the correct configuration file content.

OK, let run the test class: example.Main. (Please, make sure that the Smooks engine loads the correct configuration file).

Success!

In this section you will explore the details of Smooks Design Page usage.

Smooks Design Page is one tab of the Smooks Editor.


This page consists of 3 sections: Message Filtering Resources, Input Data and the section devoted to the configurations of a selected in a Message Filtering Resources section Item.

You can bind classes using Bindings item on the Design page of the Smooks Editor.

Resource list item in Message Filtering Resources corresponds to the root element of the smooks-config.xml file.You can configurate the next four properties using corresponding fields:

  • default-selector:Defines the selector that will be applied to all resource-config elements in the smooks-config.xml, where a selector is not defined.

  • default-selector-namespace:Defines the default selector namespace.

  • default-target-profile: Defines the default target profile that will be applied to all resources in the smooks-config.xml.

  • default-condition-ref:The condition is applied to resources where an empty "condition" element (i.e. <condition/>)is defined.The condition element does not reference a globally defined condition.

The configuration editor also edits the Smooks parse type and manages the Import Files.

This section provides information about Smooks Source Editor Page.