Plugin.java 2.5 KB
Newer Older
Matt Tucker's avatar
Matt Tucker committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
/**
 * $RCSfile$
 * $Revision$
 * $Date$
 *
 * Copyright (C) 2004 Jive Software. All rights reserved.
 *
 * This software is published under the terms of the GNU Public License (GPL),
 * a copy of which is included in this distribution.
 */

package org.jivesoftware.messenger.container;

import java.io.File;

/**
Matt Tucker's avatar
Matt Tucker committed
17 18
 * Plugin interface. Plugins enhance the functionality of Jive Messenger. They can:<ul>
 *
Matt Tucker's avatar
Matt Tucker committed
19
 *      <li>Act as {@link org.xmpp.component.Component Components} to implement
Matt Tucker's avatar
Matt Tucker committed
20 21 22 23 24
 *      additional features in the XMPP protocol.
 *      <li>Dynamically modify the admin console.
 *      <li>Use the Jive Messenger API to add new functionality to server.
 * </ul>
 *
25
 * Plugins live in the <tt>plugins</tt> directory of <tt>home</tt>. Plugins
Matt Tucker's avatar
Matt Tucker committed
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
 * that are packaged as JAR files will be automatically expanded into directories. A
 * plugin directory should have the following structure:
 *
 * <pre>[pluginDir]
 *    |-- plugin.xml
 *    |-- classes/
 *    |-- lib/</pre>
 *
 * The <tt>classes</tt> and <tt>lib</tt> directory are optional. Any files in the
 * <tt>classes</tt> directory will be added to the classpath of the plugin, as well
 * as any JAR files in the <tt>lib</tt> directory. The <tt>plugin.xml</tt> file is
 * required, and specifies the className of the Plugin implementation. The XML file
 * should resemble the following XML:
 *
 * <pre>
 * &lt;?xml version="1.0" encoding="UTF-8"?&gt;
 * &lt;plugin&gt;
 *     &lt;class&gt;org.example.YourPlugin&lt;/class&gt;
44 45 46 47 48
 *     &lt;name&gt;Example Plugin&lt;/name&gt;
 *     &lt;description&gt;This is an example plugin.&lt;/description&gt;
 *     &lt;author&gt;Foo Inc.&lt;/author&gt;
 *     &lt;version&gt;1.0&lt;/version&gt;
 *     &lt;minServerVersion&gt;2.1.2&lt;/minServerVersion&gt;
Matt Tucker's avatar
Matt Tucker committed
49 50 51
 * &lt;/plugin&gt;</pre>
 *
 * Each plugin will be loaded in its own class loader.
Matt Tucker's avatar
Matt Tucker committed
52 53 54 55 56 57 58 59 60 61 62
 *
 * @author Matt Tucker
 */
public interface Plugin {

    /**
     * Initializes the plugin.
     *
     * @param manager the plugin manager.
     * @param pluginDirectory the directory where the plugin is located.
     */
63
    public void initializePlugin(PluginManager manager, File pluginDirectory);
Matt Tucker's avatar
Matt Tucker committed
64 65

    /**
66 67 68 69 70 71 72
     * Destroys the plugin.<p>
     *
     * Implementations of this method must release all resources held
     * by the plugin such as file handles, database or network connections,
     * and references to core Jive Messenger classes. In other words, a
     * garbage collection executed after this method is called must be able
     * to clean up all plugin classes.
Matt Tucker's avatar
Matt Tucker committed
73
     */
74
    public void destroyPlugin();
Matt Tucker's avatar
Matt Tucker committed
75 76

}