/*
* The contents of this file are subject to the Mozilla Public License Version 1.1
* (the "License"); you may not use this file except in compliance with the License.
* You may obtain a copy of the License at .
*
* Software distributed under the License is distributed on an "AS IS" basis, WITHOUT
* WARRANTY OF ANY KIND, either express or implied. See the License for the specific
* language governing rights and limitations under the License.
*
* The Original Code is the Venice Web Communities System.
*
* The Initial Developer of the Original Code is Eric J. Bowersox ,
* for Silverwrist Design Studios. Portions created by Eric J. Bowersox are
* Copyright (C) 2002-03 Eric J. Bowersox/Silverwrist Design Studios. All Rights Reserved.
*
* Contributor(s):
*/
package com.silverwrist.venice.app;
import org.apache.log4j.Logger;
import org.w3c.dom.*;
import com.silverwrist.util.xml.*;
import com.silverwrist.dynamo.except.*;
import com.silverwrist.dynamo.event.*;
import com.silverwrist.dynamo.iface.*;
import com.silverwrist.venice.VeniceNamespaces;
public class StartupShutdownAuditor implements NamedObject, ComponentInitialize, ComponentShutdown, ApplicationListener
{
/*--------------------------------------------------------------------------------
* Static data members
*--------------------------------------------------------------------------------
*/
private static Logger logger = Logger.getLogger(StartupShutdownAuditor.class);
/*--------------------------------------------------------------------------------
* Attributes
*--------------------------------------------------------------------------------
*/
private String m_name;
private AuditRecordFactory m_audit;
private ComponentShutdown m_shut_event;
/*--------------------------------------------------------------------------------
* Constructor
*--------------------------------------------------------------------------------
*/
public StartupShutdownAuditor()
{ // do nothing
} // end constructor
/*--------------------------------------------------------------------------------
* Implementations from interface NamedObject
*--------------------------------------------------------------------------------
*/
public String getName()
{
return m_name;
} // end getName
/*--------------------------------------------------------------------------------
* Implementations from interface ComponentInitialize
*--------------------------------------------------------------------------------
*/
/**
* Initialize the component.
*
* @param config_root Pointer to the section of the Dynamo XML configuration file that configures this
* particular component. This is to be considered "read-only" by the component.
* @param services An implementation of {@link com.silverwrist.dynamo.iface.ServiceProvider ServiceProvider}
* which provides initialization services to the component. This will include an implementation
* of {@link com.silverwrist.dynamo.iface.ObjectProvider ObjectProvider} which may be used to
* get information about other objects previously initialized by the application.
* @exception com.silverwrist.dynamo.except.ConfigException If an error is encountered in the component
* configuration.
*/
public void initialize(Element config_root, ServiceProvider services) throws ConfigException
{
logger.info("StartupShutdownAuditor initializing");
XMLLoader loader = XMLLoader.get();
String gprops = null;
try
{ // verify the right node name
loader.verifyNodeName(config_root,"object");
// get the object's name
m_name = loader.getAttribute(config_root,"name");
} // end try
catch (XMLLoadException e)
{ // error loading XML config data
logger.fatal("XML loader exception in StartupShutdownAuditor",e);
throw new ConfigException(e);
} // end catch
// Get the audit record provider.
m_audit = (AuditRecordFactory)(services.queryService(AuditRecordFactory.class));
// Register us as an application listener.
EventListenerRegistration reg =
(EventListenerRegistration)(services.queryService(EventListenerRegistration.class));
m_shut_event = reg.registerApplicationListener(this);
} // end initialize
/*--------------------------------------------------------------------------------
* Implementations from interface ComponentShutdown
*--------------------------------------------------------------------------------
*/
public void shutdown()
{
m_shut_event.shutdown();
m_shut_event = null;
m_audit = null;
} // end shutdown
/*--------------------------------------------------------------------------------
* Implementations from interface ApplicationListener
*--------------------------------------------------------------------------------
*/
public void applicationInitialized(ApplicationEvent event)
{
AuditRecordCompose rec =
m_audit.createSystemAuditRecord(VeniceNamespaces.SYSTEM_EVENT_NAMESPACE,"system.startup");
rec.write();
} // end applicationInitialized
public void applicationExiting(ApplicationEvent event)
{
AuditRecordCompose rec =
m_audit.createSystemAuditRecord(VeniceNamespaces.SYSTEM_EVENT_NAMESPACE,"system.shutdown");
rec.write();
} // end applicationExiting
} // end class StartupShutdownAuditor