# 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/%TESTNUMBER -Q "NOOP 1" -Q "+NOOP 2" -Q "-NOOP 3" -Q "*FAIL" -Q "+*FAIL HARD" --libcurl %LOGDIR/test%TESTNUMBER.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 %TESTNUMBER RETR %TESTNUMBER NOOP 3 QUIT /********* Sample code generated by the curl command line tool ********** * All curl_easy_setopt() options are documented at: * https://curl.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/%TESTNUMBER"); 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_FTP_SKIP_PASV_IP, 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 choose to either not use them or implement them yourself. CURLOPT_WRITEDATA was set to an object pointer CURLOPT_WRITEFUNCTION was set to a function pointer CURLOPT_READDATA was set to an object pointer CURLOPT_READFUNCTION was set to a function pointer CURLOPT_SEEKDATA was set to an object pointer CURLOPT_SEEKFUNCTION was set to a function pointer CURLOPT_ERRORBUFFER was set to an object pointer CURLOPT_STDERR was set to an object pointer CURLOPT_DEBUGFUNCTION was set to a function pointer CURLOPT_DEBUGDATA was set to an object pointer CURLOPT_HEADERFUNCTION was set to a function pointer CURLOPT_HEADERDATA was set to an object pointer */ 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 # CURLOPT_INTERLEAVEDATA requires RTSP (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/ $_ = '' if /CURLOPT_HTTP09_ALLOWED/ $_ = '' if /CURLOPT_INTERLEAVEDATA/