blob: 0ff22e3a0ff643366c9fbb399d1ce61f1553caf9 [file] [log] [blame]
/*
* Copyright (c) 1997, 2018 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0, which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the
* Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
* version 2 with the GNU Classpath Exception, which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
*/
package test;
import jakarta.servlet.ServletContext;
import jakarta.servlet.http.HttpSession;
import jakarta.servlet.http.HttpSessionAttributeListener;
import jakarta.servlet.http.HttpSessionBindingEvent;
import javax.naming.*;
import jakarta.annotation.Resource;
import jakarta.annotation.Resources;
import javax.sql.DataSource;
@Resource(name="myDataSource4", type=DataSource.class)
@Resources({ @Resource(name="myDataSource5", type=DataSource.class),
@Resource(name="jdbc/myDataSource6", type=DataSource.class) })
public class MyListener implements HttpSessionAttributeListener {
private @Resource DataSource ds1;
private @Resource(name="myDataSource2") DataSource ds2;
private DataSource ds3;
@Resource(name="jdbc/myDataSource3")
private void setDataSource(DataSource ds) {
ds3 = ds;
}
/**
* Receives notification that an attribute has been added to a
* session.
*
* @param hsbe The HttpSessionBindingEvent
*/
public void attributeAdded(HttpSessionBindingEvent hsbe) {
HttpSession session = hsbe.getSession();
ServletContext sc = session.getServletContext();
try {
int loginTimeout = ds1.getLoginTimeout();
sc.log("ds1-login-timeout=" + loginTimeout);
loginTimeout = ds2.getLoginTimeout();
sc.log(",ds2-login-timeout=" + loginTimeout);
loginTimeout = ds3.getLoginTimeout();
sc.log(",ds3-login-timeout=" + loginTimeout);
InitialContext ic = new InitialContext();
DataSource ds4 = (DataSource)
ic.lookup("java:comp/env/myDataSource4");
loginTimeout = ds4.getLoginTimeout();
sc.log(",ds4-login-timeout=" + loginTimeout);
DataSource ds5 = (DataSource)
ic.lookup("java:comp/env/myDataSource5");
loginTimeout = ds5.getLoginTimeout();
sc.log(",ds5-login-timeout=" + loginTimeout);
DataSource ds6 = (DataSource)
ic.lookup("java:comp/env/jdbc/myDataSource6");
loginTimeout = ds6.getLoginTimeout();
sc.log(",ds6-login-timeout=" + loginTimeout);
session.setAttribute("success", new Object());
} catch (Exception e) {
throw new RuntimeException(e);
}
}
/**
* Receives notification that an attribute has been removed from a
* session.
*
* @param hsbe The HttpSessionBindingEvent
*/
public void attributeRemoved(HttpSessionBindingEvent hsbe) {
// Do nothing
}
/**
* Receives notification that an attribute has been replaced in a
* session.
*
* @param hsbe The HttpSessionBindingEvent
*/
public void attributeReplaced(HttpSessionBindingEvent se) {
// Do nothing
}
}