113498266Sopenharmony_ci/*************************************************************************** 213498266Sopenharmony_ci * _ _ ____ _ 313498266Sopenharmony_ci * Project ___| | | | _ \| | 413498266Sopenharmony_ci * / __| | | | |_) | | 513498266Sopenharmony_ci * | (__| |_| | _ <| |___ 613498266Sopenharmony_ci * \___|\___/|_| \_\_____| 713498266Sopenharmony_ci * 813498266Sopenharmony_ci * Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al. 913498266Sopenharmony_ci * 1013498266Sopenharmony_ci * This software is licensed as described in the file COPYING, which 1113498266Sopenharmony_ci * you should have received as part of this distribution. The terms 1213498266Sopenharmony_ci * are also available at https://curl.se/docs/copyright.html. 1313498266Sopenharmony_ci * 1413498266Sopenharmony_ci * You may opt to use, copy, modify, merge, publish, distribute and/or sell 1513498266Sopenharmony_ci * copies of the Software, and permit persons to whom the Software is 1613498266Sopenharmony_ci * furnished to do so, under the terms of the COPYING file. 1713498266Sopenharmony_ci * 1813498266Sopenharmony_ci * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY 1913498266Sopenharmony_ci * KIND, either express or implied. 2013498266Sopenharmony_ci * 2113498266Sopenharmony_ci * SPDX-License-Identifier: curl 2213498266Sopenharmony_ci * 2313498266Sopenharmony_ci ***************************************************************************/ 2413498266Sopenharmony_ci/* <DESC> 2513498266Sopenharmony_ci * Gets a file using an SFTP URL. 2613498266Sopenharmony_ci * </DESC> 2713498266Sopenharmony_ci */ 2813498266Sopenharmony_ci 2913498266Sopenharmony_ci#include <stdio.h> 3013498266Sopenharmony_ci 3113498266Sopenharmony_ci#include <curl/curl.h> 3213498266Sopenharmony_ci 3313498266Sopenharmony_ci/* define this to switch off the use of ssh-agent in this program */ 3413498266Sopenharmony_ci#undef DISABLE_SSH_AGENT 3513498266Sopenharmony_ci 3613498266Sopenharmony_ci/* 3713498266Sopenharmony_ci * This is an example showing how to get a single file from an SFTP server. 3813498266Sopenharmony_ci * It delays the actual destination file creation until the first write 3913498266Sopenharmony_ci * callback so that it will not create an empty file in case the remote file 4013498266Sopenharmony_ci * does not exist or something else fails. 4113498266Sopenharmony_ci */ 4213498266Sopenharmony_ci 4313498266Sopenharmony_cistruct FtpFile { 4413498266Sopenharmony_ci const char *filename; 4513498266Sopenharmony_ci FILE *stream; 4613498266Sopenharmony_ci}; 4713498266Sopenharmony_ci 4813498266Sopenharmony_cistatic size_t my_fwrite(void *buffer, size_t size, size_t nmemb, 4913498266Sopenharmony_ci void *stream) 5013498266Sopenharmony_ci{ 5113498266Sopenharmony_ci struct FtpFile *out = (struct FtpFile *)stream; 5213498266Sopenharmony_ci if(!out->stream) { 5313498266Sopenharmony_ci /* open file for writing */ 5413498266Sopenharmony_ci out->stream = fopen(out->filename, "wb"); 5513498266Sopenharmony_ci if(!out->stream) 5613498266Sopenharmony_ci return 0; /* failure, cannot open file to write */ 5713498266Sopenharmony_ci } 5813498266Sopenharmony_ci return fwrite(buffer, size, nmemb, out->stream); 5913498266Sopenharmony_ci} 6013498266Sopenharmony_ci 6113498266Sopenharmony_ci 6213498266Sopenharmony_ciint main(void) 6313498266Sopenharmony_ci{ 6413498266Sopenharmony_ci CURL *curl; 6513498266Sopenharmony_ci CURLcode res; 6613498266Sopenharmony_ci struct FtpFile ftpfile = { 6713498266Sopenharmony_ci "yourfile.bin", /* name to store the file as if successful */ 6813498266Sopenharmony_ci NULL 6913498266Sopenharmony_ci }; 7013498266Sopenharmony_ci 7113498266Sopenharmony_ci curl_global_init(CURL_GLOBAL_DEFAULT); 7213498266Sopenharmony_ci 7313498266Sopenharmony_ci curl = curl_easy_init(); 7413498266Sopenharmony_ci if(curl) { 7513498266Sopenharmony_ci /* 7613498266Sopenharmony_ci * You better replace the URL with one that works! 7713498266Sopenharmony_ci */ 7813498266Sopenharmony_ci curl_easy_setopt(curl, CURLOPT_URL, 7913498266Sopenharmony_ci "sftp://user@server/home/user/file.txt"); 8013498266Sopenharmony_ci /* Define our callback to get called when there is data to be written */ 8113498266Sopenharmony_ci curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, my_fwrite); 8213498266Sopenharmony_ci /* Set a pointer to our struct to pass to the callback */ 8313498266Sopenharmony_ci curl_easy_setopt(curl, CURLOPT_WRITEDATA, &ftpfile); 8413498266Sopenharmony_ci 8513498266Sopenharmony_ci#ifndef DISABLE_SSH_AGENT 8613498266Sopenharmony_ci /* We activate ssh agent. For this to work you need 8713498266Sopenharmony_ci to have ssh-agent running (type set | grep SSH_AGENT to check) or 8813498266Sopenharmony_ci pageant on Windows (there is an icon in systray if so) */ 8913498266Sopenharmony_ci curl_easy_setopt(curl, CURLOPT_SSH_AUTH_TYPES, CURLSSH_AUTH_AGENT); 9013498266Sopenharmony_ci#endif 9113498266Sopenharmony_ci 9213498266Sopenharmony_ci /* Switch on full protocol/debug output */ 9313498266Sopenharmony_ci curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L); 9413498266Sopenharmony_ci 9513498266Sopenharmony_ci res = curl_easy_perform(curl); 9613498266Sopenharmony_ci 9713498266Sopenharmony_ci /* always cleanup */ 9813498266Sopenharmony_ci curl_easy_cleanup(curl); 9913498266Sopenharmony_ci 10013498266Sopenharmony_ci if(CURLE_OK != res) { 10113498266Sopenharmony_ci /* we failed */ 10213498266Sopenharmony_ci fprintf(stderr, "curl told us %d\n", res); 10313498266Sopenharmony_ci } 10413498266Sopenharmony_ci } 10513498266Sopenharmony_ci 10613498266Sopenharmony_ci if(ftpfile.stream) 10713498266Sopenharmony_ci fclose(ftpfile.stream); /* close the local file */ 10813498266Sopenharmony_ci 10913498266Sopenharmony_ci curl_global_cleanup(); 11013498266Sopenharmony_ci 11113498266Sopenharmony_ci return 0; 11213498266Sopenharmony_ci} 113