dm_ftp_download Function

public function dm_ftp_download(server, remote_file, local_file, error_message, error_curl, debug) result(rc)

Uses

  • proc~~dm_ftp_download~~UsesGraph proc~dm_ftp_download dm_ftp_download module~dm_c dm_c proc~dm_ftp_download->module~dm_c module~dm_file dm_file proc~dm_ftp_download->module~dm_file unix unix proc~dm_ftp_download->unix module~dm_c->unix module~dm_kind dm_kind module~dm_c->module~dm_kind module~dm_error dm_error module~dm_file->module~dm_error module~dm_file->module~dm_kind module~dm_error->module~dm_kind module~dm_ascii dm_ascii module~dm_error->module~dm_ascii iso_fortran_env iso_fortran_env module~dm_kind->iso_fortran_env

Downloads remote file from FTP server.

The function returns the following error codes:

  • E_COMPILER if C pointers could not be nullified (compiler bug).
  • E_EXIST if local file exists.
  • E_FTP if libcurl initialisation failed.
  • E_FTP_AUTH if FTP authentication failed.
  • E_FTP_CONNECT if connection to server could not be established.
  • E_FTP_SSL if SSL/TLS error occured.
  • E_INVALID if arguments or FTP server type attributes are invalid.
  • E_IO if local file could not be opened for writing.

Arguments

Type IntentOptional Attributes Name
type(ftp_server_type), intent(inout) :: server

FTP server type.

character(len=*), intent(in) :: remote_file

Path of remote file.

character(len=*), intent(in) :: local_file

Path of file to upload.

character(len=:), intent(out), optional, allocatable :: error_message

Error message.

integer, intent(out), optional :: error_curl

cURL error code.

logical, intent(in), optional :: debug

Output debug messages.

Return Value integer


Calls

proc~~dm_ftp_download~~CallsGraph proc~dm_ftp_download dm_ftp_download c_fclose c_fclose proc~dm_ftp_download->c_fclose c_fopen c_fopen proc~dm_ftp_download->c_fopen curl_easy_cleanup curl_easy_cleanup proc~dm_ftp_download->curl_easy_cleanup curl_easy_init curl_easy_init proc~dm_ftp_download->curl_easy_init curl_easy_perform curl_easy_perform proc~dm_ftp_download->curl_easy_perform curl_easy_setopt curl_easy_setopt proc~dm_ftp_download->curl_easy_setopt interface~dm_present dm_present proc~dm_ftp_download->interface~dm_present interface~dm_sec_to_msec dm_sec_to_msec proc~dm_ftp_download->interface~dm_sec_to_msec proc~dm_f_c_string dm_f_c_string proc~dm_ftp_download->proc~dm_f_c_string proc~dm_file_exists dm_file_exists proc~dm_ftp_download->proc~dm_file_exists proc~dm_ftp_error dm_ftp_error proc~dm_ftp_download->proc~dm_ftp_error proc~dm_ftp_error_message dm_ftp_error_message proc~dm_ftp_download->proc~dm_ftp_error_message proc~dm_ftp_url dm_ftp_url proc~dm_ftp_download->proc~dm_ftp_url proc~dm_is_error dm_is_error proc~dm_ftp_download->proc~dm_is_error curl_easy_strerror curl_easy_strerror proc~dm_ftp_error_message->curl_easy_strerror proc~dm_ftp_url->interface~dm_present curl_url curl_url proc~dm_ftp_url->curl_url curl_url_cleanup curl_url_cleanup proc~dm_ftp_url->curl_url_cleanup curl_url_get curl_url_get proc~dm_ftp_url->curl_url_get curl_url_set curl_url_set proc~dm_ftp_url->curl_url_set interface~dm_itoa dm_itoa proc~dm_ftp_url->interface~dm_itoa proc~dm_string_is_present dm_string_is_present proc~dm_ftp_url->proc~dm_string_is_present