1
1

server: added channel callbacks

Reviewed-by: Andreas Schneider <asn@cryptomilk.org>
Этот коммит содержится в:
Aris Adamantiadis 2013-02-11 21:35:16 +01:00 коммит произвёл Andreas Schneider
родитель ab2e641b4a
Коммит 6bc64c368d
3 изменённых файлов: 64 добавлений и 14 удалений

Просмотреть файл

@ -439,6 +439,34 @@ typedef void (*ssh_channel_exit_signal_callback) (ssh_session session,
const char *lang, const char *lang,
void *userdata); void *userdata);
/**
* @brief SSH channel PTY request from a client.
* @param channel the channel
* @param width width of the terminal, in characters
* @param height height of the terminal, in characters
* @param pxwidth width of the terminal, in pixels
* @param pxheight height of the terminal, in pixels
* @param userdata Userdata to be passed to the callback function.
* @returns 0 if the pty request is accepted
* @returns -1 if the request is denied
*/
typedef int (*ssh_channel_pty_request_callback) (ssh_session session,
ssh_channel channel,
const char *term,
int width, int height,
int pxwidth, int pwheight,
void *userdata);
/**
* @brief SSH channel Shell request from a client.
* @param channel the channel
* @param userdata Userdata to be passed to the callback function.
* @returns 0 if the pty request is accepted
* @returns 1 if the request is denied
*/
typedef int (*ssh_channel_shell_request_callback) (ssh_session session,
ssh_channel channel,
void *userdata);
struct ssh_channel_callbacks_struct { struct ssh_channel_callbacks_struct {
/** DON'T SET THIS use ssh_callbacks_init() instead. */ /** DON'T SET THIS use ssh_callbacks_init() instead. */
size_t size; size_t size;
@ -470,6 +498,14 @@ struct ssh_channel_callbacks_struct {
* This functions will be called when an exit signal has been received * This functions will be called when an exit signal has been received
*/ */
ssh_channel_exit_signal_callback channel_exit_signal_function; ssh_channel_exit_signal_callback channel_exit_signal_function;
/**
* This function will be called when a client requests a PTY
*/
ssh_channel_pty_request_callback channel_pty_request_function;
/**
* This function will be called when a client requests a shell
*/
ssh_channel_shell_request_callback channel_shell_request_function;
}; };
typedef struct ssh_channel_callbacks_struct *ssh_channel_callbacks; typedef struct ssh_channel_callbacks_struct *ssh_channel_callbacks;

Просмотреть файл

@ -100,5 +100,6 @@ int ssh_message_handle_channel_request(ssh_session session, ssh_channel channel,
const char *request, uint8_t want_reply); const char *request, uint8_t want_reply);
void ssh_message_queue(ssh_session session, ssh_message message); void ssh_message_queue(ssh_session session, ssh_message message);
ssh_message ssh_message_pop_head(ssh_session session); ssh_message ssh_message_pop_head(ssh_session session);
int ssh_message_channel_request_open_reply_accept_channel(ssh_message msg, ssh_channel chan);
#endif /* MESSAGES_H_ */ #endif /* MESSAGES_H_ */

Просмотреть файл

@ -930,26 +930,18 @@ end:
return SSH_PACKET_USED; return SSH_PACKET_USED;
} }
/* TODO: make this function accept a ssh_channel */ int ssh_message_channel_request_open_reply_accept_channel(ssh_message msg, ssh_channel chan) {
ssh_channel ssh_message_channel_request_open_reply_accept(ssh_message msg) {
ssh_session session; ssh_session session;
ssh_channel chan = NULL;
enter_function(); enter_function();
if (msg == NULL) { if (msg == NULL) {
leave_function(); leave_function();
return NULL; return SSH_ERROR;
} }
session = msg->session; session = msg->session;
chan = ssh_channel_new(session);
if (chan == NULL) {
leave_function();
return NULL;
}
chan->local_channel = ssh_channel_new_id(session); chan->local_channel = ssh_channel_new_id(session);
chan->local_maxpacket = 35000; chan->local_maxpacket = 35000;
chan->local_window = 32000; chan->local_window = 32000;
@ -982,12 +974,33 @@ ssh_channel ssh_message_channel_request_open_reply_accept(ssh_message msg) {
} }
leave_function(); leave_function();
return chan; return SSH_OK;
error: error:
ssh_channel_free(chan);
leave_function(); leave_function();
return SSH_ERROR;
}
ssh_channel ssh_message_channel_request_open_reply_accept(ssh_message msg) {
ssh_channel chan;
int rc;
if (msg == NULL) {
return NULL; return NULL;
}
chan = ssh_channel_new(msg->session);
if (chan == NULL) {
return NULL;
}
rc = ssh_message_channel_request_open_reply_accept_channel(msg, chan);
if (rc < 0) {
ssh_channel_free(chan);
chan = NULL;
}
return chan;
} }
/** /**