/*! ****************************************************************************** * * 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.imp.rules; import java.util.ArrayList; import java.util.List; import org.pentaho.di.core.util.Utils; import org.pentaho.di.core.database.DatabaseMeta; import org.pentaho.di.core.exception.KettleException; import org.pentaho.di.core.xml.XMLHandler; import org.pentaho.di.imp.rule.ImportRuleInterface; import org.pentaho.di.imp.rule.ImportValidationFeedback; import org.pentaho.di.imp.rule.ImportValidationResultType; import org.pentaho.di.trans.HasDatabasesInterface; import org.w3c.dom.Node; public class DatabaseConfigurationImportRule extends BaseImportRule implements ImportRuleInterface { private DatabaseMeta databaseMeta; public DatabaseConfigurationImportRule() { super(); databaseMeta = null; // not configured. } public boolean isUnique() { return false; } @Override public ImportRuleInterface clone() { DatabaseConfigurationImportRule rule = new DatabaseConfigurationImportRule(); rule.setId( getId() ); rule.setEnabled( isEnabled() ); if ( databaseMeta != null ) { rule.setDatabaseMeta( (DatabaseMeta) databaseMeta.clone() ); } return rule; } @Override public List<ImportValidationFeedback> verifyRule( Object subject ) { List<ImportValidationFeedback> feedback = new ArrayList<ImportValidationFeedback>(); if ( !isEnabled() ) { return feedback; } if ( databaseMeta == null ) { feedback.add( new ImportValidationFeedback( this, ImportValidationResultType.ERROR, "This rule contains no database to validate against." ) ); return feedback; } DatabaseMeta verify = null; if ( subject instanceof HasDatabasesInterface ) { HasDatabasesInterface dbs = (HasDatabasesInterface) subject; verify = dbs.findDatabase( databaseMeta.getName() ); } else if ( subject instanceof DatabaseMeta ) { // See if this is the database to verify! If it's not, simply ignore it. // if ( databaseMeta.getName().equals( ( (DatabaseMeta) subject ).getName() ) ) { verify = (DatabaseMeta) subject; } } if ( verify == null ) { return feedback; } // Verify the database name if it's non-empty // if ( !Utils.isEmpty( databaseMeta.getDatabaseName() ) ) { if ( !databaseMeta.getDatabaseName().equals( verify.getDatabaseName() ) ) { feedback.add( new ImportValidationFeedback( this, ImportValidationResultType.ERROR, "The name of the database is not set to the expected value '" + databaseMeta.getDatabaseName() + "'." ) ); } } // Verify the host name if it's non-empty // if ( !Utils.isEmpty( databaseMeta.getHostname() ) ) { if ( !databaseMeta.getHostname().equals( verify.getHostname() ) ) { feedback .add( new ImportValidationFeedback( this, ImportValidationResultType.ERROR, "The host name of the database is not set to the expected value '" + databaseMeta.getHostname() + "'." ) ); } } // Verify the database port number if it's non-empty // if ( !Utils.isEmpty( databaseMeta.getDatabasePortNumberString() ) ) { if ( !databaseMeta.getDatabasePortNumberString().equals( verify.getDatabasePortNumberString() ) ) { feedback.add( new ImportValidationFeedback( this, ImportValidationResultType.ERROR, "The database port of the database is not set to the expected value '" + databaseMeta.getDatabasePortNumberString() + "'." ) ); } } // Verify the user name if it's non-empty // if ( !Utils.isEmpty( databaseMeta.getUsername() ) ) { if ( !databaseMeta.getUsername().equals( verify.getUsername() ) ) { feedback .add( new ImportValidationFeedback( this, ImportValidationResultType.ERROR, "The username of the database is not set to the expected value '" + databaseMeta.getUsername() + "'." ) ); } } // Verify the password if it's non-empty // if ( !Utils.isEmpty( databaseMeta.getPassword() ) ) { if ( !databaseMeta.getPassword().equals( verify.getPassword() ) ) { feedback.add( new ImportValidationFeedback( this, ImportValidationResultType.ERROR, "The password of the database is not set to the expected value." ) ); } } if ( feedback.isEmpty() ) { feedback.add( new ImportValidationFeedback( this, ImportValidationResultType.APPROVAL, "The database connection was found and verified." ) ); } return feedback; } @Override public String getXML() { StringBuilder xml = new StringBuilder(); xml.append( XMLHandler.openTag( XML_TAG ) ); xml.append( super.getXML() ); // id, enabled if ( databaseMeta != null ) { xml.append( databaseMeta.getXML() ); } xml.append( XMLHandler.closeTag( XML_TAG ) ); return xml.toString(); } @Override public void loadXML( Node ruleNode ) throws KettleException { super.loadXML( ruleNode ); Node connectionNode = XMLHandler.getSubNode( ruleNode, DatabaseMeta.XML_TAG ); if ( connectionNode != null ) { databaseMeta = new DatabaseMeta( connectionNode ); } } /** * @return the databaseMeta */ public DatabaseMeta getDatabaseMeta() { return databaseMeta; } /** * @param databaseMeta * the databaseMeta to set */ public void setDatabaseMeta( DatabaseMeta databaseMeta ) { this.databaseMeta = databaseMeta; } }