/*
* Copyright 2017 OmniFaces
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
* an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
* specific language governing permissions and limitations under the License.
*/
package org.omnifaces.cdi.eager;
import static java.lang.String.format;
import static java.util.logging.Level.WARNING;
import static org.omnifaces.util.Servlets.getRequestRelativeURIWithoutPathParameters;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.logging.Logger;
import javax.servlet.ServletRequestEvent;
import javax.servlet.ServletRequestListener;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;
/**
* <p>
* A web listener that instantiates eager session beans and request/view beans by request URI. This is auto-registered
* by {@link EagerBeansRepository#instantiateApplicationScopedAndRegisterListenerIfNecessary(javax.servlet.ServletContext)}
* when any eager session beans or request/view beans by request URI are available.
*
* @since 2.0
* @author Arjan Tijms
*
*/
public class EagerBeansWebListener implements HttpSessionListener, ServletRequestListener {
// Constants ------------------------------------------------------------------------------------------------------
public static final String SESSION_CREATED = "org.omnifaces.eager.SESSION_CREATED";
private static final Logger logger = Logger.getLogger(EagerBeansWebListener.class.getName());
private static final String POSSIBLY_REQUEST_SCOPE_NOT_ACTIVE =
"Could not instantiate eager request scoped beans for request %s. Possibly the CDI request scope is not active."
+ " If this is indeed the case, see JavaDoc on org.omnifaces.cdi.Eager on how to remedy this.";
private static volatile boolean sessionListenerDisabled;
private static volatile boolean requestListenerDisabled;
// Actions --------------------------------------------------------------------------------------------------------
static void disable() {
sessionListenerDisabled = true;
requestListenerDisabled = true;
}
@Override
public void sessionCreated(HttpSessionEvent event) {
if (!sessionListenerDisabled) {
if (!EagerBeansRepository.getInstance().instantiateSessionScoped()) {
sessionListenerDisabled = true;
}
}
else {
// Record a "session created" marker manually. HttpSession#isNew() not entirely accurate for our purpose.
event.getSession().setAttribute(SESSION_CREATED, new AtomicBoolean(true));
}
}
@Override
public void requestInitialized(ServletRequestEvent event) {
if (!requestListenerDisabled) {
String uri = getRequestRelativeURIWithoutPathParameters((HttpServletRequest) event.getServletRequest());
try {
if (!EagerBeansRepository.getInstance().instantiateByRequestURI(uri)) {
requestListenerDisabled = true;
}
}
catch (Exception e) {
logger.log(WARNING, format(POSSIBLY_REQUEST_SCOPE_NOT_ACTIVE, uri), e);
}
}
}
@Override
public void requestDestroyed(ServletRequestEvent event) {
// NOOP.
}
@Override
public void sessionDestroyed(HttpSessionEvent event) {
// NOOP.
}
}