aboutsummaryrefslogtreecommitdiff
path: root/lib/win32/libssh_win32/include/libssh/sftp.h
diff options
context:
space:
mode:
authorWiSo <wiso@xbmc.org>2011-04-04 18:48:29 +0200
committerWiSo <wiso@xbmc.org>2011-04-04 18:49:39 +0200
commit184bc74e0ecf855e37e79592b8ec02453c8312d6 (patch)
tree521f6943fabd31b25f73c8897e705d5c80114703 /lib/win32/libssh_win32/include/libssh/sftp.h
parent9b73d029859633ef97a4956c249d87272ba2da10 (diff)
[WIN32] removed "internal" libssh
Diffstat (limited to 'lib/win32/libssh_win32/include/libssh/sftp.h')
-rw-r--r--lib/win32/libssh_win32/include/libssh/sftp.h906
1 files changed, 0 insertions, 906 deletions
diff --git a/lib/win32/libssh_win32/include/libssh/sftp.h b/lib/win32/libssh_win32/include/libssh/sftp.h
deleted file mode 100644
index 1eab58231c..0000000000
--- a/lib/win32/libssh_win32/include/libssh/sftp.h
+++ /dev/null
@@ -1,906 +0,0 @@
-/*
- * This file is part of the SSH Library
- *
- * Copyright (c) 2003-2008 by Aris Adamantiadis
- *
- * The SSH Library is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1 of the License, or (at your
- * option) any later version.
- *
- * The SSH Library is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
- * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
- * License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with the SSH Library; see the file COPYING. If not, write to
- * the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
- * MA 02111-1307, USA.
- */
-
-/**
- * @file sftp.h
- *
- * @brief SFTP handling functions
- *
- * SFTP commands are channeled by the ssh sftp subsystem. Every packet is
- * sent/read using a sftp_packet type structure. Related to these packets,
- * most of the server answers are messages having an ID and a message
- * specific part. It is described by sftp_message when reading a message,
- * the sftp system puts it into the queue, so the process having asked for
- * it can fetch it, while continuing to read for other messages (it is
- * unspecified in which order messages may be sent back to the client
- *
- * @defgroup ssh_sftp SFTP Functions
- * @{
- */
-
-#ifndef SFTP_H
-#define SFTP_H
-
-#include <sys/types.h>
-
-#include "libssh.h"
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifdef _WIN32
-#ifndef uid_t
- typedef uint32_t uid_t;
-#endif /* uid_t */
-#ifndef gid_t
- typedef uint32_t gid_t;
-#endif /* gid_t */
-#ifdef _MSC_VER
-#ifndef ssize_t
- typedef _W64 SSIZE_T ssize_t;
-#endif /* ssize_t */
-#endif /* _MSC_VER */
-#endif /* _WIN32 */
-
-typedef struct sftp_attributes_struct* sftp_attributes;
-typedef struct sftp_client_message_struct* sftp_client_message;
-typedef struct sftp_dir_struct* sftp_dir;
-typedef struct sftp_ext_struct *sftp_ext;
-typedef struct sftp_file_struct* sftp_file;
-typedef struct sftp_message_struct* sftp_message;
-typedef struct sftp_packet_struct* sftp_packet;
-typedef struct sftp_request_queue_struct* sftp_request_queue;
-typedef struct sftp_session_struct* sftp_session;
-typedef struct sftp_status_message_struct* sftp_status_message;
-typedef struct sftp_statvfs_struct* sftp_statvfs_t;
-
-struct sftp_session_struct {
- ssh_session session;
- ssh_channel channel;
- int server_version;
- int client_version;
- int version;
- sftp_request_queue queue;
- uint32_t id_counter;
- int errnum;
- void **handles;
- sftp_ext ext;
-};
-
-struct sftp_packet_struct {
- sftp_session sftp;
- uint8_t type;
- ssh_buffer payload;
-};
-
-/* file handler */
-struct sftp_file_struct {
- sftp_session sftp;
- char *name;
- uint64_t offset;
- ssh_string handle;
- int eof;
- int nonblocking;
-};
-
-struct sftp_dir_struct {
- sftp_session sftp;
- char *name;
- ssh_string handle; /* handle to directory */
- ssh_buffer buffer; /* contains raw attributes from server which haven't been parsed */
- uint32_t count; /* counts the number of following attributes structures into buffer */
- int eof; /* end of directory listing */
-};
-
-struct sftp_message_struct {
- sftp_session sftp;
- uint8_t packet_type;
- ssh_buffer payload;
- uint32_t id;
-};
-
-/* this is a bunch of all data that could be into a message */
-struct sftp_client_message_struct {
- sftp_session sftp;
- uint8_t type;
- uint32_t id;
- char *filename; /* can be "path" */
- uint32_t flags;
- sftp_attributes attr;
- ssh_string handle;
- uint64_t offset;
- uint32_t len;
- int attr_num;
- ssh_buffer attrbuf; /* used by sftp_reply_attrs */
- ssh_string data; /* can be newpath of rename() */
-};
-
-struct sftp_request_queue_struct {
- sftp_request_queue next;
- sftp_message message;
-};
-
-/* SSH_FXP_MESSAGE described into .7 page 26 */
-struct sftp_status_message_struct {
- uint32_t id;
- uint32_t status;
- ssh_string error;
- ssh_string lang;
- char *errormsg;
- char *langmsg;
-};
-
-struct sftp_attributes_struct {
- char *name;
- char *longname; /* ls -l output on openssh, not reliable else */
- uint32_t flags;
- uint8_t type;
- uint64_t size;
- uint32_t uid;
- uint32_t gid;
- char *owner; /* set if openssh and version 4 */
- char *group; /* set if openssh and version 4 */
- uint32_t permissions;
- uint64_t atime64;
- uint32_t atime;
- uint32_t atime_nseconds;
- uint64_t createtime;
- uint32_t createtime_nseconds;
- uint64_t mtime64;
- uint32_t mtime;
- uint32_t mtime_nseconds;
- ssh_string acl;
- uint32_t extended_count;
- ssh_string extended_type;
- ssh_string extended_data;
-};
-
-struct sftp_statvfs_struct {
- uint64_t f_bsize; /* file system block size */
- uint64_t f_frsize; /* fundamental fs block size */
- uint64_t f_blocks; /* number of blocks (unit f_frsize) */
- uint64_t f_bfree; /* free blocks in file system */
- uint64_t f_bavail; /* free blocks for non-root */
- uint64_t f_files; /* total file inodes */
- uint64_t f_ffree; /* free file inodes */
- uint64_t f_favail; /* free file inodes for to non-root */
- uint64_t f_fsid; /* file system id */
- uint64_t f_flag; /* bit mask of f_flag values */
- uint64_t f_namemax; /* maximum filename length */
-};
-
-#define LIBSFTP_VERSION 3
-
-/**
- * @brief Start a new sftp session.
- *
- * @param session The ssh session to use.
- *
- * @return A new sftp session or NULL on error.
- */
-LIBSSH_API sftp_session sftp_new(ssh_session session);
-
-/**
- * @brief Close and deallocate a sftp session.
- *
- * @param sftp The sftp session handle to free.
- */
-LIBSSH_API void sftp_free(sftp_session sftp);
-
-/**
- * @brief Initialize the sftp session with the server.
- *
- * @param sftp The sftp session to initialize.
- *
- * @return 0 on success, < 0 on error with ssh error set.
- */
-LIBSSH_API int sftp_init(sftp_session sftp);
-
-/**
- * @brief Get the last sftp error.
- *
- * Use this function to get the latest error set by a posix like sftp function.
- *
- * @param sftp The sftp session where the error is saved.
- *
- * @return The saved error (see server responses), < 0 if an error
- * in the function occured.
- */
-LIBSSH_API int sftp_get_error(sftp_session sftp);
-
-/**
- * @brief Get the count of extensions provided by the server.
- *
- * @param sftp The sftp session to use.
- *
- * @return The count of extensions provided by the server, 0 on error or
- * not available.
- */
-LIBSSH_API unsigned int sftp_extensions_get_count(sftp_session sftp);
-
-/**
- * @brief Get the name of the extension provided by the server.
- *
- * @param sftp The sftp session to use.
- *
- * @param indexn The index number of the extension name you want.
- *
- * @return The name of the extension.
- */
-LIBSSH_API const char *sftp_extensions_get_name(sftp_session sftp, unsigned int indexn);
-
-/**
- * @brief Get the data of the extension provided by the server.
- *
- * This is normally the version number of the extension.
- *
- * @param sftp The sftp session to use.
- *
- * @param indexn The index number of the extension data you want.
- *
- * @return The data of the extension.
- */
-LIBSSH_API const char *sftp_extensions_get_data(sftp_session sftp, unsigned int indexn);
-
-/**
- * @brief Check if the given extension is supported.
- *
- * @param sftp The sftp session to use.
- *
- * @param name The name of the extension.
- *
- * @param data The data of the extension.
- *
- * @return 1 if supported, 0 if not.
- *
- * Example:
- *
- * @code
- * sftp_extension_supported(sftp, "statvfs@openssh.com", "2");
- * @endcode
- */
-LIBSSH_API int sftp_extension_supported(sftp_session sftp, const char *name,
- const char *data);
-
-/**
- * @brief Open a directory used to obtain directory entries.
-
- * @param session The sftp session handle to open the directory.
- * @param path The path of the directory to open.
- *
- * @return A sftp directory handle or NULL on error with ssh and
- * sftp error set.
- *
- * @see sftp_readdir
- * @see sftp_closedir
- */
-LIBSSH_API sftp_dir sftp_opendir(sftp_session session, const char *path);
-
-/**
- * @brief Get a single file attributes structure of a directory.
- *
- * @param session The sftp session handle to read the directory entry.
- * @param dir The opened sftp directory handle to read from.
- *
- * @return A file attribute structure or NULL at the end of the
- * directory.
- *
- * @see sftp_opendir()
- * @see sftp_attribute_free()
- * @see sftp_closedir()
- */
-LIBSSH_API sftp_attributes sftp_readdir(sftp_session session, sftp_dir dir);
-
-/**
- * @brief Tell if the directory has reached EOF (End Of File).
- *
- * @param dir The sftp directory handle.
- *
- * @return 1 if the directory is EOF, 0 if not.
- *
- * @see sftp_readdir()
- */
-LIBSSH_API int sftp_dir_eof(sftp_dir dir);
-
-/**
- * @brief Get information about a file or directory.
- *
- * @param session The sftp session handle.
- * @param path The path to the file or directory to obtain the
- * information.
- *
- * @return The sftp attributes structure of the file or directory,
- * NULL on error with ssh and sftp error set.
- */
-LIBSSH_API sftp_attributes sftp_stat(sftp_session session, const char *path);
-
-/**
- * @brief Get information about a file or directory.
- *
- * Identical to sftp_stat, but if the file or directory is a symbolic link,
- * then the link itself is stated, not the file that it refers to.
- *
- * @param session The sftp session handle.
- * @param path The path to the file or directory to obtain the
- * information.
- *
- * @return The sftp attributes structure of the file or directory,
- * NULL on error with ssh and sftp error set.
- */
-LIBSSH_API sftp_attributes sftp_lstat(sftp_session session, const char *path);
-
-/**
- * @brief Get information about a file or directory from a file handle.
- *
- * @param file The sftp file handle to get the stat information.
- *
- * @return The sftp attributes structure of the file or directory,
- * NULL on error with ssh and sftp error set.
- */
-LIBSSH_API sftp_attributes sftp_fstat(sftp_file file);
-
-/**
- * @brief Free a sftp attribute structure.
- *
- * @param file The sftp attribute structure to free.
- */
-LIBSSH_API void sftp_attributes_free(sftp_attributes file);
-
-/**
- * @brief Close a directory handle opened by sftp_opendir().
- *
- * @param dir The sftp directory handle to close.
- *
- * @return Returns SSH_NO_ERROR or SSH_ERROR if an error occured.
- */
-LIBSSH_API int sftp_closedir(sftp_dir dir);
-
-/**
- * @brief Close an open file handle.
- *
- * @param file The open sftp file handle to close.
- *
- * @return Returns SSH_NO_ERROR or SSH_ERROR if an error occured.
- *
- * @see sftp_open()
- */
-LIBSSH_API int sftp_close(sftp_file file);
-
-/**
- * @brief Open a file on the server.
- *
- * @param session The sftp session handle.
- *
- * @param file The file to be opened.
- *
- * @param accesstype Is one of O_RDONLY, O_WRONLY or O_RDWR which request
- * opening the file read-only,write-only or read/write.
- * Acesss may also be bitwise-or'd with one or more of
- * the following:
- * O_CREAT - If the file does not exist it will be
- * created.
- * O_EXCL - When used with O_CREAT, if the file already
- * exists it is an error and the open will fail.
- * O_TRUNC - If the file already exists it will be
- * truncated.
- *
- * @param mode Mode specifies the permissions to use if a new file is
- * created. It is modified by the process's umask in
- * the usual way: The permissions of the created file are
- * (mode & ~umask)
- *
- * @return A sftp file handle, NULL on error with ssh and sftp
- * error set.
- */
-LIBSSH_API sftp_file sftp_open(sftp_session session, const char *file, int accesstype,
- mode_t mode);
-
-LIBSSH_API void sftp_file_set_nonblocking(sftp_file handle);
-
-LIBSSH_API void sftp_file_set_blocking(sftp_file handle);
-
-/**
- * @brief Read from a file using an opened sftp file handle.
- *
- * @param file The opened sftp file handle to be read from.
- *
- * @param buf Pointer to buffer to recieve read data.
- *
- * @param count Size of the buffer in bytes.
- *
- * @return Number of bytes written, < 0 on error with ssh and sftp
- * error set.
- */
-LIBSSH_API ssize_t sftp_read(sftp_file file, void *buf, size_t count);
-
-/**
- * @brief Start an asynchronous read from a file using an opened sftp file handle.
- *
- * Its goal is to avoid the slowdowns related to the request/response pattern
- * of a synchronous read. To do so, you must call 2 functions:
- *
- * sftp_async_read_begin() and sftp_async_read().
- *
- * The first step is to call sftp_async_read_begin(). This function returns a
- * request identifier. The second step is to call sftp_async_read() using the
- * returned identifier.
- *
- * @param file The opened sftp file handle to be read from.
- *
- * @param len Size to read in bytes.
- *
- * @return An identifier corresponding to the sent request, < 0 on
- * error.
- *
- * @warning When calling this function, the internal offset is
- * updated corresponding to the len parameter.
- *
- * @warning A call to sftp_async_read_begin() sends a request to
- * the server. When the server answers, libssh allocates
- * memory to store it until sftp_async_read() is called.
- * Not calling sftp_async_read() will lead to memory
- * leaks.
- *
- * @see sftp_async_read()
- * @see sftp_open()
- */
-LIBSSH_API int sftp_async_read_begin(sftp_file file, uint32_t len);
-
-/**
- * @brief Wait for an asynchronous read to complete and save the data.
- *
- * @param file The opened sftp file handle to be read from.
- *
- * @param data Pointer to buffer to recieve read data.
- *
- * @param len Size of the buffer in bytes. It should be bigger or
- * equal to the length parameter of the
- * sftp_async_read_begin() call.
- *
- * @param id The identifier returned by the sftp_async_read_begin()
- * function.
- *
- * @return Number of bytes read, 0 on EOF, SSH_ERROR if an error
- * occured, SSH_AGAIN if the file is opened in nonblocking
- * mode and the request hasn't been executed yet.
- *
- * @warning A call to this function with an invalid identifier
- * will never return.
- *
- * @see sftp_async_read_begin()
- */
-LIBSSH_API int sftp_async_read(sftp_file file, void *data, uint32_t len, uint32_t id);
-
-/**
- * @brief Write to a file using an opened sftp file handle.
- *
- * @param file Open sftp file handle to write to.
- *
- * @param buf Pointer to buffer to write data.
- *
- * @param count Size of buffer in bytes.
- *
- * @return Number of bytes written, < 0 on error with ssh and sftp
- * error set.
- *
- * @see sftp_open()
- * @see sftp_read()
- * @see sftp_close()
- */
-LIBSSH_API ssize_t sftp_write(sftp_file file, const void *buf, size_t count);
-
-/**
- * @brief Seek to a specific location in a file.
- *
- * @param file Open sftp file handle to seek in.
- *
- * @param new_offset Offset in bytes to seek.
- *
- * @return 0 on success, < 0 on error.
- */
-LIBSSH_API int sftp_seek(sftp_file file, uint32_t new_offset);
-
-/**
- * @brief Seek to a specific location in a file. This is the
- * 64bit version.
- *
- * @param file Open sftp file handle to seek in.
- *
- * @param new_offset Offset in bytes to seek.
- *
- * @return 0 on success, < 0 on error.
- */
-LIBSSH_API int sftp_seek64(sftp_file file, uint64_t new_offset);
-
-/**
- * @brief Report current byte position in file.
- *
- * @param file Open sftp file handle.
- *
- * @return The offset of the current byte relative to the beginning
- * of the file associated with the file descriptor. < 0 on
- * error.
- */
-LIBSSH_API unsigned long sftp_tell(sftp_file file);
-
-/**
- * @brief Report current byte position in file.
- *
- * @param file Open sftp file handle.
- *
- * @return The offset of the current byte relative to the beginning
- * of the file associated with the file descriptor. < 0 on
- * error.
- */
-LIBSSH_API uint64_t sftp_tell64(sftp_file file);
-
-/**
- * @brief Rewinds the position of the file pointer to the beginning of the
- * file.
- *
- * @param file Open sftp file handle.
- */
-LIBSSH_API void sftp_rewind(sftp_file file);
-
-/**
- * @brief Unlink (delete) a file.
- *
- * @param sftp The sftp session handle.
- *
- * @param file The file to unlink/delete.
- *
- * @return 0 on success, < 0 on error with ssh and sftp error set.
- */
-LIBSSH_API int sftp_unlink(sftp_session sftp, const char *file);
-
-/**
- * @brief Remove a directoy.
- *
- * @param sftp The sftp session handle.
- *
- * @param directory The directory to remove.
- *
- * @return 0 on success, < 0 on error with ssh and sftp error set.
- */
-LIBSSH_API int sftp_rmdir(sftp_session sftp, const char *directory);
-
-/**
- * @brief Create a directory.
- *
- * @param sftp The sftp session handle.
- *
- * @param directory The directory to create.
- *
- * @param mode Specifies the permissions to use. It is modified by the
- * process's umask in the usual way:
- * The permissions of the created file are (mode & ~umask)
- *
- * @return 0 on success, < 0 on error with ssh and sftp error set.
- */
-LIBSSH_API int sftp_mkdir(sftp_session sftp, const char *directory, mode_t mode);
-
-/**
- * @brief Rename or move a file or directory.
- *
- * @param sftp The sftp session handle.
- *
- * @param original The original url (source url) of file or directory to
- * be moved.
- *
- * @param newname The new url (destination url) of the file or directory
- * after the move.
- *
- * @return 0 on success, < 0 on error with ssh and sftp error set.
- */
-LIBSSH_API int sftp_rename(sftp_session sftp, const char *original, const char *newname);
-
-/**
- * @brief Set file attributes on a file, directory or symbolic link.
- *
- * @param sftp The sftp session handle.
- *
- * @param file The file which attributes should be changed.
- *
- * @param attr The file attributes structure with the attributes set
- * which should be changed.
- *
- * @return 0 on success, < 0 on error with ssh and sftp error set.
- */
-LIBSSH_API int sftp_setstat(sftp_session sftp, const char *file, sftp_attributes attr);
-
-/**
- * @brief Change the file owner and group
- *
- * @param sftp The sftp session handle.
- *
- * @param file The file which owner and group should be changed.
- *
- * @param owner The new owner which should be set.
- *
- * @param group The new group which should be set.
- *
- * @return 0 on success, < 0 on error with ssh and sftp error set.
- */
-LIBSSH_API int sftp_chown(sftp_session sftp, const char *file, uid_t owner, gid_t group);
-
-/**
- * @brief Change permissions of a file
- *
- * @param sftp The sftp session handle.
- *
- * @param file The file which owner and group should be changed.
- *
- * @param mode Specifies the permissions to use. It is modified by the
- * process's umask in the usual way:
- * The permissions of the created file are (mode & ~umask)
- *
- * @return 0 on success, < 0 on error with ssh and sftp error set.
- */
-LIBSSH_API int sftp_chmod(sftp_session sftp, const char *file, mode_t mode);
-
-/**
- * @brief Change the last modification and access time of a file.
- *
- * @param sftp The sftp session handle.
- *
- * @param file The file which owner and group should be changed.
- *
- * @param times A timeval structure which contains the desired access
- * and modification time.
- *
- * @return 0 on success, < 0 on error with ssh and sftp error set.
- */
-LIBSSH_API int sftp_utimes(sftp_session sftp, const char *file, const struct timeval *times);
-
-/**
- * @brief Create a symbolic link.
- *
- * @param sftp The sftp session handle.
- *
- * @param target Specifies the target of the symlink.
- *
- * @param dest Specifies the path name of the symlink to be created.
- *
- * @return 0 on success, < 0 on error with ssh and sftp error set.
- */
-LIBSSH_API int sftp_symlink(sftp_session sftp, const char *target, const char *dest);
-
-/**
- * @brief Read the value of a symbolic link.
- *
- * @param sftp The sftp session handle.
- *
- * @param path Specifies the path name of the symlink to be read.
- *
- * @return The target of the link, NULL on error.
- */
-LIBSSH_API char *sftp_readlink(sftp_session sftp, const char *path);
-
-/**
- * @brief Get information about a mounted file system.
- *
- * @param sftp The sftp session handle.
- *
- * @param path The pathname of any file within the mounted file system.
- *
- * @return A statvfs structure or NULL on error.
- */
-LIBSSH_API sftp_statvfs_t sftp_statvfs(sftp_session sftp, const char *path);
-
-/**
- * @brief Get information about a mounted file system.
- *
- * @param file An opened file.
- *
- * @return A statvfs structure or NULL on error.
- */
-LIBSSH_API sftp_statvfs_t sftp_fstatvfs(sftp_file file);
-
-/**
- * @brief Free the memory of an allocated statvfs.
- *
- * @param statvfs_o The statvfs to free.
- */
-LIBSSH_API void sftp_statvfs_free(sftp_statvfs_t statvfs_o);
-
-/**
- * @brief Canonicalize a sftp path.
- *
- * @param sftp The sftp session handle.
- *
- * @param path The path to be canonicalized.
- *
- * @return The canonicalize path, NULL on error.
- */
-LIBSSH_API char *sftp_canonicalize_path(sftp_session sftp, const char *path);
-
-/**
- * @brief Get the version of the SFTP protocol supported by the server
- *
- * @param sftp The sftp session handle.
- *
- * @return The server version.
- */
-LIBSSH_API int sftp_server_version(sftp_session sftp);
-
-#ifdef WITH_SERVER
-/**
- * @brief Create a new sftp server session.
- *
- * @param session The ssh session to use.
- *
- * @param chan The ssh channel to use.
- *
- * @return A new sftp server session.
- */
-LIBSSH_API sftp_session sftp_server_new(ssh_session session, ssh_channel chan);
-
-/**
- * @brief Intialize the sftp server.
- *
- * @param sftp The sftp session to init.
- *
- * @return 0 on success, < 0 on error.
- */
-LIBSSH_API int sftp_server_init(sftp_session sftp);
-#endif /* WITH_SERVER */
-
-/* this is not a public interface */
-#define SFTP_HANDLES 256
-sftp_packet sftp_packet_read(sftp_session sftp);
-int sftp_packet_write(sftp_session sftp,uint8_t type, ssh_buffer payload);
-void sftp_packet_free(sftp_packet packet);
-int buffer_add_attributes(ssh_buffer buffer, sftp_attributes attr);
-sftp_attributes sftp_parse_attr(sftp_session session, ssh_buffer buf,int expectname);
-/* sftpserver.c */
-
-sftp_client_message sftp_get_client_message(sftp_session sftp);
-void sftp_client_message_free(sftp_client_message msg);
-int sftp_reply_name(sftp_client_message msg, const char *name,
- sftp_attributes attr);
-int sftp_reply_handle(sftp_client_message msg, ssh_string handle);
-ssh_string sftp_handle_alloc(sftp_session sftp, void *info);
-int sftp_reply_attr(sftp_client_message msg, sftp_attributes attr);
-void *sftp_handle(sftp_session sftp, ssh_string handle);
-int sftp_reply_status(sftp_client_message msg, uint32_t status, const char *message);
-int sftp_reply_names_add(sftp_client_message msg, const char *file,
- const char *longname, sftp_attributes attr);
-int sftp_reply_names(sftp_client_message msg);
-int sftp_reply_data(sftp_client_message msg, const void *data, int len);
-void sftp_handle_remove(sftp_session sftp, void *handle);
-
-/* SFTP commands and constants */
-#define SSH_FXP_INIT 1
-#define SSH_FXP_VERSION 2
-#define SSH_FXP_OPEN 3
-#define SSH_FXP_CLOSE 4
-#define SSH_FXP_READ 5
-#define SSH_FXP_WRITE 6
-#define SSH_FXP_LSTAT 7
-#define SSH_FXP_FSTAT 8
-#define SSH_FXP_SETSTAT 9
-#define SSH_FXP_FSETSTAT 10
-#define SSH_FXP_OPENDIR 11
-#define SSH_FXP_READDIR 12
-#define SSH_FXP_REMOVE 13
-#define SSH_FXP_MKDIR 14
-#define SSH_FXP_RMDIR 15
-#define SSH_FXP_REALPATH 16
-#define SSH_FXP_STAT 17
-#define SSH_FXP_RENAME 18
-#define SSH_FXP_READLINK 19
-#define SSH_FXP_SYMLINK 20
-
-#define SSH_FXP_STATUS 101
-#define SSH_FXP_HANDLE 102
-#define SSH_FXP_DATA 103
-#define SSH_FXP_NAME 104
-#define SSH_FXP_ATTRS 105
-
-#define SSH_FXP_EXTENDED 200
-#define SSH_FXP_EXTENDED_REPLY 201
-
-/* attributes */
-/* sftp draft is completely braindead : version 3 and 4 have different flags for same constants */
-/* and even worst, version 4 has same flag for 2 different constants */
-/* follow up : i won't develop any sftp4 compliant library before having a clarification */
-
-#define SSH_FILEXFER_ATTR_SIZE 0x00000001
-#define SSH_FILEXFER_ATTR_PERMISSIONS 0x00000004
-#define SSH_FILEXFER_ATTR_ACCESSTIME 0x00000008
-#define SSH_FILEXFER_ATTR_ACMODTIME 0x00000008
-#define SSH_FILEXFER_ATTR_CREATETIME 0x00000010
-#define SSH_FILEXFER_ATTR_MODIFYTIME 0x00000020
-#define SSH_FILEXFER_ATTR_ACL 0x00000040
-#define SSH_FILEXFER_ATTR_OWNERGROUP 0x00000080
-#define SSH_FILEXFER_ATTR_SUBSECOND_TIMES 0x00000100
-#define SSH_FILEXFER_ATTR_EXTENDED 0x80000000
-#define SSH_FILEXFER_ATTR_UIDGID 0x00000002
-
-/* types */
-#define SSH_FILEXFER_TYPE_REGULAR 1
-#define SSH_FILEXFER_TYPE_DIRECTORY 2
-#define SSH_FILEXFER_TYPE_SYMLINK 3
-#define SSH_FILEXFER_TYPE_SPECIAL 4
-#define SSH_FILEXFER_TYPE_UNKNOWN 5
-
-/* server responses */
-#define SSH_FX_OK 0
-#define SSH_FX_EOF 1
-#define SSH_FX_NO_SUCH_FILE 2
-#define SSH_FX_PERMISSION_DENIED 3
-#define SSH_FX_FAILURE 4
-#define SSH_FX_BAD_MESSAGE 5
-#define SSH_FX_NO_CONNECTION 6
-#define SSH_FX_CONNECTION_LOST 7
-#define SSH_FX_OP_UNSUPPORTED 8
-#define SSH_FX_INVALID_HANDLE 9
-#define SSH_FX_NO_SUCH_PATH 10
-#define SSH_FX_FILE_ALREADY_EXISTS 11
-#define SSH_FX_WRITE_PROTECT 12
-#define SSH_FX_NO_MEDIA 13
-
-/* file flags */
-#define SSH_FXF_READ 0x01
-#define SSH_FXF_WRITE 0x02
-#define SSH_FXF_APPEND 0x04
-#define SSH_FXF_CREAT 0x08
-#define SSH_FXF_TRUNC 0x10
-#define SSH_FXF_EXCL 0x20
-#define SSH_FXF_TEXT 0x40
-
-/* rename flags */
-#define SSH_FXF_RENAME_OVERWRITE 0x00000001
-#define SSH_FXF_RENAME_ATOMIC 0x00000002
-#define SSH_FXF_RENAME_NATIVE 0x00000004
-
-#define SFTP_OPEN SSH_FXP_OPEN
-#define SFTP_CLOSE SSH_FXP_CLOSE
-#define SFTP_READ SSH_FXP_READ
-#define SFTP_WRITE SSH_FXP_WRITE
-#define SFTP_LSTAT SSH_FXP_LSTAT
-#define SFTP_FSTAT SSH_FXP_FSTAT
-#define SFTP_SETSTAT SSH_FXP_SETSTAT
-#define SFTP_FSETSTAT SSH_FXP_FSETSTAT
-#define SFTP_OPENDIR SSH_FXP_OPENDIR
-#define SFTP_READDIR SSH_FXP_READDIR
-#define SFTP_REMOVE SSH_FXP_REMOVE
-#define SFTP_MKDIR SSH_FXP_MKDIR
-#define SFTP_RMDIR SSH_FXP_RMDIR
-#define SFTP_REALPATH SSH_FXP_REALPATH
-#define SFTP_STAT SSH_FXP_STAT
-#define SFTP_RENAME SSH_FXP_RENAME
-#define SFTP_READLINK SSH_FXP_READLINK
-#define SFTP_SYMLINK SSH_FXP_SYMLINK
-
-/* openssh flags */
-#define SSH_FXE_STATVFS_ST_RDONLY 0x1 /* read-only */
-#define SSH_FXE_STATVFS_ST_NOSUID 0x2 /* no setuid */
-
-#ifdef __cplusplus
-} ;
-#endif
-
-#endif /* SFTP_H */
-
-/** @} */
-/* vim: set ts=2 sw=2 et cindent: */