summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorAris Adamantiadis <aris@0xbadc0de.be>2013-06-02 18:40:13 +0200
committerAndreas Schneider <asn@cryptomilk.org>2013-07-13 15:01:17 +0200
commit31a129ee9e0626d3230bea46d93bde2e2738119c (patch)
tree0346b0e26898b1a74745f04b62e12fd00a0d1cfe /src
parent7e7910a1ca35c069864bafc200d7ba593a73a1f2 (diff)
downloadlibssh-31a129ee9e0626d3230bea46d93bde2e2738119c.tar.gz
libssh-31a129ee9e0626d3230bea46d93bde2e2738119c.tar.xz
libssh-31a129ee9e0626d3230bea46d93bde2e2738119c.zip
sftp: more flexibility on channels
Reviewed-by: Andreas Schneider <asn@cryptomilk.org>
Diffstat (limited to 'src')
-rw-r--r--src/sftp.c31
-rw-r--r--src/sftpserver.c8
2 files changed, 36 insertions, 3 deletions
diff --git a/src/sftp.c b/src/sftp.c
index ee86107..73b1f30 100644
--- a/src/sftp.c
+++ b/src/sftp.c
@@ -149,6 +149,37 @@ sftp_session sftp_new(ssh_session session){
return sftp;
}
+sftp_session sftp_new_channel(ssh_session session, ssh_channel channel){
+ sftp_session sftp;
+
+ if (session == NULL) {
+ return NULL;
+ }
+ enter_function();
+
+ sftp = malloc(sizeof(struct sftp_session_struct));
+ if (sftp == NULL) {
+ ssh_set_error_oom(session);
+ leave_function();
+ return NULL;
+ }
+ ZERO_STRUCTP(sftp);
+
+ sftp->ext = sftp_ext_new();
+ if (sftp->ext == NULL) {
+ ssh_set_error_oom(session);
+ SAFE_FREE(sftp);
+ leave_function();
+ return NULL;
+ }
+
+ sftp->session = session;
+ sftp->channel = channel;
+
+ leave_function();
+ return sftp;
+}
+
#ifdef WITH_SERVER
sftp_session sftp_server_new(ssh_session session, ssh_channel chan){
sftp_session sftp = NULL;
diff --git a/src/sftpserver.c b/src/sftpserver.c
index 431d1d8..0986b6c 100644
--- a/src/sftpserver.c
+++ b/src/sftpserver.c
@@ -263,9 +263,10 @@ void sftp_client_message_set_filename(sftp_client_message msg, const char *newna
msg->filename = strdup(newname);
}
-char *sftp_client_message_get_data(sftp_client_message msg){
- char *str = ssh_string_to_char(msg->data);
- return str;
+const char *sftp_client_message_get_data(sftp_client_message msg){
+ if (msg->str_data == NULL)
+ msg->str_data = ssh_string_to_char(msg->data);
+ return msg->str_data;
}
uint32_t sftp_client_message_get_flags(sftp_client_message msg){
@@ -282,6 +283,7 @@ void sftp_client_message_free(sftp_client_message msg) {
ssh_string_free(msg->handle);
sftp_attributes_free(msg->attr);
ssh_buffer_free(msg->complete_message);
+ SAFE_FREE(msg->str_data);
ZERO_STRUCTP(msg);
SAFE_FREE(msg);
}