Book Image

Drools JBoss Rules 5.X Developer's Guide

By : Michal Bali
Book Image

Drools JBoss Rules 5.X Developer's Guide

By: Michal Bali

Overview of this book

<p>Writing business rules has always been a challenging task. Business rules tend to change often leading to a maintenance nightmare. This book shows you various ways to code your business rules using Drools, the open source Business Rules Management System.<br /><br />Drools JBoss Rules 5.X Developer's Guide shows various features of the Drools platform by walking the reader through several real-world examples. Each chapter elaborates on different aspects of the Drools platform. The reader will also learn about the inner workings of Drools and its implementation of the Rete algorithm.<br /><br />The book starts with explaining rule basics, then builds on this information by going through various areas like human readable rules, rules for validation, and stateful rules, using examples from the banking domain. A loan approval process example shows the use of the jBPM module. Parts of a banking fraud detection system are implemented with the Drools Fusion module which is the complex event processing part of Drools. Finally, more technical details are shown detailing the inner workings of Drools, the implementation of the ReteOO algorithm, indexing, node sharing, and partitioning.</p>
Table of Contents (22 chapters)
Drools JBoss Rules 5.X Developer's Guide
Credits
About the Author
About the Reviewers
www.PacktPub.com
Preface
Setting Up the Development Environment
Creating Custom Operators
Dependencies of Sample Application
Index

Summary


Let's look at what we've achieved in this chapter. By separating the validation rules from the rest of the application, we've made it easier for others to identify and understand them. Because of the declarative nature of rules, they can be maintained and refactored more easily. We can easily change rules or add new ones without increasing the overall complexity.

A simple extensible reporting model was defined and later used in the customer validation rules. Throughout this chapter a stateless session has been used, which is ideal for this type of decision rules. Remember that it is stateless only because it doesn't hold state between invocations. A special feature of a stateless session is that it can be executed in sequential mode, which has performance benefits for very simple rules. We've learned about the KnowledgeHelper object, which is present in every rule consequence as a convenient helper class. We've discussed the use of a validation report as a global variable versus being...