mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 01:02:24 +00:00
Factor out the check for ext-info-* keyword.
I'm about to want to use the same code to check for something else. It's only a handful of lines, but even so. Also, since the string constants are mentioned several times, this seems like a good moment to lift them out into reusable static const ptrlens.
This commit is contained in:
parent
9e09915157
commit
f2e7086902
@ -27,6 +27,9 @@ const static ssh2_macalg *const buggymacs[] = {
|
|||||||
&ssh_hmac_sha1_buggy, &ssh_hmac_sha1_96_buggy, &ssh_hmac_md5
|
&ssh_hmac_sha1_buggy, &ssh_hmac_sha1_96_buggy, &ssh_hmac_md5
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const static ptrlen ext_info_c = PTRLEN_DECL_LITERAL("ext-info-c");
|
||||||
|
const static ptrlen ext_info_s = PTRLEN_DECL_LITERAL("ext-info-s");
|
||||||
|
|
||||||
static ssh_compressor *ssh_comp_none_init(void)
|
static ssh_compressor *ssh_comp_none_init(void)
|
||||||
{
|
{
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -938,9 +941,9 @@ static void ssh2_write_kexinit_lists(
|
|||||||
}
|
}
|
||||||
if (i == KEXLIST_KEX && first_time) {
|
if (i == KEXLIST_KEX && first_time) {
|
||||||
if (our_hostkeys) /* we're the server */
|
if (our_hostkeys) /* we're the server */
|
||||||
add_to_commasep(list, "ext-info-s");
|
add_to_commasep_pl(list, ext_info_s);
|
||||||
else /* we're the client */
|
else /* we're the client */
|
||||||
add_to_commasep(list, "ext-info-c");
|
add_to_commasep_pl(list, ext_info_c);
|
||||||
}
|
}
|
||||||
put_stringsb(pktout, list);
|
put_stringsb(pktout, list);
|
||||||
}
|
}
|
||||||
@ -955,6 +958,14 @@ struct server_hostkeys {
|
|||||||
size_t n, size;
|
size_t n, size;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static bool kexinit_keyword_found(ptrlen list, ptrlen keyword)
|
||||||
|
{
|
||||||
|
for (ptrlen word; get_commasep_word(&list, &word) ;)
|
||||||
|
if (ptrlen_eq_ptrlen(word, keyword))
|
||||||
|
return true;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
static bool ssh2_scan_kexinits(
|
static bool ssh2_scan_kexinits(
|
||||||
ptrlen client_kexinit, ptrlen server_kexinit, bool we_are_server,
|
ptrlen client_kexinit, ptrlen server_kexinit, bool we_are_server,
|
||||||
struct kexinit_algorithm_list kexlists[NKEXLIST],
|
struct kexinit_algorithm_list kexlists[NKEXLIST],
|
||||||
@ -1165,16 +1176,10 @@ static bool ssh2_scan_kexinits(
|
|||||||
/*
|
/*
|
||||||
* Check whether the other side advertised support for EXT_INFO.
|
* Check whether the other side advertised support for EXT_INFO.
|
||||||
*/
|
*/
|
||||||
{
|
if (kexinit_keyword_found(
|
||||||
ptrlen extinfo_advert =
|
we_are_server ? clists[KEXLIST_KEX] : slists[KEXLIST_KEX],
|
||||||
(we_are_server ? PTRLEN_LITERAL("ext-info-c") :
|
we_are_server ? ext_info_c : ext_info_s))
|
||||||
PTRLEN_LITERAL("ext-info-s"));
|
|
||||||
ptrlen list = (we_are_server ? clists[KEXLIST_KEX] :
|
|
||||||
slists[KEXLIST_KEX]);
|
|
||||||
for (ptrlen word; get_commasep_word(&list, &word) ;)
|
|
||||||
if (ptrlen_eq_ptrlen(word, extinfo_advert))
|
|
||||||
*can_send_ext_info = true;
|
*can_send_ext_info = true;
|
||||||
}
|
|
||||||
|
|
||||||
if (server_hostkeys) {
|
if (server_hostkeys) {
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user