#ifndef HEADER_CURL_SSH_H
#define HEADER_CURL_SSH_H
#include "../curl_setup.h"
#ifdef USE_LIBSSH2
#include <libssh2.h>
#include <libssh2_sftp.h>
#elif defined(USE_LIBSSH)
#define SSH_SUPPRESS_DEPRECATED
#include <libssh/libssh.h>
#include <libssh/sftp.h>
#endif
#include "curl_path.h"
#define CURL_META_SSH_EASY "meta:proto:ssh:easy"
#define CURL_META_SSH_CONN "meta:proto:ssh:conn"
typedef enum {
SSH_NO_STATE = -1,
SSH_STOP = 0,
SSH_INIT,
SSH_S_STARTUP,
SSH_HOSTKEY,
SSH_AUTHLIST,
SSH_AUTH_PKEY_INIT,
SSH_AUTH_PKEY,
SSH_AUTH_PASS_INIT,
SSH_AUTH_PASS,
SSH_AUTH_AGENT_INIT,
SSH_AUTH_AGENT_LIST,
SSH_AUTH_AGENT,
SSH_AUTH_HOST_INIT,
SSH_AUTH_HOST,
SSH_AUTH_KEY_INIT,
SSH_AUTH_KEY,
SSH_AUTH_GSSAPI,
SSH_AUTH_DONE,
SSH_SFTP_INIT,
SSH_SFTP_REALPATH,
SSH_SFTP_QUOTE_INIT,
SSH_SFTP_POSTQUOTE_INIT,
SSH_SFTP_QUOTE,
SSH_SFTP_NEXT_QUOTE,
SSH_SFTP_QUOTE_STAT,
SSH_SFTP_QUOTE_SETSTAT,
SSH_SFTP_QUOTE_SYMLINK,
SSH_SFTP_QUOTE_MKDIR,
SSH_SFTP_QUOTE_RENAME,
SSH_SFTP_QUOTE_RMDIR,
SSH_SFTP_QUOTE_UNLINK,
SSH_SFTP_QUOTE_STATVFS,
SSH_SFTP_GETINFO,
SSH_SFTP_FILETIME,
SSH_SFTP_TRANS_INIT,
SSH_SFTP_UPLOAD_INIT,
SSH_SFTP_CREATE_DIRS_INIT,
SSH_SFTP_CREATE_DIRS,
SSH_SFTP_CREATE_DIRS_MKDIR,
SSH_SFTP_READDIR_INIT,
SSH_SFTP_READDIR,
SSH_SFTP_READDIR_LINK,
SSH_SFTP_READDIR_BOTTOM,
SSH_SFTP_READDIR_DONE,
SSH_SFTP_DOWNLOAD_INIT,
SSH_SFTP_DOWNLOAD_STAT,
SSH_SFTP_CLOSE,
SSH_SFTP_SHUTDOWN,
SSH_SCP_TRANS_INIT,
SSH_SCP_UPLOAD_INIT,
SSH_SCP_DOWNLOAD_INIT,
SSH_SCP_DOWNLOAD,
SSH_SCP_DONE,
SSH_SCP_SEND_EOF,
SSH_SCP_WAIT_EOF,
SSH_SCP_WAIT_CLOSE,
SSH_SCP_CHANNEL_FREE,
SSH_SESSION_DISCONNECT,
SSH_SESSION_FREE,
SSH_QUIT,
SSH_LAST
} sshstate;
#define CURL_PATH_MAX 1024
struct SSHPROTO {
char *path;
#ifdef USE_LIBSSH2
struct dynbuf readdir_link;
struct dynbuf readdir;
char readdir_filename[CURL_PATH_MAX + 1];
char readdir_longentry[CURL_PATH_MAX + 1];
LIBSSH2_SFTP_ATTRIBUTES quote_attrs;
LIBSSH2_SFTP_ATTRIBUTES readdir_attrs;
#endif
};
struct ssh_conn {
const char *authlist;
const char *passphrase;
char *rsa_pub;
char *rsa;
sshstate state;
sshstate nextstate;
struct curl_slist *quote_item;
char *quote_path1;
char *quote_path2;
char *homedir;
int secondCreateDirs;
int orig_waitfor;
char *slash_pos;
#ifdef USE_LIBSSH
CURLcode actualcode;
char *readdir_linkPath;
size_t readdir_len;
struct dynbuf readdir_buf;
unsigned kbd_state;
ssh_key privkey;
ssh_key pubkey;
unsigned int auth_methods;
ssh_session ssh_session;
ssh_scp scp_session;
sftp_session sftp_session;
sftp_file sftp_file;
sftp_dir sftp_dir;
unsigned sftp_recv_state;
#if LIBSSH_VERSION_INT > SSH_VERSION_INT(0, 11, 0)
sftp_aio sftp_recv_aio;
sftp_aio sftp_send_aio;
unsigned sftp_send_state;
#else
int sftp_file_index;
#endif
sftp_attributes readdir_attrs;
sftp_attributes readdir_link_attrs;
sftp_attributes quote_attrs;
const char *readdir_filename;
const char *readdir_longentry;
char *readdir_tmp;
BIT(initialised);
#elif defined(USE_LIBSSH2)
LIBSSH2_SESSION *ssh_session;
LIBSSH2_CHANNEL *ssh_channel;
LIBSSH2_SFTP *sftp_session;
LIBSSH2_SFTP_HANDLE *sftp_handle;
#ifndef CURL_DISABLE_PROXY
Curl_recv *tls_recv;
Curl_send *tls_send;
#endif
LIBSSH2_AGENT *ssh_agent;
struct libssh2_agent_publickey *sshagent_identity;
struct libssh2_agent_publickey *sshagent_prev_identity;
LIBSSH2_KNOWNHOSTS *kh;
#endif
BIT(authed);
BIT(acceptfail);
};
#ifdef USE_LIBSSH
#if LIBSSH_VERSION_INT < SSH_VERSION_INT(0, 9, 0)
# error "SCP/SFTP protocols require libssh 0.9.0 or later"
#endif
#endif
#ifdef USE_LIBSSH2
#if !defined(LIBSSH2_VERSION_NUM) || (LIBSSH2_VERSION_NUM < 0x010208)
# error "SCP/SFTP protocols require libssh2 1.2.8 or later"
#endif
#endif
#ifdef USE_SSH
extern const struct Curl_handler Curl_handler_scp;
extern const struct Curl_handler Curl_handler_sftp;
CURLcode Curl_ssh_init(void);
void Curl_ssh_cleanup(void);
void Curl_ssh_version(char *buffer, size_t buflen);
void Curl_ssh_attach(struct Curl_easy *data,
struct connectdata *conn);
#else
#define Curl_ssh_cleanup()
#define Curl_ssh_attach(x,y)
#define Curl_ssh_init() 0
#endif
#endif