/*
* This file is part of PaloKettlePlugin.
*
* PaloKettlePlugin 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 3 of the License, or
* (at your option) any later version.
*
* PaloKettlePlugin 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 PaloKettlePlugin. If not, see <http://www.gnu.org/licenses/>.
*
* Portions Copyright 2008 Stratebi Business Solutions, S.L.
* Portions Copyright 2011 De Bortoli Wines Pty Limited (Australia)
* Portions Copyright 2011 - 2013 Pentaho Corporation
*/
package org.pentaho.di.trans.steps.palo.diminput;
import org.pentaho.di.core.exception.KettleException;
import org.pentaho.di.core.row.RowMetaInterface;
import org.pentaho.di.palo.core.PaloHelper;
import org.pentaho.di.trans.Trans;
import org.pentaho.di.trans.TransMeta;
import org.pentaho.di.trans.step.BaseStep;
import org.pentaho.di.trans.step.StepDataInterface;
import org.pentaho.di.trans.step.StepInterface;
import org.pentaho.di.trans.step.StepMeta;
import org.pentaho.di.trans.step.StepMetaInterface;
public class PaloDimInput extends BaseStep implements StepInterface {
private PaloDimInputMeta meta;
private PaloDimInputData data;
private ListenerWithException listener;
public PaloDimInput( final StepMeta stepMeta, final StepDataInterface stepDataInterface, final int copyNr,
final TransMeta transMeta, final Trans trans ) {
super( stepMeta, stepDataInterface, copyNr, transMeta, trans );
}
private abstract class ListenerWithException implements PaloHelper.Listener {
protected Exception throwedException = null;
}
public boolean processRow( final StepMetaInterface smi, final StepDataInterface sdi ) throws KettleException {
this.logBasic( "Getting Dimension Row Meta." );
final RowMetaInterface rowMeta =
data.helper.getDimensionRowMeta( meta.getDimension(), meta.getLevels(), meta.getBaseElementsOnly() );
this.logBasic( "Getting Dimension Rows." );
listener = new ListenerWithException() {
public void resume() {
}
public void stop() {
}
public void cancel() {
}
public boolean getStop() {
return false;
}
public void prepareElements( int numElements ) {
}
public boolean getCancel() {
return false;
}
public void oneMoreElement( Object element ) {
final Object[] row = (Object[]) element;
try {
assert ( rowMeta.size() != row.length );
incrementLinesInput();
putRow( rowMeta, row );
} catch ( Exception ex ) {
this.throwedException = ex;
this.cancel();
}
}
};
data.helper.getDimensionRows( meta.getDimension(), rowMeta, meta.getBaseElementsOnly(), listener );
if ( listener.throwedException != null ) {
throw new KettleException( "Failed to fetch some row", listener.throwedException );
}
this.logBasic( "Process Ended." );
setOutputDone();
return false;
}
public boolean init( StepMetaInterface smi, StepDataInterface sdi ) {
meta = (PaloDimInputMeta) smi;
data = (PaloDimInputData) sdi;
if ( super.init( smi, sdi ) ) {
try {
this.logDebug( "Meta Levels: " + meta.getLevels().size() );
data.helper = new PaloHelper( meta.getDatabaseMeta(), getLogLevel() );
data.helper.connect();
return true;
} catch ( Exception e ) {
logError( "An error occurred, processing will be stopped: " + e.getMessage() );
setErrors( 1 );
stopAll();
}
}
return false;
}
public void dispose( StepMetaInterface smi, StepDataInterface sdi ) {
data.helper.disconnect();
super.dispose( smi, sdi );
}
}