You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@cayenne.apache.org by "Andrus Adamchik (JIRA)" <ji...@apache.org> on 2010/02/28 14:00:05 UTC

[jira] Closed: (CAY-1394) DI-based replacement for JNDI hack

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

Andrus Adamchik closed CAY-1394.
--------------------------------

       Resolution: Fixed
    Fix Version/s: 3.1M1

> DI-based replacement for JNDI hack
> ----------------------------------
>
>                 Key: CAY-1394
>                 URL: https://issues.apache.org/jira/browse/CAY-1394
>             Project: Cayenne
>          Issue Type: Task
>          Components: Core Library
>    Affects Versions: 3.1M1
>            Reporter: Andrus Adamchik
>            Assignee: Andrus Adamchik
>             Fix For: 3.1M1
>
>
> Cayenne up to 3.0 supported emulation of JNDI DataSource for local work based on the Modeler preferences (aka "JNDI hack"):
> http://cayenne.apache.org/doc30/using-jndi.html
> In 3.1, Modeler preferences are implemented differently, using "java.util.prefs", and instead of porting the JNDI hack to the new mechanism, I will provide a more sensible replacement, based on JVM startup properties. The name of the new DS factory  will be PropertyDataSourceFactory. PropertyDataSourceFactory will be used to override not only JNDI DataSources, but any other DataSource configured in the Modeler.
> The property names will be the same as the properties used in unit testing:
> http://cayenne.apache.org/running-unit-tests.html
> But with a few changes:
> * we'll support  dot notation, not capitalized notation. Dot notation is traditional Java property naming approach, while capitalized notation was introduced to be able to run unit tests on Hudson that breaks on dot notation.
> * property names will allow an (optional) suffix with <domain_name>.<node_name> to make sure multiple connections can be specified per JVM. 
> * cayenne.jdbc.driver[.domain_name.node_name]
> * cayenne.jdbc.url[.domain_name.node_name]
> * cayenne.adapter[.domain_name.node_name]
> * cayenne.jdbc.username[.domain_name.node_name]
> * cayenne.jdbc.password[.domain_name.node_name]
> * cayenne.jdbc.min.connections[.domain_name.node_name]
> * cayenne.jdbc.max.conections[.domain_name.node_name]
> At the minimum, cayenne.jdbc.url and cayenne.jdbc.driver must be present for the overrides to kick in.

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.