183 lines
5.7 KiB
C
183 lines
5.7 KiB
C
/*
|
|
* Copyright (C) 2015 Glyptodon LLC
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
* in the Software without restriction, including without limitation the rights
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
* THE SOFTWARE.
|
|
*/
|
|
|
|
#ifndef GUAC_COMMON_SSH_SFTP_H
|
|
#define GUAC_COMMON_SSH_SFTP_H
|
|
|
|
#include "guac_json.h"
|
|
#include "guac_ssh.h"
|
|
|
|
#include <guacamole/client.h>
|
|
#include <guacamole/object.h>
|
|
#include <libssh2.h>
|
|
#include <libssh2_sftp.h>
|
|
|
|
/**
|
|
* Maximum number of bytes per path.
|
|
*/
|
|
#define GUAC_COMMON_SSH_SFTP_MAX_PATH 2048
|
|
|
|
/**
|
|
* Data associated with an SFTP-driven filesystem object.
|
|
*/
|
|
typedef struct guac_common_ssh_sftp_data {
|
|
|
|
/**
|
|
* The distinct SSH session used for SFTP.
|
|
*/
|
|
guac_common_ssh_session* ssh_session;
|
|
|
|
/**
|
|
* SFTP session, used for file transfers.
|
|
*/
|
|
LIBSSH2_SFTP* sftp_session;
|
|
|
|
/**
|
|
* The path files will be sent to, if uploaded directly via a "file"
|
|
* instruction.
|
|
*/
|
|
char upload_path[GUAC_COMMON_SSH_SFTP_MAX_PATH];
|
|
|
|
} guac_common_ssh_sftp_data;
|
|
|
|
/**
|
|
* The current state of a directory listing operation.
|
|
*/
|
|
typedef struct guac_common_ssh_sftp_ls_state {
|
|
|
|
/**
|
|
* Data associated with the current SFTP session.
|
|
*/
|
|
guac_common_ssh_sftp_data* sftp_data;
|
|
|
|
/**
|
|
* Reference to the directory currently being listed over SFTP. This
|
|
* directory must already be open from a call to libssh2_sftp_opendir().
|
|
*/
|
|
LIBSSH2_SFTP_HANDLE* directory;
|
|
|
|
/**
|
|
* The absolute path of the directory being listed.
|
|
*/
|
|
char directory_name[GUAC_COMMON_SSH_SFTP_MAX_PATH];
|
|
|
|
/**
|
|
* The current state of the JSON directory object being written.
|
|
*/
|
|
guac_common_json_state json_state;
|
|
|
|
} guac_common_ssh_sftp_ls_state;
|
|
|
|
/**
|
|
* Creates a new Guacamole filesystem object which provides access to files
|
|
* and directories via SFTP using the given SSH session. When the filesystem
|
|
* will no longer be used, it must be explicitly destroyed with
|
|
* guac_common_ssh_destroy_sftp_filesystem().
|
|
*
|
|
* @param session
|
|
* The session to use to provide SFTP. This session will automatically be
|
|
* destroyed when this filesystem is destroyed.
|
|
*
|
|
* @param name
|
|
* The name to send as the name of the filesystem.
|
|
*
|
|
* @return
|
|
* A new Guacamole filesystem object, already configured to use SFTP for
|
|
* uploading and downloading files.
|
|
*/
|
|
guac_object* guac_common_ssh_create_sftp_filesystem(
|
|
guac_common_ssh_session* session,
|
|
const char* name);
|
|
|
|
/**
|
|
* Destroys the given filesystem object, disconnecting from SFTP and freeing
|
|
* and associated resources. Any associated session or user objects must be
|
|
* explicitly destroyed.
|
|
*
|
|
* @param object
|
|
* The filesystem object to destroy.
|
|
*/
|
|
void guac_common_ssh_destroy_sftp_filesystem(guac_object* filesystem);
|
|
|
|
/**
|
|
* Initiates an SFTP file download to the user via the Guacamole "file"
|
|
* instruction. The download will be automatically monitored and continued
|
|
* after this function terminates in response to "ack" instructions received by
|
|
* the client.
|
|
*
|
|
* @param filesystem
|
|
* The filesystem containing the file to be downloaded.
|
|
*
|
|
* @param filename
|
|
* The filename of the file to download, relative to the given filesystem.
|
|
*
|
|
* @return
|
|
* The file stream created for the file download, already configured to
|
|
* properly handle "ack" responses, etc. from the client.
|
|
*/
|
|
guac_stream* guac_common_ssh_sftp_download_file(guac_object* filesystem,
|
|
char* filename);
|
|
|
|
/**
|
|
* Handles an incoming stream from a Guacamole "file" instruction, saving the
|
|
* contents of that stream to the file having the given name within the
|
|
* upload directory set by guac_common_ssh_sftp_set_upload_path().
|
|
*
|
|
* @param filesystem
|
|
* The filesystem that should receive the uploaded file.
|
|
*
|
|
* @param stream
|
|
* The stream through which the uploaded file data will be received.
|
|
*
|
|
* @param mimetype
|
|
* The mimetype of the data being received.
|
|
*
|
|
* @param filename
|
|
* The filename of the file to write to. This filename will always be taken
|
|
* relative to the upload path set by
|
|
* guac_common_ssh_sftp_set_upload_path().
|
|
*
|
|
* @return
|
|
* Zero if the incoming stream has been handled successfully, non-zero on
|
|
* failure.
|
|
*/
|
|
int guac_common_ssh_sftp_handle_file_stream(guac_object* filesystem,
|
|
guac_stream* stream, char* mimetype, char* filename);
|
|
|
|
/**
|
|
* Set the destination directory for future uploads submitted via
|
|
* guac_common_ssh_sftp_handle_file_stream(). This function has no bearing
|
|
* on the destination directories of files uploaded with "put" instructions.
|
|
*
|
|
* @param filesystem
|
|
* The filesystem to set the upload path of.
|
|
*
|
|
* @param path
|
|
* The path to use for future uploads submitted via the
|
|
* guac_common_ssh_sftp_handle_file_stream() function.
|
|
*/
|
|
void guac_common_ssh_sftp_set_upload_path(guac_object* filesystem,
|
|
const char* path);
|
|
|
|
#endif
|
|
|