Passing a JSF2 managed pojo bean into EJB or putting what is required into a transfer object
Asked Answered
A

2

1

Currently i am calling EJB 3 Session Beans from JSF 2. However, i am not sure if i should be passing JSF managed beans into EJB?

Assuming that whatever on the form (and thus the backing bean) was everything i needed to persist through the EJB layer, should i clone out all the attributes by hand into a transfer object, or is there a better way of doing this?

The backing bean though POJO is heavily annotated with JSF lifecycle tags (Such as @ManagedBean) and resides in the Web project while the EJBs reside separately in the EJB project.

Anacrusis answered 12/2, 2012 at 3:17 Comment(0)
J
7

It sounds like as if you've tight-coupled the model with the controller like as shown in most basic JSF tutorials. You should decouple the model from the controller into its own class. As you're using EJBs, the chance is big that you're also using JPA (how else would EJBs be really useful for persistence?), you can just use the existing JPA @Entity class as model.

E.g.

@Entity
public class Product {

    @Id
    private Long id;
    private String name;
    private String description;
    private Category category;

    // ...
}

with

@ManagedBean
@ViewScoped
public class ProductController {

    private Product product;

    @EJB
    private ProductService service;

    public void save() {
        service.save(product);
    }

    // ...
}

which is to be used as

<h:form>
    <h:inputText value="#{productController.product.name}" />
    <h:inputTextarea value="#{productController.product.description}" />
    <h:selectOneMenu value="#{productController.product.category}">
        <f:selectItems value="#{applicationData.categories}" />
    </h:selectOneMenu>
    <h:commandButton value="Save" action="#{productController.save}" />
</h:form>
Jori answered 12/2, 2012 at 13:4 Comment(6)
Hi BalusC, thanks, i tried an implementation similar to this after reading one of your replies in other threads. Just curious, wouldn't Product also need to be annotated as a Managed bean, i think in my previous attempt i hit some exception because i did not annotate Product as Managed bean.Anacrusis
No, definitely not. That problem must be caused by something else. Perhaps you attempted to use #{product} elsewhere while it's not available in the scope at all.Jori
@Jori so it means we should normally have three classes: 1. The view (Product), 2. The service, which will handle the DAO and 3. the controller which will be the one accessible by the XHTML. For every view, I should have a service and a controller, right?Torpedoman
@Erick: The service is not tied to the view. It's tied to the model. In other words, you can just reuse models and services on other views (and controllers).Jori
Yes sorry. I meant to say that for every model, I should have a service and a controllerTorpedoman
@Torpedoman I believe he meant that for every model you should have a service, period. The "controllers" (ie, the backing beans) are tied to the XHMTL views, and can import as many services as they need. A Sales view dealing with both Products and Clients will possibly call all 3 services.Hillman
S
0

I was trying to do the same with CDI and the main diffrence (excluding using @Named instead of @ManagedBean) was that I had to initialize my transport object in the Controller class.

So instead of:

private Product product;

I had to use:

private Product product = new Product();

Maybe it will help someone :)

Stilted answered 18/2, 2014 at 13:39 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.