1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
|
//
// ========================================================================
// Copyright (c) 1995-2015 Mort Bay Consulting Pty. Ltd.
// ------------------------------------------------------------------------
// All rights reserved. This program and the accompanying materials
// are made available under the terms of the Eclipse Public License v1.0
// and Apache License v2.0 which accompanies this distribution.
//
// The Eclipse Public License is available at
// http://www.eclipse.org/legal/epl-v10.html
//
// The Apache License v2.0 is available at
// http://www.opensource.org/licenses/apache2.0.php
//
// You may elect to redistribute this code under either of these licenses.
// ========================================================================
//
package org.eclipse.jetty.jaas.spi;
import java.sql.Connection;
import java.sql.DriverManager;
import java.util.Map;
import javax.security.auth.Subject;
import javax.security.auth.callback.CallbackHandler;
import org.eclipse.jetty.util.Loader;
import org.eclipse.jetty.util.log.Log;
import org.eclipse.jetty.util.log.Logger;
/* ---------------------------------------------------- */
/** JDBCLoginModule
* <p>JAAS LoginModule to retrieve user information from
* a database and authenticate the user.
*
* <p><h4>Notes</h4>
* <p>This version uses plain old JDBC connections NOT
* Datasources.
*
* <p><h4>Usage</h4>
* <pre>
* </pre>
*
* @version 1.0 Tue Apr 15 2003
*/
public class JDBCLoginModule extends AbstractDatabaseLoginModule
{
private static final Logger LOG = Log.getLogger(JDBCLoginModule.class);
private String dbDriver;
private String dbUrl;
private String dbUserName;
private String dbPassword;
/**
* Get a connection from the DriverManager
* @see AbstractDatabaseLoginModule#getConnection()
* @return the connection for this datasource
* @throws Exception
*/
public Connection getConnection ()
throws Exception
{
if (!((dbDriver != null)
&&
(dbUrl != null)))
throw new IllegalStateException ("Database connection information not configured");
if(LOG.isDebugEnabled())LOG.debug("Connecting using dbDriver="+dbDriver+"+ dbUserName="+dbUserName+", dbPassword="+dbUrl);
return DriverManager.getConnection (dbUrl,
dbUserName,
dbPassword);
}
/* ------------------------------------------------ */
/** Init LoginModule.
* Called once by JAAS after new instance created.
* @param subject
* @param callbackHandler
* @param sharedState
* @param options
*/
public void initialize(Subject subject,
CallbackHandler callbackHandler,
Map<String,?> sharedState,
Map<String,?> options)
{
try
{
super.initialize(subject, callbackHandler, sharedState, options);
//get the jdbc username/password, jdbc url out of the options
dbDriver = (String)options.get("dbDriver");
dbUrl = (String)options.get("dbUrl");
dbUserName = (String)options.get("dbUserName");
dbPassword = (String)options.get("dbPassword");
if (dbUserName == null)
dbUserName = "";
if (dbPassword == null)
dbPassword = "";
if (dbDriver != null)
Loader.loadClass(this.getClass(), dbDriver).newInstance();
}
catch (ClassNotFoundException e)
{
throw new IllegalStateException (e.toString());
}
catch (InstantiationException e)
{
throw new IllegalStateException (e.toString());
}
catch (IllegalAccessException e)
{
throw new IllegalStateException (e.toString());
}
}
}
|