/*! ****************************************************************************** * * Pentaho Data Integration * * Copyright (C) 2002-2016 by Pentaho : http://www.pentaho.com * ******************************************************************************* * * Licensed under the Apache 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.apache.org/licenses/LICENSE-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.pentaho.di.core.logging; import java.io.FileInputStream; import java.io.InputStream; import java.lang.annotation.Annotation; import java.util.List; import java.util.Map; import org.apache.commons.vfs2.FileObject; import org.pentaho.di.core.Const; import org.pentaho.di.core.util.Utils; import org.pentaho.di.core.exception.KettlePluginException; import org.pentaho.di.core.exception.KettleXMLException; import org.pentaho.di.core.plugins.BasePluginType; import org.pentaho.di.core.plugins.PluginAnnotationType; import org.pentaho.di.core.plugins.PluginFolderInterface; import org.pentaho.di.core.plugins.PluginMainClassType; import org.pentaho.di.core.plugins.PluginTypeInterface; import org.pentaho.di.core.vfs.KettleVFS; import org.pentaho.di.core.xml.XMLHandler; import org.w3c.dom.Document; import org.w3c.dom.Node; /** * This class represents the logging plugin type. * * @author matt * */ @PluginMainClassType( LoggingPluginInterface.class ) @PluginAnnotationType( LoggingPlugin.class ) public class LoggingPluginType extends BasePluginType implements PluginTypeInterface { private static LoggingPluginType loggingPluginType; private LoggingPluginType() { super( LoggingPlugin.class, "LOGGING", "Logging Plugin" ); populateFolders( "logging" ); } public static LoggingPluginType getInstance() { if ( loggingPluginType == null ) { loggingPluginType = new LoggingPluginType(); } return loggingPluginType; } /** * Scan & register internal logging plugins */ @Override protected void registerNatives() throws KettlePluginException { // Scan the native steps... // String kettleLoggingPluginsXmlFile = Const.XML_FILE_KETTLE_LOGGING_PLUGINS; String alternative = System.getProperty( Const.KETTLE_LOGGING_PLUGINS_FILE, null ); if ( !Utils.isEmpty( alternative ) ) { kettleLoggingPluginsXmlFile = alternative; } // Load the plugins for this file... // try { InputStream inputStream = getClass().getResourceAsStream( kettleLoggingPluginsXmlFile ); if ( inputStream == null ) { inputStream = getClass().getResourceAsStream( "/" + kettleLoggingPluginsXmlFile ); } // Retry to load a regular file... if ( inputStream == null && !Utils.isEmpty( alternative ) ) { try { inputStream = new FileInputStream( kettleLoggingPluginsXmlFile ); } catch ( Exception e ) { throw new KettlePluginException( "Unable to load native logging plugins '" + kettleLoggingPluginsXmlFile + "'", e ); } } if ( inputStream == null ) { throw new KettlePluginException( "Unable to find native logging plugins definition file: " + Const.XML_FILE_KETTLE_LOGGING_PLUGINS ); } Document document = XMLHandler.loadXMLFile( inputStream, null, true, false ); Node stepsNode = XMLHandler.getSubNode( document, "logging-plugins" ); List<Node> stepNodes = XMLHandler.getNodes( stepsNode, "logging-plugin" ); for ( Node stepNode : stepNodes ) { registerPluginFromXmlResource( stepNode, null, this.getClass(), true, null ); } } catch ( KettleXMLException e ) { throw new KettlePluginException( "Unable to read the kettle logging plugins XML config file: " + kettleLoggingPluginsXmlFile, e ); } } @Override protected void registerXmlPlugins() throws KettlePluginException { for ( PluginFolderInterface folder : pluginFolders ) { if ( folder.isPluginXmlFolder() ) { List<FileObject> pluginXmlFiles = findPluginXmlFiles( folder.getFolder() ); for ( FileObject file : pluginXmlFiles ) { try { Document document = XMLHandler.loadXMLFile( file ); Node pluginNode = XMLHandler.getSubNode( document, "plugin" ); if ( pluginNode != null ) { registerPluginFromXmlResource( pluginNode, KettleVFS.getFilename( file.getParent() ), this .getClass(), false, file.getParent().getURL() ); } } catch ( Exception e ) { // We want to report this plugin.xml error, perhaps an XML typo or something like that... // log.logError( "Error found while reading logging plugin.xml file: " + file.getName().toString(), e ); } } } } } @Override protected String extractCategory( Annotation annotation ) { return null; } @Override protected String extractDesc( Annotation annotation ) { return null; } @Override protected String extractID( Annotation annotation ) { String id = ( (LoggingPlugin) annotation ).id(); return id; } @Override protected String extractName( Annotation annotation ) { String name = ( (LoggingPlugin) annotation ).name(); return Utils.isEmpty( name ) ? extractID( annotation ) : name; } @Override protected String extractImageFile( Annotation annotation ) { return null; } @Override protected boolean extractSeparateClassLoader( Annotation annotation ) { return ( (LoggingPlugin) annotation ).isSeparateClassLoaderNeeded(); } @Override protected String extractI18nPackageName( Annotation annotation ) { return null; } @Override protected void addExtraClasses( Map<Class<?>, String> classMap, Class<?> clazz, Annotation annotation ) { } @Override protected String extractDocumentationUrl( Annotation annotation ) { return null; } @Override protected String extractCasesUrl( Annotation annotation ) { return null; } @Override protected String extractForumUrl( Annotation annotation ) { return null; } @Override protected String extractClassLoaderGroup( Annotation annotation ) { return ( (LoggingPlugin) annotation ).classLoaderGroup(); } }