org.springframework.jdbc.datasource
Class UserCredentialsDataSourceAdapter

java.lang.Object
  extended by org.springframework.jdbc.datasource.DelegatingDataSource
      extended by org.springframework.jdbc.datasource.UserCredentialsDataSourceAdapter
All Implemented Interfaces:
java.sql.Wrapper, javax.sql.CommonDataSource, javax.sql.DataSource, InitializingBean
Direct Known Subclasses:
IsolationLevelDataSourceAdapter

public class UserCredentialsDataSourceAdapter
extends DelegatingDataSource

An adapter for a target JDBC DataSource, applying the specified user credentials to every standard getConnection() call, implicitly invoking getConnection(username, password) on the target. All other methods simply delegate to the corresponding methods of the target DataSource.

Can be used to proxy a target JNDI DataSource that does not have user credentials configured. Client code can work with this DataSource as usual, using the standard getConnection() call.

In the following example, client code can simply transparently work with the preconfigured "myDataSource", implicitly accessing "myTargetDataSource" with the specified user credentials.

 <bean id="myTargetDataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
   <property name="jndiName" value="java:comp/env/jdbc/myds"/>
 </bean>

 <bean id="myDataSource" class="org.springframework.jdbc.datasource.UserCredentialsDataSourceAdapter">
   <property name="targetDataSource" ref="myTargetDataSource"/>
   <property name="username" value="myusername"/>
   <property name="password" value="mypassword"/>
 </bean>

If the "username" is empty, this proxy will simply delegate to the standard getConnection() method of the target DataSource. This can be used to keep a UserCredentialsDataSourceAdapter bean definition just for the option of implicitly passing in user credentials if the particular target DataSource requires it.

Since:
1.0.2
Author:
Juergen Hoeller
See Also:
getConnection()

Nested Class Summary
private static class UserCredentialsDataSourceAdapter.JdbcUserCredentials
          Inner class used as ThreadLocal value.
 
Field Summary
private  java.lang.String password
           
private  java.lang.ThreadLocal<UserCredentialsDataSourceAdapter.JdbcUserCredentials> threadBoundCredentials
           
private  java.lang.String username
           
 
Constructor Summary
UserCredentialsDataSourceAdapter()
           
 
Method Summary
protected  java.sql.Connection doGetConnection(java.lang.String username, java.lang.String password)
          This implementation delegates to the getConnection(username, password) method of the target DataSource, passing in the specified user credentials.
 java.sql.Connection getConnection()
          Determine whether there are currently thread-bound credentials, using them if available, falling back to the statically specified username and password (i.e.
 java.sql.Connection getConnection(java.lang.String username, java.lang.String password)
          Simply delegates to doGetConnection(String, String), keeping the given user credentials as-is.
 void removeCredentialsFromCurrentThread()
          Remove any user credentials for this proxy from the current thread.
 void setCredentialsForCurrentThread(java.lang.String username, java.lang.String password)
          Set user credententials for this proxy and the current thread.
 void setPassword(java.lang.String password)
          Set the default user's password that this adapter should use for retrieving Connections.
 void setUsername(java.lang.String username)
          Set the default username that this adapter should use for retrieving Connections.
 
Methods inherited from class org.springframework.jdbc.datasource.DelegatingDataSource
afterPropertiesSet, getLoginTimeout, getLogWriter, getTargetDataSource, isWrapperFor, setLoginTimeout, setLogWriter, setTargetDataSource, unwrap
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

username

private java.lang.String username

password

private java.lang.String password

threadBoundCredentials

private final java.lang.ThreadLocal<UserCredentialsDataSourceAdapter.JdbcUserCredentials> threadBoundCredentials
Constructor Detail

UserCredentialsDataSourceAdapter

public UserCredentialsDataSourceAdapter()
Method Detail

setUsername

public void setUsername(java.lang.String username)
Set the default username that this adapter should use for retrieving Connections.

Default is no specific user. Note that an explicitly specified username will always override any username/password specified at the DataSource level.

See Also:
setPassword(java.lang.String), setCredentialsForCurrentThread(String, String), getConnection(String, String)

setPassword

public void setPassword(java.lang.String password)
Set the default user's password that this adapter should use for retrieving Connections.

Default is no specific password. Note that an explicitly specified username will always override any username/password specified at the DataSource level.

See Also:
setUsername(java.lang.String), setCredentialsForCurrentThread(String, String), getConnection(String, String)

setCredentialsForCurrentThread

public void setCredentialsForCurrentThread(java.lang.String username,
                                           java.lang.String password)
Set user credententials for this proxy and the current thread. The given username and password will be applied to all subsequent getConnection() calls on this DataSource proxy.

This will override any statically specified user credentials, that is, values of the "username" and "password" bean properties.

Parameters:
username - the username to apply
password - the password to apply
See Also:
removeCredentialsFromCurrentThread()

removeCredentialsFromCurrentThread

public void removeCredentialsFromCurrentThread()
Remove any user credentials for this proxy from the current thread. Statically specified user credentials apply again afterwards.

See Also:
setCredentialsForCurrentThread(java.lang.String, java.lang.String)

getConnection

public java.sql.Connection getConnection()
                                  throws java.sql.SQLException
Determine whether there are currently thread-bound credentials, using them if available, falling back to the statically specified username and password (i.e. values of the bean properties) else.

Delegates to doGetConnection(String, String) with the determined credentials as parameters.

Specified by:
getConnection in interface javax.sql.DataSource
Overrides:
getConnection in class DelegatingDataSource
Throws:
java.sql.SQLException

getConnection

public java.sql.Connection getConnection(java.lang.String username,
                                         java.lang.String password)
                                  throws java.sql.SQLException
Simply delegates to doGetConnection(String, String), keeping the given user credentials as-is.

Specified by:
getConnection in interface javax.sql.DataSource
Overrides:
getConnection in class DelegatingDataSource
Throws:
java.sql.SQLException

doGetConnection

protected java.sql.Connection doGetConnection(java.lang.String username,
                                              java.lang.String password)
                                       throws java.sql.SQLException
This implementation delegates to the getConnection(username, password) method of the target DataSource, passing in the specified user credentials. If the specified username is empty, it will simply delegate to the standard getConnection() method of the target DataSource.

Parameters:
username - the username to use
password - the password to use
Returns:
the Connection
Throws:
java.sql.SQLException
See Also:
DataSource.getConnection(String, String), DataSource.getConnection()