mirror of
https://git.libssh.org/projects/libssh.git
synced 2026-02-10 18:28:10 +09:00
messages: Reformat ssh_packet_service_request()
Signed-off-by: Andreas Schneider <asn@cryptomilk.org>
This commit is contained in:
@@ -611,38 +611,45 @@ void ssh_message_free(ssh_message msg){
|
|||||||
|
|
||||||
#ifdef WITH_SERVER
|
#ifdef WITH_SERVER
|
||||||
|
|
||||||
SSH_PACKET_CALLBACK(ssh_packet_service_request){
|
SSH_PACKET_CALLBACK(ssh_packet_service_request)
|
||||||
ssh_string service = NULL;
|
{
|
||||||
char *service_c = NULL;
|
ssh_string service = NULL;
|
||||||
ssh_message msg=NULL;
|
char *service_c = NULL;
|
||||||
|
ssh_message msg = NULL;
|
||||||
|
|
||||||
(void)type;
|
(void)type;
|
||||||
(void)user;
|
(void)user;
|
||||||
service = ssh_buffer_get_ssh_string(packet);
|
|
||||||
if (service == NULL) {
|
|
||||||
ssh_set_error(session, SSH_FATAL, "Invalid SSH_MSG_SERVICE_REQUEST packet");
|
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
|
|
||||||
service_c = ssh_string_to_char(service);
|
service = ssh_buffer_get_ssh_string(packet);
|
||||||
if (service_c == NULL) {
|
if (service == NULL) {
|
||||||
goto error;
|
ssh_set_error(session,
|
||||||
}
|
SSH_FATAL,
|
||||||
SSH_LOG(SSH_LOG_PACKET,
|
"Invalid SSH_MSG_SERVICE_REQUEST packet");
|
||||||
"Received a SERVICE_REQUEST for service %s", service_c);
|
goto error;
|
||||||
msg=ssh_message_new(session);
|
}
|
||||||
if(!msg){
|
|
||||||
SAFE_FREE(service_c);
|
service_c = ssh_string_to_char(service);
|
||||||
goto error;
|
if (service_c == NULL) {
|
||||||
}
|
goto error;
|
||||||
msg->type=SSH_REQUEST_SERVICE;
|
}
|
||||||
msg->service_request.service=service_c;
|
SSH_LOG(SSH_LOG_PACKET,
|
||||||
|
"Received a SERVICE_REQUEST for service %s",
|
||||||
|
service_c);
|
||||||
|
msg = ssh_message_new(session);
|
||||||
|
if (msg == NULL) {
|
||||||
|
SAFE_FREE(service_c);
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
|
msg->type=SSH_REQUEST_SERVICE;
|
||||||
|
msg->service_request.service=service_c;
|
||||||
error:
|
error:
|
||||||
ssh_string_free(service);
|
ssh_string_free(service);
|
||||||
if(msg != NULL)
|
if (msg != NULL) {
|
||||||
ssh_message_queue(session,msg);
|
ssh_message_queue(session, msg);
|
||||||
|
}
|
||||||
|
|
||||||
return SSH_PACKET_USED;
|
return SSH_PACKET_USED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user