libssh2_sftp_init - Man Page

open SFTP channel for the given SSH session.


#include <libssh2.h>
#include <libssh2_sftp.h>

libssh2_sftp_init(LIBSSH2_SESSION *session);


session - Session instance as returned by libssh2_session_init_ex(3)

Open a channel and initialize the SFTP subsystem. Although the SFTP subsystem operates over the same type of channel as those exported by the Channel API, the protocol itself implements its own unique binary packet protocol which must be managed with the libssh2_sftp_*() family of functions. When an SFTP session is complete, it must be destroyed using the libssh2_sftp_shutdown(3) function.

Return Value

A pointer to the newly allocated SFTP instance or NULL on failure.


LIBSSH2_ERROR_ALLOC -  An internal memory allocation call failed.

LIBSSH2_ERROR_SOCKET_SEND - Unable to send data on socket.


LIBSSH2_ERROR_SFTP_PROTOCOL - An invalid SFTP protocol response was received on the socket, or an SFTP operation caused an errorcode to be returned by the server.

LIBSSH2_ERROR_EAGAIN - Marked for non-blocking I/O but the call would block.

See Also

libssh2_sftp_shutdown(3) libssh2_sftp_open_ex(3)

Referenced By

libssh2_sftp_get_channel(3), libssh2_sftp_last_error(3), libssh2_sftp_mkdir_ex(3), libssh2_sftp_open_ex(3), libssh2_sftp_open_ex_r(3), libssh2_sftp_rename_ex(3), libssh2_sftp_rmdir_ex(3), libssh2_sftp_shutdown(3), libssh2_sftp_stat_ex(3), libssh2_sftp_statvfs(3), libssh2_sftp_symlink_ex(3), libssh2_sftp_unlink_ex(3).

1 Jun 2007 libssh2 0.15