/* * Trigger.java - eXist Open Source Native XML Database * Copyright (C) 2003 Wolfgang M. Meier * wolfgang@exist-db.org * http://exist-db.org * * This program 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 * 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. * * $Id$ * */ package org.exist.collections.triggers; import java.util.Map; import org.apache.log4j.Logger; import org.exist.collections.Collection; import org.exist.collections.CollectionConfigurationException; import org.exist.storage.DBBroker; /** * Defines the base interface for collection triggers. Triggers are registered through the * collection configuration file, called "collection.xconf", which should be * stored in the corresponding database collection. If a collection configuration file is * found in the collection, it will be parsed and any triggers will be created and configured. * The {@link #configure(DBBroker, Collection, Map) configure} method is called once on each trigger. * * Triggers listen to events. Currently, there are five events to which triggers may be * attached: * * <table border="0"> * <tr> * <td>{@link #STORE_DOCUMENT_EVENT}</td> * <td>Fired, if a new document is inserted into the collection.</td> * </tr> * <tr> * <td>{@link #UPDATE_DOCUMENT_EVENT}</td> * <td>Fired, whenever an existing document is updated, i.e. replaced * with a new version.</td> * </tr> * <tr> * <td>{@link #REMOVE_DOCUMENT_EVENT}</td> * <td>Fired, whenever a document is removed from the collection.</td> * </tr> * <tr> * <td>{@link #RENAME_COLLECTION_EVENT}</td> * <td>Fired, before a collection is renamed.</td> * </tr> * <tr> * <td>{@link #CREATE_COLLECTION_EVENT}</td> * <td>Fired, before a new collection is created.</td> * </tr> * </table> * * The document-related events are handled by the sub-interface {@link org.exist.collections.triggers.DocumentTrigger}, * collection-related events are handled by {@link org.exist.collections.triggers.CollectionTrigger}. * * The collection configuration file looks as follows: * * <pre> * <?xml version="1.0" encoding="ISO-8859-1"?> * <exist:collection xmlns:exist="http://exist-db.org/collection-config/1.0"> * <exist:triggers> * <exist:trigger event="store" * class="fully qualified classname of the trigger"> * <exist:parameter name="parameter-name" * value="parameter-value"/> * </exist:trigger> * </exist:triggers> * </exist:collection> * </pre> * * @author wolf * @see org.exist.collections.triggers.DocumentTrigger */ public interface Trigger { public final static int STORE_DOCUMENT_EVENT = 0; public final static int UPDATE_DOCUMENT_EVENT = 1; public final static int REMOVE_DOCUMENT_EVENT = 2; public final static int CREATE_COLLECTION_EVENT = 3; public final static int RENAME_COLLECTION_EVENT = 4; public final static int DELETE_COLLECTION_EVENT = 5; /** * The configure method is called once whenever the collection configuration is loaded. Use it to * initialize the trigger, probably by looking at the parameters. * * @param broker the database instance used to load the collection configuration. The broker object is * required for all database actions. Please note: the broker instance used for configuration is probably * different from the one passed to the prepare method. Don't store the broker object in your class. * @param parent the collection to which this trigger belongs. * @param parameters a Map containing any key/value parameters defined in the configuration file. * @throws CollectionConfigurationException if the trigger cannot be initialized. */ public void configure(DBBroker broker, Collection parent, Map parameters) throws CollectionConfigurationException; /** * Returns a Logger object. Use this to log debugging information. * */ public Logger getLogger(); }