diff options
Diffstat (limited to 'kexgexs.c')
-rw-r--r-- | kexgexs.c | 16 |
1 files changed, 3 insertions, 13 deletions
@@ -1,4 +1,4 @@ | |||
1 | /* $OpenBSD: kexgexs.c,v 1.40 2019/01/21 10:03:37 djm Exp $ */ | 1 | /* $OpenBSD: kexgexs.c,v 1.41 2019/01/21 10:05:09 djm Exp $ */ |
2 | /* | 2 | /* |
3 | * Copyright (c) 2000 Niels Provos. All rights reserved. | 3 | * Copyright (c) 2000 Niels Provos. All rights reserved. |
4 | * Copyright (c) 2001 Markus Friedl. All rights reserved. | 4 | * Copyright (c) 2001 Markus Friedl. All rights reserved. |
@@ -136,19 +136,9 @@ input_kex_dh_gex_init(int type, u_int32_t seq, struct ssh *ssh) | |||
136 | size_t hashlen; | 136 | size_t hashlen; |
137 | int r; | 137 | int r; |
138 | 138 | ||
139 | if (kex->load_host_public_key == NULL || | 139 | if ((r = kex_load_hostkey(ssh, &server_host_private, |
140 | kex->load_host_private_key == NULL) { | 140 | &server_host_public)) != 0) |
141 | r = SSH_ERR_INVALID_ARGUMENT; | ||
142 | goto out; | 141 | goto out; |
143 | } | ||
144 | server_host_public = kex->load_host_public_key(kex->hostkey_type, | ||
145 | kex->hostkey_nid, ssh); | ||
146 | server_host_private = kex->load_host_private_key(kex->hostkey_type, | ||
147 | kex->hostkey_nid, ssh); | ||
148 | if (server_host_public == NULL) { | ||
149 | r = SSH_ERR_NO_HOSTKEY_LOADED; | ||
150 | goto out; | ||
151 | } | ||
152 | 142 | ||
153 | /* key, cert */ | 143 | /* key, cert */ |
154 | if ((r = sshpkt_get_bignum2(ssh, &dh_client_pub)) != 0 || | 144 | if ((r = sshpkt_get_bignum2(ssh, &dh_client_pub)) != 0 || |