01: /******************************************************************************
02: * JBoss, a division of Red Hat *
03: * Copyright 2006, Red Hat Middleware, LLC, and individual *
04: * contributors as indicated by the @authors tag. See the *
05: * copyright.txt in the distribution for a full listing of *
06: * individual contributors. *
07: * *
08: * This is free software; you can redistribute it and/or modify it *
09: * under the terms of the GNU Lesser General Public License as *
10: * published by the Free Software Foundation; either version 2.1 of *
11: * the License, or (at your option) any later version. *
12: * *
13: * This software is distributed in the hope that it will be useful, *
14: * but WITHOUT ANY WARRANTY; without even the implied warranty of *
15: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
16: * Lesser General Public License for more details. *
17: * *
18: * You should have received a copy of the GNU Lesser General Public *
19: * License along with this software; if not, write to the Free *
20: * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA *
21: * 02110-1301 USA, or see the FSF site: http://www.fsf.org. *
22: ******************************************************************************/package org.jboss.portal.core.identity;
23:
24: import org.jboss.portal.identity.event.IdentityEvent;
25: import org.jboss.portal.identity.event.IdentityEventEmitter;
26: import org.jboss.portal.identity.event.IdentityEventListener;
27: import org.jboss.portal.identity.event.UserDestroyedEvent;
28: import org.jboss.portal.jems.as.system.AbstractJBossService;
29: import org.jboss.security.auth.login.DynamicLoginConfigMBean;
30:
31: /**
32: * Use identity destroy events to destroy corresponding dashboards.
33: *
34: * @author <a href="mailto:julien@jboss.org">Julien Viet</a>
35: * @version $Revision: 8786 $
36: */
37: public class SecurityBridge extends AbstractJBossService implements
38: IdentityEventListener {
39:
40: /** . */
41: private IdentityEventEmitter identityEventEmitter;
42:
43: /** . */
44: private DynamicLoginConfigMBean dynamicLoginConfig;
45:
46: public IdentityEventEmitter getIdentityEventEmitter() {
47: return identityEventEmitter;
48: }
49:
50: public void setIdentityEventEmitter(
51: IdentityEventEmitter identityEventEmitter) {
52: this .identityEventEmitter = identityEventEmitter;
53: }
54:
55: public DynamicLoginConfigMBean getDynamicLoginConfig() {
56: return dynamicLoginConfig;
57: }
58:
59: public void setDynamicLoginConfig(
60: DynamicLoginConfigMBean dynamicLoginConfig) {
61: this .dynamicLoginConfig = dynamicLoginConfig;
62: }
63:
64: protected void startService() throws Exception {
65: identityEventEmitter.addListener(this );
66: }
67:
68: protected void stopService() throws Exception {
69: identityEventEmitter.removeListener(this );
70: }
71:
72: public void onEvent(IdentityEvent event) {
73: if (event instanceof UserDestroyedEvent) {
74: final UserDestroyedEvent destroyedEvent = (UserDestroyedEvent) event;
75:
76: //
77: log
78: .debug("User (userName="
79: + destroyedEvent.getUserName()
80: + ",id="
81: + destroyedEvent.getUserId()
82: + " ) is destroyed, will invalidate security manager cache instead ");
83:
84: //
85: try {
86: dynamicLoginConfig.flushAuthenticationCaches();
87: } catch (Exception e) {
88: log
89: .warn(
90: "Error while flushing authentication cache",
91: e);
92: }
93: }
94: }
95: }
|