The UserBean class manages the communication between the UI and the server. Once you instantiate the user object, it is available for both of them.
That's why when you run it, the Name | E-mail is already filled (the user object is instantiated when the UserBean class is created by the server).
We associated the userAction() method from the UserBean class to the Validate button of the UI:
<h:commandButton value="Validate" action="#{userBean.userAction()}"/>
You can create other methods in UserBean and do the same to empower your application.
The whole core of our recipe is represented by just a single line in the UI:
<h:inputText id="userNameEmail" value="#{userBean.user}" converter="userConverter" validator="userValidator"/>
So, our two implemented interfaces used here are userConverter and userValidator.
Basically, the UserConverter class (with getAsString and getAsObject methods) converts an object to/from a string and vice versa, according to the logic defined by you.
We have just mentioned it in the preceding code snippet:
value="#{userBean.user}"
The server uses the userConverter object, calls the getAsString method, and prints the result using the preceding expression language.
Finally, the UserValidator class is automatically called when you submit the form, by calling its validate method, and applying the rules defined by you.