server: added channel callbacks
Reviewed-by: Andreas Schneider <asn@cryptomilk.org>
Этот коммит содержится в:
родитель
ab2e641b4a
Коммит
6bc64c368d
@ -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;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Загрузка…
x
Ссылка в новой задаче
Block a user