/**********************************************************************************
* $URL: https://source.sakaiproject.org/svn/search/trunk/search-impl/impl/src/java/org/sakaiproject/search/component/service/impl/SearchNotificationAction.java $
* $Id: SearchNotificationAction.java 105078 2012-02-24 23:00:38Z ottenhoff@longsight.com $
***********************************************************************************
*
* Copyright (c) 2003, 2004, 2005, 2006, 2008 The Sakai Foundation
*
* Licensed under the Educational Community 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.opensource.org/licenses/ECL-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.sakaiproject.search.component.service.impl;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.sakaiproject.event.api.Event;
import org.sakaiproject.event.api.Notification;
import org.sakaiproject.event.api.NotificationAction;
import org.sakaiproject.search.api.SearchIndexBuilder;
import org.w3c.dom.Element;
/**
* This action pushes the Event and Notification to the SearchIndexBuilder That
* manages the update of the search indexes.
*
* @author ieb
*/
public class SearchNotificationAction implements NotificationAction
{
private static Log dlog = LogFactory.getLog(SearchNotificationAction.class);
private SearchIndexBuilder searchIndexBuilder;
public SearchNotificationAction()
{
dlog.debug("Constructor()");
}
public SearchNotificationAction(SearchIndexBuilder searchIndexBuilder)
{
dlog.debug("Constructory()" + searchIndexBuilder);
this.searchIndexBuilder = searchIndexBuilder;
}
/**
* @{inheritDoc}
*/
public void set(Element arg0)
{
dlog.debug("set element");
// copy the element contents to this action
}
/**
* @{inheritDoc}
*/
public void set(NotificationAction arg0)
{
dlog.debug("set action");
// copy the notifiation action to this notification action
}
/**
* @{inheritDoc}
*/
public NotificationAction getClone()
{
dlog.debug("Clone");
SearchNotificationAction clone = new SearchNotificationAction(
searchIndexBuilder);
clone.set(this);
return clone;
}
/**
* @{inheritDoc}
*/
public void toXml(Element arg0)
{
// Serialise to XML
}
/**
* The notify operation will come in with an event that we are registerd to
* recieve, and notification.
*
* @{inheritDoc}
*/
public void notify(Notification notification, Event event)
{
dlog.debug("Notify " + event.getEvent());
// This is done so that we can persist the Actions if we want without
// having to keep a reference to the SearchIndexBuilder
searchIndexBuilder.addResource(notification, event);
}
}