/* * Copyright (C) 2003-2010 eXo Platform SAS. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU Affero General Public License * as published by the Free Software Foundation; either version 3 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, see<http://www.gnu.org/licenses/>. */ package org.exoplatform.wiki.service.impl; import javax.servlet.http.HttpSessionEvent; import org.exoplatform.container.PortalContainer; import org.exoplatform.container.RootContainer; import org.exoplatform.container.component.RequestLifeCycle; import org.exoplatform.services.listener.Event; import org.exoplatform.services.listener.Listener; import org.exoplatform.services.log.ExoLogger; import org.exoplatform.services.log.Log; import org.exoplatform.wiki.service.WikiService; /** * Created by The eXo Platform SAS * Author : viet nguyen * viet.nguyen@exoplatform.com * Jun 24, 2010 */ public class SessionDestroyedListener extends Listener<PortalContainer, HttpSessionEvent> { private static Log LOG = ExoLogger.getLogger("SessionDestroyedListener"); @Override public void onEvent(Event<PortalContainer, HttpSessionEvent> event) throws Exception { String sessionId = event.getData().getSession().getId(); if (LOG.isTraceEnabled()) { LOG.trace("Removing the key: " + sessionId); } try { SessionManager sessionManager = (SessionManager) RootContainer.getComponent(SessionManager.class); sessionManager.removeSessionContainer(sessionId); } catch (Exception e) { LOG.warn("Can't remove the key: " + sessionId, e); } if (LOG.isTraceEnabled()) { LOG.trace("Removed the key: " + sessionId); } PortalContainer container = event.getSource(); if (container.isStarted()) { WikiService wikiService = (WikiService) container.getComponentInstanceOfType(WikiService.class); RequestLifeCycle.begin(PortalContainer.getInstance()); wikiService.deleteDraftNewPage(sessionId); RequestLifeCycle.end(); } } }