Skip to main content

Importance of Facade Layer

I still remember that around mid 2013, I was arguing for the same concept of Facade layer in our application in my earlier company. I was unable to digest the importance of Facade layer, so I was of firm opinion that Facade layer is unnecessary and should not be used!!

After 3 years, today when I was working on some code I realized that if we would have used Facade layer in our application then my work would have been much simpler than what I was doing...

Structure of our application -


Controllers/CommandHandlers
                                                  | <----- Aspect execute at here
Service Layer
|
Accessor/DAO
|             |
DB      Server

This is the structure of our application, in which Service layer handles the gathering and processing of data from DB and server process.
We have a concept of MSU, where our application hosted of a central server gathers data from various servers and shows it on the centralized server. Now when call from controller or command handler goes to service layer, our custom Aspect comes into picture and performs the same operation for various servers mapped into our application.
Now this operation can be of four types -


  1. Local only
  2. Local or remote
  3. Local and remote
  4. Remote only
Depending upon the parameter configured in the Annotation aspect, this aspect executes this call of service layer on various servers.

Today when I was working on one of call, which has very heavy processing in service layer I remembered my discussion with one of my colleague or rather my oppose to the use of Facade layer in our application.
I realized that, it would have been very much beneficial if we would have had the following kind of structure of our application.

Controllers/CommandHandlers
                                                                    | <----- Aspect would have executed here
Facade Layer
|
Service Layer
|
Accessor/DAO
|             |
DB      Server
In this case it would have been so easy for our to intercept the facade calls and execute them on various servers without worrying about the heavy processing in the service layer. Well, I would like to also add the point which my colleague was telling me in this discussion, that Facade layer helps to write more testable code(I still do not agree fully on this point yet). 
But surely it helps to segregate the code from the service layer and controller layer which can be very helpful in situations like us.

Comments

Popular posts from this blog

Java Tools Plugin for Notepad++

This post and the plugin is outdated. Please use plugin from this link which is updated and allows customization of shortcut key mappings and much more . Notepad++ is a great free editor. I like notepad++ because its a light weight editor and loads instantly. I use notepad++ for editing many files everyday. One plugin I always wanted was a plugin which lets me compile my java files and execute them from editor itself, but I couldn't find it so I wrote a myself. This plugin can be downloaded from  this link . I am working on this plugin to make it more effective, so that if user have more than one installations of JDK or JRE then user should be able to choose which one to use etc. This is a simple plugin which has two commands- Compile - compiles a java file. Run - executes a java file. For using this plugin Java must be installed on the system.

Encrypt Decrypt data using AES in Java

AES stands for Advanced Encryption Standard. AES is an Symmetric Key Algorithm, that means key used for encrypting the data, same key will be used for  decryption of  the encrypted data. This algorithm supplants DES algorithm. This post shows how to use AES algorithm in Java to encrypt and decrypt data. Encrypting Data- import java.security.GeneralSecurityException; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; public class AESTest1 { public static void main(String[] args) throws GeneralSecurityException { KeyGenerator keyGenerator = KeyGenerator.getInstance("AES"); keyGenerator.init(128); SecretKey key = keyGenerator.generateKey(); Cipher cipher = Cipher.getInstance("AES"); cipher.init(Cipher.ENCRYPT_MODE, key); byte encryptedData[] = cipher.doFinal(args[0].getBytes()); } } In above example we have used KeyGenerator class, which generates key for encrypting data, as we are using...

Java Tools Plugin for Notepad++ Update

This post and the plugin is outdated. Please use plugin from  this link  which is updated and allows customization of shortcut key mappings and much more . This post is regarding the update for Notepad++ plugin which I wrote to use compile and execute Java programs from the Notepad++ editor itself. I have updated the plugin so that user can customize the shortcut keys assigned for compiling and executing the programs. Following image shows simple Settings dialog where you can customize the shortcut keys mapping. Although user can customize the keys but to apply them Notepad++ must be restarted. Well, I tried but in Notepad++, there is no way to change mapping after initialization process of plugin.. Click here to download the plugin.