# Derived from test227 FTP post-quote pre-quote --libcurl # Server-side data to see that FTP works so does it? REPLY EPSV 500 no such command REPLY FAIL 500 this might not be a failure! # Client-side ftp --libcurl for FTP with quote ops SSL_CERT_FILE= ftp://%HOSTIP:%FTPPORT/1405 -Q "NOOP 1" -Q "+NOOP 2" -Q "-NOOP 3" -Q "*FAIL" -Q "+*FAIL HARD" --libcurl log/test1405.c # Verify data after the test has been "shot" USER anonymous PASS ftp@example.com PWD NOOP 1 FAIL EPSV PASV TYPE I NOOP 2 FAIL HARD SIZE 1405 RETR 1405 NOOP 3 QUIT /********* Sample code generated by the curl command line tool ********** * All curl_easy_setopt() options are documented at: * https://curl.haxx.se/libcurl/c/curl_easy_setopt.html ************************************************************************/ #include int main(int argc, char *argv[]) { CURLcode ret; CURL *hnd; struct curl_slist *slist1; struct curl_slist *slist2; struct curl_slist *slist3; slist1 = NULL; slist1 = curl_slist_append(slist1, "NOOP 1"); slist1 = curl_slist_append(slist1, "*FAIL"); slist2 = NULL; slist2 = curl_slist_append(slist2, "NOOP 3"); slist3 = NULL; slist3 = curl_slist_append(slist3, "NOOP 2"); slist3 = curl_slist_append(slist3, "*FAIL HARD"); hnd = curl_easy_init(); curl_easy_setopt(hnd, CURLOPT_BUFFERSIZE, 102400L); curl_easy_setopt(hnd, CURLOPT_URL, "ftp://%HOSTIP:%FTPPORT/1405"); curl_easy_setopt(hnd, CURLOPT_HEADER, 1L); curl_easy_setopt(hnd, CURLOPT_QUOTE, slist1); curl_easy_setopt(hnd, CURLOPT_POSTQUOTE, slist2); curl_easy_setopt(hnd, CURLOPT_PREQUOTE, slist3); curl_easy_setopt(hnd, CURLOPT_VERBOSE, 1L); curl_easy_setopt(hnd, CURLOPT_TCP_KEEPALIVE, 1L); /* Here is a list of options the curl code used that cannot get generated as source easily. You may select to either not use them or implement them yourself. CURLOPT_WRITEDATA set to a objectpointer CURLOPT_INTERLEAVEDATA set to a objectpointer CURLOPT_WRITEFUNCTION set to a functionpointer CURLOPT_READDATA set to a objectpointer CURLOPT_READFUNCTION set to a functionpointer CURLOPT_SEEKDATA set to a objectpointer CURLOPT_SEEKFUNCTION set to a functionpointer CURLOPT_ERRORBUFFER set to a objectpointer CURLOPT_STDERR set to a objectpointer CURLOPT_DEBUGFUNCTION set to a functionpointer CURLOPT_DEBUGDATA set to a objectpointer CURLOPT_HEADERFUNCTION set to a functionpointer CURLOPT_HEADERDATA set to a objectpointer */ ret = curl_easy_perform(hnd); curl_easy_cleanup(hnd); hnd = NULL; curl_slist_free_all(slist1); slist1 = NULL; curl_slist_free_all(slist2); slist2 = NULL; curl_slist_free_all(slist3); slist3 = NULL; return (int)ret; } /**** End of sample code ****/ # CURLOPT_USERAGENT and CURLOPT_MAXREDIRS requires HTTP protocol # support, IOW depends on configuration - just ignore these. $_ = '' if /CURLOPT_USERAGENT/ $_ = '' if /CURLOPT_MAXREDIRS/ # CURLOPT_SSL_VERIFYPEER, SSH_KNOWNHOSTS and HTTP_VERSION vary with # configurations - just ignore them $_ = '' if /CURLOPT_SSL_VERIFYPEER/ $_ = '' if /CURLOPT_SSH_KNOWNHOSTS/ $_ = '' if /CURLOPT_HTTP_VERSION/