/* * JOSSO: Java Open Single Sign-On * * Copyright 2004-2009, Atricore, Inc. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. * */ package org.josso.util.config; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.josso.SSOConfigurationEventListener; import javax.management.AttributeChangeNotification; import java.util.EventObject; /** * This ConfigurationHandler receives SSOEvents and uses them to update JOSSO configuration files. * * @author <a href="mailto:sgonzalez@josso.org">Sebastian Gonzalez Oyuela</a> * @version $Id: SSOConfigurationEventHandler.java 543 2008-03-18 21:34:58Z sgonzalez $ */ public class SSOConfigurationEventHandler extends XUpdateConfigurationHandler implements SSOConfigurationEventListener { private static final Log logger = LogFactory.getLog(SSOConfigurationEventHandler.class); private Object source; private String[] ignoredAttrs; /** * @param ctx the ConfigurationContext used by this handler. * @param elementsBaseLocation a XPath expression used to determine where elements to be updated are found in the configuration file. * @param newElementsBaseLocation a XPath expression used to determine where new elements will be inserted as siblings in the configuration file. * @param source the event source this handler uses */ public SSOConfigurationEventHandler(ConfigurationContext ctx, String elementsBaseLocation, String newElementsBaseLocation, Object source, String[] ignoredAttrs) { super(ctx, elementsBaseLocation, newElementsBaseLocation); this.source = source; this.ignoredAttrs = ignoredAttrs; } /** * Handles an BaseSSOEvent and updates JOSSO config if necessary. * The event object must be instance of javax.management.AttributeChangeNotification * * @param eventType the event type (this may be a JMX event type) * @param event the event object. Only AttributeChangeNotification events are supported by this handler. */ public void handleEvent(String eventType, EventObject event) { // An attribute has change in the SSOAgent ... update config file. if (event instanceof AttributeChangeNotification) { AttributeChangeNotification notification = (AttributeChangeNotification) event; String attrName = notification.getAttributeName(); if (ignore(attrName)) return; // This should cover longs, ints and of course, strings. String newValue = notification.getNewValue().toString(); String oldValue = (notification.getOldValue() != null ? notification.getOldValue().toString() : null); this.saveElement(attrName, oldValue, newValue); } } /** * Only handles events of type : "jmx.attribute.change" for the supported resource. */ public boolean isEventEnabled(String eventType, EventObject event) { // This will only handle SSOAgent related events : return source.equals(event.getSource()); } /** * Util to determine if an attribute must be ignored. * Subclasses may add different behavior. */ protected boolean ignore(String attrName) { for (int i = 0; i < ignoredAttrs.length; i++) { String ignoredAttr = ignoredAttrs[i]; if (ignoredAttr.equals(attrName)) return true; } return false; } }