Remove Middle Man
Problem
A class has too many methods that simply delegate to other objects.
Solution
Delete these methods and force the client to call the end methods directly.
data:image/s3,"s3://crabby-images/cc0d4/cc0d4616d3a19be3ab92b7e9cc875316f53cc1d7" alt="Remove Middle Man - Before"
data:image/s3,"s3://crabby-images/044b1/044b1809e6dd79b76a1773eff30a49d1714803d3" alt="Remove Middle Man - After"
Why Refactor
To describe this technique, we’ll use the terms from Hide Delegate, which are:
-
Server is the object to which the client has direct access.
-
Delegate is the end object that contains the functionality needed by the client.
There are two types of problems:
-
The server-class doesn’t do anything itself and simply creates needless complexity. In this case, give thought to whether this class is needed at all.
-
Every time a new feature is added to the delegate, you need to create a delegating method for it in the server-class. If a lot of changes are made, this will be rather tiresome.
How to Refactor
-
Create a getter for accessing the delegate-class object from the server-class object.
-
Replace calls to delegating methods in the server-class with direct calls for methods in the delegate-class.