mirror of
git://anongit.mindrot.org/openssh.git
synced 2024-12-19 08:34:32 +00:00
upstream: add a variant of send_status() that allows overriding the
default, generic error message. feedback/ok markus & jsg OpenBSD-Commit-ID: 81f251e975d759994131b717ee7c0b439659c40f
This commit is contained in:
parent
9614113377
commit
9acddcd591
@ -1,4 +1,4 @@
|
||||
/* $OpenBSD: sftp-server.c,v 1.135 2022/01/01 01:55:30 jsg Exp $ */
|
||||
/* $OpenBSD: sftp-server.c,v 1.136 2022/01/08 07:33:54 djm Exp $ */
|
||||
/*
|
||||
* Copyright (c) 2000-2004 Markus Friedl. All rights reserved.
|
||||
*
|
||||
@ -536,7 +536,7 @@ status_to_message(u_int32_t status)
|
||||
}
|
||||
|
||||
static void
|
||||
send_status(u_int32_t id, u_int32_t status)
|
||||
send_status_errmsg(u_int32_t id, u_int32_t status, const char *errmsg)
|
||||
{
|
||||
struct sshbuf *msg;
|
||||
int r;
|
||||
@ -552,14 +552,21 @@ send_status(u_int32_t id, u_int32_t status)
|
||||
(r = sshbuf_put_u32(msg, status)) != 0)
|
||||
fatal_fr(r, "compose");
|
||||
if (version >= 3) {
|
||||
if ((r = sshbuf_put_cstring(msg,
|
||||
status_to_message(status))) != 0 ||
|
||||
if ((r = sshbuf_put_cstring(msg, errmsg == NULL ?
|
||||
status_to_message(status) : errmsg)) != 0 ||
|
||||
(r = sshbuf_put_cstring(msg, "")) != 0)
|
||||
fatal_fr(r, "compose message");
|
||||
}
|
||||
send_msg(msg);
|
||||
sshbuf_free(msg);
|
||||
}
|
||||
|
||||
static void
|
||||
send_status(u_int32_t id, u_int32_t status)
|
||||
{
|
||||
return send_status_errmsg(id, status, NULL);
|
||||
}
|
||||
|
||||
static void
|
||||
send_data_or_handle(char type, u_int32_t id, const u_char *data, int dlen)
|
||||
{
|
||||
|
Loading…
Reference in New Issue
Block a user