NIFI-10559 Clarified remote path can come from flowfile attributes and made inherited prop descriptors more obvious

This closes #6457

Signed-off-by: David Handermann <exceptionfactory@apache.org>
This commit is contained in:
Joe Witt 2022-09-28 13:14:12 -07:00 committed by exceptionfactory
parent 6461061e8f
commit 1a99b9611c
No known key found for this signature in database
GPG Key ID: 29B6A52D2AAE8DBA
2 changed files with 19 additions and 18 deletions

View File

@ -34,6 +34,7 @@ import org.apache.nifi.components.ValidationResult;
import org.apache.nifi.processor.ProcessContext; import org.apache.nifi.processor.ProcessContext;
import org.apache.nifi.processor.ProcessorInitializationContext; import org.apache.nifi.processor.ProcessorInitializationContext;
import org.apache.nifi.processors.standard.util.FTPTransfer; import org.apache.nifi.processors.standard.util.FTPTransfer;
import org.apache.nifi.processors.standard.util.FileTransfer;
import org.apache.nifi.processors.standard.util.SFTPTransfer; import org.apache.nifi.processors.standard.util.SFTPTransfer;
@SupportsBatching @SupportsBatching
@ -50,30 +51,30 @@ public class PutSFTP extends PutFileTransfer<SFTPTransfer> {
@Override @Override
protected void init(final ProcessorInitializationContext context) { protected void init(final ProcessorInitializationContext context) {
final List<PropertyDescriptor> properties = new ArrayList<>(); final List<PropertyDescriptor> properties = new ArrayList<>();
properties.add(SFTPTransfer.HOSTNAME); properties.add(FileTransfer.HOSTNAME);
properties.add(SFTPTransfer.PORT); properties.add(SFTPTransfer.PORT);
properties.add(SFTPTransfer.USERNAME); properties.add(FileTransfer.USERNAME);
properties.add(SFTPTransfer.PASSWORD); properties.add(FileTransfer.PASSWORD);
properties.add(SFTPTransfer.PRIVATE_KEY_PATH); properties.add(SFTPTransfer.PRIVATE_KEY_PATH);
properties.add(SFTPTransfer.PRIVATE_KEY_PASSPHRASE); properties.add(SFTPTransfer.PRIVATE_KEY_PASSPHRASE);
properties.add(SFTPTransfer.REMOTE_PATH); properties.add(FileTransfer.REMOTE_PATH);
properties.add(SFTPTransfer.CREATE_DIRECTORY); properties.add(FileTransfer.CREATE_DIRECTORY);
properties.add(SFTPTransfer.DISABLE_DIRECTORY_LISTING); properties.add(SFTPTransfer.DISABLE_DIRECTORY_LISTING);
properties.add(SFTPTransfer.BATCH_SIZE); properties.add(FileTransfer.BATCH_SIZE);
properties.add(SFTPTransfer.CONNECTION_TIMEOUT); properties.add(FileTransfer.CONNECTION_TIMEOUT);
properties.add(SFTPTransfer.DATA_TIMEOUT); properties.add(FileTransfer.DATA_TIMEOUT);
properties.add(SFTPTransfer.CONFLICT_RESOLUTION); properties.add(FileTransfer.CONFLICT_RESOLUTION);
properties.add(SFTPTransfer.REJECT_ZERO_BYTE); properties.add(FileTransfer.REJECT_ZERO_BYTE);
properties.add(SFTPTransfer.DOT_RENAME); properties.add(FileTransfer.DOT_RENAME);
properties.add(SFTPTransfer.TEMP_FILENAME); properties.add(FileTransfer.TEMP_FILENAME);
properties.add(SFTPTransfer.HOST_KEY_FILE); properties.add(SFTPTransfer.HOST_KEY_FILE);
properties.add(SFTPTransfer.LAST_MODIFIED_TIME); properties.add(FileTransfer.LAST_MODIFIED_TIME);
properties.add(SFTPTransfer.PERMISSIONS); properties.add(FileTransfer.PERMISSIONS);
properties.add(SFTPTransfer.REMOTE_OWNER); properties.add(FileTransfer.REMOTE_OWNER);
properties.add(SFTPTransfer.REMOTE_GROUP); properties.add(FileTransfer.REMOTE_GROUP);
properties.add(SFTPTransfer.STRICT_HOST_KEY_CHECKING); properties.add(SFTPTransfer.STRICT_HOST_KEY_CHECKING);
properties.add(SFTPTransfer.USE_KEEPALIVE_ON_TIMEOUT); properties.add(SFTPTransfer.USE_KEEPALIVE_ON_TIMEOUT);
properties.add(SFTPTransfer.USE_COMPRESSION); properties.add(FileTransfer.USE_COMPRESSION);
properties.add(SFTPTransfer.PROXY_CONFIGURATION_SERVICE); properties.add(SFTPTransfer.PROXY_CONFIGURATION_SERVICE);
properties.add(FTPTransfer.PROXY_TYPE); properties.add(FTPTransfer.PROXY_TYPE);
properties.add(FTPTransfer.PROXY_HOST); properties.add(FTPTransfer.PROXY_HOST);

View File

@ -111,7 +111,7 @@ public interface FileTransfer extends Closeable {
.description("The path on the remote system from which to pull or push files") .description("The path on the remote system from which to pull or push files")
.required(false) .required(false)
.addValidator(StandardValidators.NON_EMPTY_VALIDATOR) .addValidator(StandardValidators.NON_EMPTY_VALIDATOR)
.expressionLanguageSupported(ExpressionLanguageScope.VARIABLE_REGISTRY) .expressionLanguageSupported(ExpressionLanguageScope.FLOWFILE_ATTRIBUTES)
.build(); .build();
public static final PropertyDescriptor CREATE_DIRECTORY = new PropertyDescriptor.Builder() public static final PropertyDescriptor CREATE_DIRECTORY = new PropertyDescriptor.Builder()
.name("Create Directory") .name("Create Directory")