NAME

EAI::FTP - wrapper for Net::SFTP::Foreign and Net::FTP

SYNOPSIS

removeFilesOlderX ($param)
fetchFiles ($FTP,$param)
putFile ($FTP,$param)
moveTempFile ($FTP,$param)
archiveFiles ($param)
removeFiles ($param)
login ($FTP,$setRemoteHost)
setHandle ($handle,$remoteHost)
getHandle ()

DESCRIPTION

EAI::FTP contains all (secure) FTP related API-calls. This is for logging in to a FTP Server, getting files from a remote folder, writing files to a remote folder, archiving/deleting files from/on a remote folder (to an archive folder) and removing files on an FTP server being older than a Date X.

API

removeFilesOlderX ($)

remove files on FTP server being older than a time back (given in remove)

$param .. ref to hash with function parameters:
$param->{remove}{removeFolders} .. list of folders where files should be removed
$param->{remove}{day} .. days back to remove
$param->{remove}{mon} .. months back to remove
$param->{remove}{year} .. years back to remove
$param->{remoteDir} .. remote directory where files are located

returns 1 if ALL files were removed successfully, 0 on error (doesn't exit early)

fetchFiles ($$)

fetch files from FTP server

$FTP .. ref to hash with general FTP parameters:
$FTP->{queue_size} .. queue_size for Net::SFTP::Foreign, if > 1 this causes often connection issues
$FTP->{remoteDir} .. remote directory where files are located
$FTP->{path} .. path of folder of file below remoteDir
$FTP->{localDir} .. alternative storage path, if not given then files are stored to
$FTP->{fileToRemove} .. ignore errors for a file that was either removed or is optional 
$FTP->{dontDoUtime} .. don't set time stamp of local file to that of remote file
$param .. ref to hash with function parameters:
$param->{fileToRetrieve} .. file to retrieve. if a glob (*) is contained, then multiple files are retrieved
$param->{fileToRetrieveOptional} .. flag that file is optional
$param->{firstRunSuccess} .. used to suppress fetching errors (if first run was already successful)
$param->{homedir} .. standard storage path
$param->{retrievedFiles} .. returned array with retrieved file (or files if glob was given)

returns 1 if ALL files were fetched successfully, 0 on error (doesn't exit early)

putFile ($$)

put file to FTP server

The file is written either directly ($FTP->{dontUseTempFile} 1) or as temp.<name> file ($FTP->{dontUseTempFile} = 0 or not set), these temp files are immediately renamed on the server (if $FTP->{dontMoveTempImmediately} = 0 or not set), when $FTP->{dontMoveTempImmediately} =1 then this waits until moveTempFile is called. This is needed to have an atomic transaction for file monitoring jobs on the FTP site! when $FTP->{dontDoSetStat} is set for Net::SFTP::Foreign handles, no setting of time stamp of remote file to that of local file is done (avoid error messages of FTP Server if it doesn't support this)

$FTP .. ref to hash with general FTP parameters:
$FTP->{dontUseTempFile} .. see above
$FTP->{dontMoveTempImmediately} .. see above
$FTP->{dontDoSetStat} .. see above
$FTP->{remoteDir} .. remote directory where files are located
$FTP->{additionalParams} .. additional Net::SFTP::Foreign params to be passed to ftp->put.
$param .. ref to hash with function parameters:
$param->{fileToWrite} .. single file to upload. this has to exist in local folder
$param->{filesToWrite} .. multiple files to upload (ref to array). files have to exist in local folder, either fileToWrite or filesToWrite are mandatory. If both are set, fileToWrite is merged into filesToWrite
$param->{remoteDir} .. remote directory where files are located
$param->{remoteDir} .. remote directory where files are located

returns 1 if ALL files were written successfully, 0 on error (exits on first error !)

moveTempFile ($$)

separately rename temp file on FTP Server to final name (atomic transaction !)

$FTP .. ref to hash with general FTP parameters:
$FTP->{remoteDir} .. remote directory where files are located
$param .. ref to hash with function parameters:
$param->{fileToWrite} ..  file to rename from temp to final
$param->{remoteDir} .. remote directory where files are located

returns 1 if ALL files were renamed successfully, 0 on error (exits on first error !)

archiveFiles ($)

archive files on FTP server, given in $param->{filesToArchive}

$param .. ref to hash with function parameters:
$param->{filesToArchive} .. ref to array with files to be archived if a glob is given, it is being resolved and all retrieved files are archived separately
$param->{timestamp} .. timestamp to prepend to file, if undef this is done with the current datetime (YYYYMMDD_hhmmss)
$param->{remoteDir} .. remote directory where files are located
$param->{archiveDir} .. folder for archived files on the FTP server

returns 1 if ALL files were archived successfully, 0 on error (doesn't exit early), except for "No such file or directory" errors, only warning is logged here

removeFiles ($)

delete files on FTP server, given in $param->{filesToRemove}

$param .. ref to hash with function parameters:
$param->{filesToRemove} .. ref to array with files to be deleted
$param->{remoteDir} .. remote directory where files are located

returns 1 if ALL files were deleted successfully, 0 on error (doesn't exit early), except for "No such file or directory" errors, only warning is logged here

login ($$)

log in to FTP server, stores the handle of the ftp connection

$FTP .. ref to hash with function parameters:
$FTP->{maxConnectionTries} ..  maximum number of tries for connecting in login procedure
$FTP->{sshInstallationPath} .. path were ssh/plink exe to be used by Net::SFTP::Foreign is located
$FTP->{user} .. for setting user directly
$FTP->{pwd} .. for setting password directly
$FTP->{dontUseQuoteSystemForPwd} .. for windows, a special quoting is used for passing passwords to Net::SFTP::Foreign that contain [()"<>& . This flag can be used to disable this quoting.
$FTP->{FTPdebugLevel} .. debug sftp:  0||~(1|2|4|8|16|1024|2048) for Net::SFTP:Foreign or 0||1 for Net::FTP, loglevel automatically set to debug for module EAI::FTP if FTPdebugLevel > 0
$FTP->{hostkey} .. hostkey to present to the server for Net::SFTP::Foreign, either directly (insecure -> visible) or via sensitive lookup
$FTP->{privKey} .. sftp key file location for Net::SFTP::Foreign, either directly (insecure -> visible) or via sensitive lookup
$FTP->{port} .. ftp/sftp port (leave empty for default ports 22 or 21)
$FTP->{SFTP} .. to explicitly use SFTP, if not given SFTP will be derived from existence of privKey or hostkey. If neither exists, an FTP connection will be opened.
$FTP->{moreparams} .. either a ref to an ARRAY or a ref to a HASH, used to pass more parameters into Net::SFTP::Foreign->new (as documented there)
$setRemoteHost .. remote host to be set

returns 1 if login was successful, 0 on error

setHandle ($$)

sets externally created Net::SFTP:Foreign or Net::FTP handle to be further used by EAI::FTP. Additionally the RemoteHost used in the handle can be passed (used for calls to login)

$handle .. ref to handle
$remoteHost .. remote Host
getHandle

returns the net-sftp-foreign/ftp handler and the RemoteHost string to allow direct commands with the handler

COPYRIGHT

Copyright (c) 2025 Roland Kapl

All rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

The full text of the license can be found in the LICENSE file included with this module.