This chapter introduces the basic concepts necessary to use the XEO framework an XEO's approach to development.
XEO was designed from scratch with the purpose of modelling business (real-world) entities using an object oriented approach, as the team felt that that was the most natural way of developing a web-application. Being able to create an entity, its data model and web pages for listing all instances of that entity (with powerful options such as ordering and grouping), editing single instances and searching a particular instance, while still being able to use customized logic to implement behavior, without dealing with all the low-level complexities was truly the ultimate goal.
Developing starts by defining a set of entities (XEO Object Models) and their properties, using XEO Studio's Object Model editor (basically a graphic editor for a specific XML language). Those entities are processed by the framework in a processes known as "XEO Build" which generates the data model, and support classes to interact with the entities. Using the Object Model as a base, web viewers for listing, edit and search instances can be "scaffolded" (ala Ruby on Rails) by XEO Studio.
As seen above, using XEO is all about modelling business entities as XEO Object Models, which will be used by the framework to create the data model, logic and web layer for each of those entities, which can then be further customized to fit the business logic of the application. Let's begin with the basics of a XEO Object Model.
An Object Model is the XEO representation of a business entity. Almost every business entity can be described in a number of "atributes" and relations with other entities (be it relations of extension, 1-1 relation, or 1-N relation). For example, if we're modelling a entity that represents a "Book" in real life, that book would probably have attributes such as the book's title, the author's name, the edition number or category list (drama, romance, etc...) of the book.
In a XEO Object Model, attributes modelling the properties of a business entity can be of different types. XEO provides attributes that represent Textual values ( AttributeText), Numeric Values ( AttributeNumber), Date and Time values ( AttributeDate and AttributeDateTime), Sequential Values ( AttributeSequence), Long textual values ( AttributeLongText) and Boolean values ( AttributeBoolean) as well as attributes to make a 1:1 relation (single relation - AttributeObject) and to make a 1:N relation (a relation to a collection of objects - AttributeObjectCollection)
Each of those types of attribute have specific properties which can be set to customize their behavior, which we'll see further in the documentation. These properties vary with the type of attribute, naturally. For example, a Numeric Value can have a property maxValue and minValue (which specify maximum and maximum values for the attribute) while a collection attribute can have the maximum number of objects to which the first can relate to (or declare the type of objects to which the first can relate to)
One of the defining features of XEO is the possibility to associate business logic directly to the Object Models, and also with their attributes. By allowing business logic to be "embedded" in the Object Model, instances of a given model are now almost like "living entities" which respond to events and have customized actions all without complex code managing events handling and etc. Custom Business Logic is defined using the Java Language and interaction with the current instance object (or other objects) can be done by using XEO's Java API. Such logic can influence the viewer layer, because logic can determine whether a given object/attribute is visible, required, etc...
Let's take a look at the possibilities for defining business logic in an Object Model.
Attributes themselves can have logic associated. For example, a given attribute may have a default value that is calculated, or its value may need be validated when its value is changed (and that validation, may required more or less complicated operations).
Attributes can have logic to define the following
Every instance of an Object Model can react (i.e. execute Java code) to certain actions in its life cycle. Each action generates two events (an onBeforeAction event and an onAfterAction event) in which you can write your code, the list of actions (and events) is as follows:
Each onBeforeEvent returns a boolean value. If the returned value is true, the action (load, create, save, destroy) associated with the event is carried on, otherwise the action is not executed (this allows, for example, to control when an object is to be deleted, if all required conditions for that to happen are met)
In the following figure is depicted the XEO Events mechanims and when they are triggered given a certain action performed on an instance object.
Attributes may also react to events triggered by actions made upon the attributes and there are three groups of events available. The first group of events (regular events) is applicable to all attributes, except collection attribute (AttributeObjectCollection), the second group is only applicable to collection attributes (collection events) and the last group contains the events that are common to all attributes (common events). The List is as follows:
Regular Events:
Collection Events:
Common Events:
aaa
Most often, business entities modeled in an application have logic associated with them (i.e. entities are not just there to represent the data model). Often enough, that logic is decoupled from the entity model due to constraints of the programming language/framework used to create that application. Using XEO, entity business logic can be created right along side the model of the entity, in the form of "Methods". Methods are entry-points in a XEO Object Model to declare business logic associated to the entity; those methods will be available in all instance objects and can perform any desired actions.
Imagine, for example we're dealing with Invoices (each Invoice has several "Invoice Lines" each of those lines has a state indicating whether it has been processed or not). The Invoice entity has a flag (true/false) which determines when that Invoice has been processed (an Invoice is considered processed when all its items [Invoice Lines] have been processed). At a given point in time in the application, some action occurs and the consequence of that action is that a given invoice should be considered "processed". Using XEO Methods, we can defne a processInvoice method (which will available to all instance of the Invoice Object Model) that will check every Invoice Line of the instance and set its processed attribute to true and in the end, change the processed attribute of the Invoice to true.
By declaring a method in a XEO Object Model that behavior is now available in every instance of the Object Model; furthermore if that Object Model is used in another application that behavior is taken along with the Model definition, there's no need to "hunt down" the code in the application logic layer.
In the figure bellow is depicted how the process of defining and invoking a XEO Method on an instance object.
One important factor when creating a business application is security (including permissions). XEO has a feature named Object Policy Labeling (OPL) which helps to create a permission system for Object Instances.
When defining a XEO Object Model, we can determine who has the permission to read the instances, change the instances, delete the instances or have full control over instances, these are called "AttributeKeys".
A note before explaining the OPL mechanism: The XEO framework includes some System Object Models which represent entities such as Users, Groups and Profiles and those Object Models are required to set the OPL mechanism (worry not, because it's possible to use your own users/groups with OPL)
The main idea is to give read/write/delete/full control permissions to instances of a User/Group/Role Object Model which means a given XEO Model must declare an AttributeObject relation to a User/Group/Role and then a read/write/delete/full control permission can be given to the
The following figure depicts and example of OPL usage.
There's also the possibility to create user-defined permissions by implementing specific interfaces. Implementing these interfaces allows great liberty for developers which may defined complex permission rules, such as "a given group can only change objects on even days between 13:00 and 15:42", these are known as ClassKeys (will be explained in another Chapter)
Most object-oriented languages have concepts like Inheritance and Interfaces. XEO being a Java-based framework makes use of those concepts in its XEO Object Models.
When creating a new XEO Object Model we can extend an existing Object Model (and inheriting all of its attributes, events and methods). If required all of these can be overridden in the new Object Model. Extension can be seen just like in a regular object oriented programming language (although there's no multiple inheritance, like in C++).
A XEO Interface is similar in objectives to a Java Interface, meaning that Object Models that implement the XEO Interface share the same type, but contrary to Java Interfaces, in XEO Interfaces you can define regular object attributes, events and methods and when an object implements the interface it will inherit all of the interface's attributes, events and methods.
In most applications there's a notion of entities that can only exist if a another entity exists, or more properly, an instance of an entity can only exist if another instance of an entity exists, frequently this is called a parent-child relationship where the child cannot exist without its parent.
XEO Object Models can be logically grouped in XEO Packages (more or less like Java Packages) which
The XEO Builder is responsible for ....
Aqaaaa
List Viewer
Edit Viewer
Lookup Viewer
No permission to view TWiki.WebTopBar