Saturday, 14 May 2016

Hybris:       Jalo Layer:
             The Jalo Layer is the traditional hybris Commerce Suite functional layer. It combines data model aspects and business logic aspects. "Jalo" is short for "Jakarta Logic". "Jakarta" being the original name of the hybris Platform.
·         Schematic Overview

·         Using the Jalo Layer

·         Usage Example 


Schematic Overview
The hybris Jalo Layer offers an API to clients using the hybris Commerce Suite and abstracts from the database. It also covers two major aspects of the hybris Commerce Suite:
·         Data Model, which you can define in the items.xml files in the form of types and attributes.
·         Business Logic, which you implement in Java classes. 
For each type defined in the items.xml file, the hybris Commerce Suite's Build Framework generates two Java files:
·         Abstract Java class: Automatically generated by the hybris Commerce Suite Build Framework and generated again on every hybris Commerce Suite build. Abstract Java classes contain automatically-generated getter and setter methods for the defined type attributes in the items.xml file.
·         Non-Abstract Java class: Extends from the abstract Java class. Non-Abstract Java classes are only generated by the hybris Commerce Suite Build Framework if they are non-existent. Non-Abstract Java classes are not overwritten during hybris Commerce Suite builds.

Figure: Overview of the Jalo Layer
See Also
The hybris Jalo Layer is a tight coupling between data model and business logic, as the implemented business logic in Java classes that are generated are based on the data model. If the data model changes, your business logic might need adaption as well. For example, if you rename a type, the Java classes have to be renamed too. For a more loose coupling between data model and business logic, see ServiceLayer.
You can implement Java classes that are not backed by the data model, but the instances are runtime objects only and are not persistent. An example for such non-persistent Java classes is the JaloSession.
Using the Jalo Layer
The basic workflow of using the Jalo layer is as follows:
·         Define your data model in terms of types and attributes using the items.xml file.
·         Build the hybris Commerce Suite to have the Java classes generated.
·         Implement business logic in the non-abstract Java class.
Usage Example
This section demonstrates a concrete example of using the hybris Jalo Layer.
The following items.xml file sample defines the type MyType with a single String attribute, MyAttribute:

<itemtype code="MyType" autocreate="true" generate="true"
    jaloclass="de.hybris.jalolayer.sample.MyType">
    <attributes>
        <attribute type="java.lang.String" qualifier="MyAttribute">
            <persistence type="property" />
        </attribute>
    </attributes>
</itemtype>

Running a build of the hybris Commerce Suite will result in two Java classes being generated:

Fully Qualified Java Class Name
Path and File Name
Description
de.hybris.jalolayer.sample.GeneratedMyType
gensrc/de/hybris/jalolayer/sample/GeneratedMyType.java
Abstract Java class, containing getter and setter methods for MyAttribute such as:
·         public String getMyAttribute(final SessionContext ctx)
·         public String getMyAttribute()
·         public void setMyAttribute(final SessionContext ctx, final String value)
·         public void setMyAttribute(final String value)
de.hybris.jalolayer.sample.MyType
src/de/hybris/jalolayer/sample/MyType.java
Non-abstract Java class extendingGeneratedMyType. Here you can implement your business logic and optionally override the getter and setter methods for MyAttribute if you need special business logic for that.

for more informayion about jalo layer goto wiki