You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@camel.apache.org by "Claus Ibsen (JIRA)" <ji...@apache.org> on 2013/09/29 11:57:24 UTC

[jira] [Resolved] (CAMEL-6798) JPAComponent: unable to find EntityManagerFactory in JNDIRegistry

     [ https://issues.apache.org/jira/browse/CAMEL-6798?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Claus Ibsen resolved CAMEL-6798.
--------------------------------

    Resolution: Duplicate
      Assignee: Claus Ibsen

There is another JIRA about JNDIRegistry should be improved to implement these methods also. 

> JPAComponent: unable to find EntityManagerFactory in JNDIRegistry
> -----------------------------------------------------------------
>
>                 Key: CAMEL-6798
>                 URL: https://issues.apache.org/jira/browse/CAMEL-6798
>             Project: Camel
>          Issue Type: Bug
>          Components: camel-core, camel-jpa
>    Affects Versions: 2.12.0, 2.12.1
>            Reporter: Alessandro Baldoni
>            Assignee: Claus Ibsen
>
> When using a JNDIRegistry in a Camel context to make a JPA EntityManagerFactory available to a JPAComponent (required when running Camel in a Java EE container), the JPAComponent is unable to find it due do this line:
>             Map<String, EntityManagerFactory> map = getCamelContext().getRegistry().findByTypeWithName(EntityManagerFactory.class);
> since the method findByTypeWithName in JNDIRegistry is unimplemented (returns a null map).
> This forces to fallback to a SimpleRegistry or to a Spring registry, thus making impossible to use the JAVA EE container JNDI registry.
> Proposted solution: At present, JNDI does not allow lookups based on a class.
> My suggestion is to lookup the EntityManagerFactory by a standard name, such as when looking for the default persistence unit name (and eventually adding a property for the JPA URL in order to use a custom name).



--
This message was sent by Atlassian JIRA
(v6.1#6144)