本文整理匯總了Java中org.pentaho.di.core.variables.VariableSpace.environmentSubstitute方法的典型用法代碼示例。如果您正苦於以下問題:Java VariableSpace.environmentSubstitute方法的具體用法?Java VariableSpace.environmentSubstitute怎麽用?Java VariableSpace.environmentSubstitute使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.pentaho.di.core.variables.VariableSpace
的用法示例。
在下文中一共展示了VariableSpace.environmentSubstitute方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: getStage
import org.pentaho.di.core.variables.VariableSpace; //導入方法依賴的package包/類
/**
* Gets the Snowflake stage name based on the configured metadata
* @param space The variable space
* @return The Snowflake stage name to use
*/
public String getStage( VariableSpace space ) {
if ( locationType.equals( LOCATION_TYPE_CODES[LOCATION_TYPE_USER] ) ) {
return "@~/" + space.environmentSubstitute( targetTable );
} else if ( locationType.equals( LOCATION_TYPE_CODES[LOCATION_TYPE_TABLE] ) ) {
if ( !Const.isEmpty( space.environmentSubstitute( targetSchema ) ) ) {
return "@" + space.environmentSubstitute( targetSchema ) + ".%" + space.environmentSubstitute( targetTable );
} else {
return "@%" + space.environmentSubstitute( targetTable );
}
} else if ( locationType.equals( LOCATION_TYPE_CODES[LOCATION_TYPE_INTERNAL_STAGE] ) ) {
if ( !Const.isEmpty( space.environmentSubstitute( targetSchema ) ) ) {
return "@" + space.environmentSubstitute( targetSchema ) + "." + space.environmentSubstitute( stageName );
} else {
return "@" + space.environmentSubstitute( stageName );
}
}
return null;
}
示例2: getFields
import org.pentaho.di.core.variables.VariableSpace; //導入方法依賴的package包/類
@Override
public void getFields(RowMetaInterface row, String name, RowMetaInterface[] info, StepMeta nextStep, VariableSpace space, Repository repository, IMetaStore metaStore)
throws KettleStepException {
CassandraConnection connection;
String nodes = space.environmentSubstitute(this.cassandraNodes);
String port = space.environmentSubstitute(this.cassandraPort);
String keyspace = space.environmentSubstitute(this.keyspace);
String cql = space.environmentSubstitute(this.cqlStatement);
if ((Const.isEmpty(nodes)) || (Const.isEmpty(port)) || (Const.isEmpty(keyspace)) || (Const.isEmpty(cql))) {
return;
}
String user = space.environmentSubstitute(this.username);
String pass = space.environmentSubstitute(this.password);
String trustfile = space.environmentSubstitute(this.trustStoreFilePath);
String trustpass = space.environmentSubstitute(this.trustStorePass);
logDebug("meta: opening connection");
try {
connection = Utils.connect(nodes, port, user, pass, keyspace, this.SslEnabled, trustfile, trustpass, this.compression);
} catch (CassandraConnectionException e) {
throw new KettleStepException("Failed to create connection", e);
}
Session session = connection.getSession();
logDebug("meta: parsing cql '" + cql + "'");
ResultSet rs = session.execute(cql);
createOutputRowMeta(row, rs);
connection.release();
}
示例3: getProp
import org.pentaho.di.core.variables.VariableSpace; //導入方法依賴的package包/類
/**
* 獲取參數 <br/>
* @author jingma
* @param vs
* @param key 參數名稱
* @return 值
*/
public static String getProp(VariableSpace vs, String key){
String value = vs.environmentSubstitute("${"+key+"}");
if(value.startsWith("${")){
return "";
}else{
return value;
}
}
示例4: getRestUrl
import org.pentaho.di.core.variables.VariableSpace; //導入方法依賴的package包/類
public String getRestUrl(VariableSpace space) {
/*
* Construct the following URL:
*
* http://tenant.namespace.server:port/rest
*/
StringBuilder url = new StringBuilder();
if (useSSL) {
url.append("https://");
} else {
url.append("http://");
}
url.append(space.environmentSubstitute(tenant)).append('.');
url.append(space.environmentSubstitute(namespace)).append('.');
url.append(space.environmentSubstitute(server));
String realPort = space.environmentSubstitute(port);
if (StringUtils.isNotEmpty(realPort)) {
url.append(':').append(realPort);
}
url.append("/rest");
return url.toString();
}
示例5: buildFilename
import org.pentaho.di.core.variables.VariableSpace; //導入方法依賴的package包/類
/**
* Builds a filename for a temporary file The filename is in tableName_date_time_stepnr_partnr_splitnr.gz format
*
* @param space The variables currently set
* @param stepNumber The step number. Used when multiple copies of the step are started.
* @param partNumber The partition number. Used when the transformation is executed clustered, the number of the
* partition.
* @param splitNumber The split number. Used when the file is split into multiple chunks.
* @return The filename to use
*/
public String buildFilename( VariableSpace space, int stepNumber, String partNumber,
int splitNumber ) {
SimpleDateFormat daf = new SimpleDateFormat();
// Replace possible environment variables...
String realWorkDirectory = space.environmentSubstitute( workDirectory );
//Files are always gzipped
String extension = ".gz";
StringBuilder returnValue = new StringBuilder( realWorkDirectory );
if ( !realWorkDirectory.endsWith( "/" ) && !realWorkDirectory.endsWith( "\\" ) ) {
returnValue.append( Const.FILE_SEPARATOR );
}
returnValue.append( targetTable ).append( "_" );
if ( fileDate == null ) {
Date now = new Date();
daf.applyPattern( "yyyyMMdd_HHmmss" );
fileDate = daf.format( now );
}
returnValue.append( fileDate ).append( "_" );
returnValue.append( stepNumber ).append( "_" );
returnValue.append( partNumber ).append( "_" );
returnValue.append( splitNumber );
returnValue.append( extension );
return returnValue.toString();
}
示例6: getRequiredFields
import org.pentaho.di.core.variables.VariableSpace; //導入方法依賴的package包/類
/**
* Gets a list of fields in the database table
* @param space The variable space
* @return The metadata about the fields in the table.
* @throws KettleException
*/
public RowMetaInterface getRequiredFields( VariableSpace space ) throws KettleException {
String realTableName = space.environmentSubstitute( targetTable );
String realSchemaName = space.environmentSubstitute( targetSchema );
if ( databaseMeta != null ) {
Database db = new Database( loggingObject, databaseMeta );
try {
db.connect();
if ( !Const.isEmpty( realTableName ) ) {
String schemaTable = databaseMeta.getQuotedSchemaTableCombination( realSchemaName, realTableName );
// Check if this table exists...
if ( db.checkTableExists( schemaTable ) ) {
return db.getTableFields( schemaTable );
} else {
throw new KettleException( BaseMessages.getString( PKG, "SnowflakeBulkLoaderMeta.Exception.TableNotFound" ) );
}
} else {
throw new KettleException( BaseMessages.getString( PKG, "SnowflakeBulkLoaderMeta.Exception.TableNotSpecified" ) );
}
} catch ( Exception e ) {
throw new KettleException(
BaseMessages.getString( PKG, "SnowflakeBulkLoaderMeta.Exception.ErrorGettingFields" ), e );
} finally {
db.disconnect();
}
} else {
throw new KettleException( BaseMessages.getString( PKG, "SnowflakeBulkLoaderMeta.Exception.ConnectionNotDefined" ) );
}
}
示例7: getFields
import org.pentaho.di.core.variables.VariableSpace; //導入方法依賴的package包/類
public void getFields(RowMetaInterface inputRowMeta, String name,
RowMetaInterface[] info, StepMeta nextStep, VariableSpace space,
Repository repository, IMetaStore metaStore) throws KettleStepException {
// Output field (String)
ValueMetaInterface v = new ValueMetaDom(
space.environmentSubstitute(getResultfieldname()),
ValueMetaDom.TYPE_DOM);
v.setOrigin(name);
inputRowMeta.addValueMeta(v);
}
示例8: getFields
import org.pentaho.di.core.variables.VariableSpace; //導入方法依賴的package包/類
public void getFields(RowMetaInterface r, String name, RowMetaInterface info[], StepMeta nextStep, VariableSpace space) throws KettleStepException {
if(StringUtils.isNotBlank(this.getIdOutField()) ){
ValueMetaInterface valueMeta = new ValueMeta(space.environmentSubstitute(this.getIdOutField()), ValueMetaInterface.TYPE_STRING);
valueMeta.setOrigin(name);
//add if doesn't exist
if(!r.exists(valueMeta)){
r.addValueMeta(valueMeta);
}
}
}
示例9: getFields
import org.pentaho.di.core.variables.VariableSpace; //導入方法依賴的package包/類
public void getFields( RowMetaInterface row, String name, RowMetaInterface[] info, StepMeta nextStep,
VariableSpace space, Repository repository, IMetaStore metaStore ) throws KettleStepException {
// change the case insensitive flag too
if ( outputType.equalsIgnoreCase( "field" ) ) {
ValueMetaInterface v = new ValueMeta( space.environmentSubstitute( outputFieldName ), ValueMetaInterface.TYPE_STRING );
v.setOrigin( name );
row.addValueMeta( v );
}
}
示例10: validate
import org.pentaho.di.core.variables.VariableSpace; //導入方法依賴的package包/類
public boolean validate(CheckResultSourceInterface source, String propertyName, List<CheckResultInterface> remarks,
ValidatorContext context)
{
String filename = ValidatorUtils.getValueAsString(source, propertyName);
VariableSpace variableSpace = getVariableSpace(source, propertyName, remarks, context);
boolean failIfExists = getFailIfExists(source, propertyName, remarks, context);
if (null == variableSpace)
{
return false;
}
String realFileName = variableSpace.environmentSubstitute(filename);
FileObject fileObject = null;
try
{
fileObject = KettleVFS.getFileObject(realFileName, variableSpace);
if (fileObject.exists() && failIfExists)
{
JobEntryValidatorUtils.addFailureRemark(source, propertyName, VALIDATOR_NAME, remarks, JobEntryValidatorUtils
.getLevelOnFail(context, VALIDATOR_NAME));
return false;
}
try
{
fileObject.close(); // Just being paranoid
} catch (IOException ignored)
{
}
} catch (Exception e)
{
JobEntryValidatorUtils.addExceptionRemark(source, propertyName, VALIDATOR_NAME, remarks, e);
return false;
}
return true;
}
示例11: getRequiredFields
import org.pentaho.di.core.variables.VariableSpace; //導入方法依賴的package包/類
public RowMetaInterface getRequiredFields(VariableSpace space)
throws KettleException {
String realTableName = space.environmentSubstitute(tableName);
String realSchemaName = space.environmentSubstitute(schemaName);
if (databaseMeta != null) {
Database db = new Database(loggingObject, databaseMeta);
try {
db.connect();
if (!Const.isEmpty(realTableName)) {
String schemaTable = databaseMeta.getQuotedSchemaTableCombination(
realSchemaName, realTableName);
// Check if this table exists...
if (db.checkTableExists(schemaTable)) {
return db.getTableFields(schemaTable);
} else {
throw new KettleException(BaseMessages.getString(PKG,
"LucidDBStreamingLoaderMeta.Exception.TableNotFound"));
}
} else {
throw new KettleException(BaseMessages.getString(PKG,
"LucidDBStreamingLoaderMeta.Exception.TableNotSpecified"));
}
} catch (Exception e) {
throw new KettleException(BaseMessages.getString(PKG,
"LucidDBStreamingLoaderMeta.Exception.ErrorGettingFields"), e);
} finally {
db.disconnect();
}
} else {
throw new KettleException(BaseMessages.getString(PKG,
"LucidDBStreamingLoaderMeta.Exception.ConnectionNotDefined"));
}
}
示例12: validate
import org.pentaho.di.core.variables.VariableSpace; //導入方法依賴的package包/類
public boolean validate(CheckResultSourceInterface source, String propertyName, List<CheckResultInterface> remarks,
ValidatorContext context)
{
String filename = ValidatorUtils.getValueAsString(source, propertyName);
VariableSpace variableSpace = getVariableSpace(source, propertyName, remarks, context);
boolean failIfDoesNotExist = getFailIfDoesNotExist(source, propertyName, remarks, context);
if (null == variableSpace)
{
return false;
}
String realFileName = variableSpace.environmentSubstitute(filename);
FileObject fileObject = null;
try
{
fileObject = KettleVFS.getFileObject(realFileName);
if (fileObject == null || (fileObject != null && !fileObject.exists() && failIfDoesNotExist))
{
JobEntryValidatorUtils.addFailureRemark(source, propertyName, VALIDATOR_NAME, remarks, JobEntryValidatorUtils
.getLevelOnFail(context, VALIDATOR_NAME));
return false;
}
try
{
fileObject.close(); // Just being paranoid
} catch (IOException ignored)
{
}
} catch (Exception e)
{
JobEntryValidatorUtils.addExceptionRemark(source, propertyName, VALIDATOR_NAME, remarks, e);
return false;
}
return true;
}
示例13: getFields
import org.pentaho.di.core.variables.VariableSpace; //導入方法依賴的package包/類
public void getFields(RowMetaInterface inputRowMeta, String name, RowMetaInterface info[], StepMeta nextStep, VariableSpace space) throws KettleStepException
{
// Output field (String)
if (!Const.isEmpty(resultfieldname))
{
ValueMetaInterface v = new ValueMeta(space.environmentSubstitute(resultfieldname), ValueMeta.TYPE_BOOLEAN);
v.setOrigin(name);
inputRowMeta.addValueMeta(v);
}
}
示例14: getFields
import org.pentaho.di.core.variables.VariableSpace; //導入方法依賴的package包/類
public void getFields(RowMetaInterface row, String origin, RowMetaInterface[] info, StepMeta nextStep, VariableSpace space) throws KettleStepException
{
// Just add the returning key field...
if (returningGeneratedKeys && generatedKeyField!=null && generatedKeyField.length()>0)
{
ValueMetaInterface key = new ValueMeta(space.environmentSubstitute(generatedKeyField), ValueMetaInterface.TYPE_INTEGER);
key.setOrigin(origin);
row.addValueMeta(key);
}
}
示例15: getFields
import org.pentaho.di.core.variables.VariableSpace; //導入方法依賴的package包/類
public void getFields(RowMetaInterface inputRowMeta, String name, RowMetaInterface info[], StepMeta nextStep, VariableSpace space) throws KettleStepException
{
if (!Const.isEmpty(linenumfield))
{
ValueMetaInterface v = new ValueMeta(space.environmentSubstitute(linenumfield), ValueMeta.TYPE_INTEGER);
v.setLength(ValueMetaInterface.DEFAULT_INTEGER_LENGTH, 0);
v.setOrigin(name);
inputRowMeta.addValueMeta(v);
}
}