=================================================================== RCS file: /cvsrepo/anoncvs/cvs/src/usr.bin/ssh/Attic/key.c,v retrieving revision 1.55.2.2 retrieving revision 1.56 diff -u -r1.55.2.2 -r1.56 --- src/usr.bin/ssh/Attic/key.c 2005/03/10 17:15:04 1.55.2.2 +++ src/usr.bin/ssh/Attic/key.c 2004/07/28 09:40:29 1.56 @@ -32,7 +32,7 @@ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #include "includes.h" -RCSID("$OpenBSD: key.c,v 1.55.2.2 2005/03/10 17:15:04 brad Exp $"); +RCSID("$OpenBSD: key.c,v 1.56 2004/07/28 09:40:29 markus Exp $"); #include @@ -681,8 +681,8 @@ key_from_blob(const u_char *blob, u_int blen) { Buffer b; + char *ktype; int rlen, type; - char *ktype = NULL; Key *key = NULL; #ifdef DEBUG_PK @@ -690,38 +690,24 @@ #endif buffer_init(&b); buffer_append(&b, blob, blen); - if ((ktype = buffer_get_string_ret(&b, NULL)) == NULL) { - error("key_from_blob: can't read key type"); - goto out; - } - + ktype = buffer_get_string(&b, NULL); type = key_type_from_name(ktype); switch (type) { case KEY_RSA: key = key_new(type); - if (buffer_get_bignum2_ret(&b, key->rsa->e) == -1 || - buffer_get_bignum2_ret(&b, key->rsa->n) == -1) { - error("key_from_blob: can't read rsa key"); - key_free(key); - key = NULL; - goto out; - } + buffer_get_bignum2(&b, key->rsa->e); + buffer_get_bignum2(&b, key->rsa->n); #ifdef DEBUG_PK RSA_print_fp(stderr, key->rsa, 8); #endif break; case KEY_DSA: key = key_new(type); - if (buffer_get_bignum2_ret(&b, key->dsa->p) == -1 || - buffer_get_bignum2_ret(&b, key->dsa->q) == -1 || - buffer_get_bignum2_ret(&b, key->dsa->g) == -1 || - buffer_get_bignum2_ret(&b, key->dsa->pub_key) == -1) { - error("key_from_blob: can't read dsa key"); - key_free(key); - key = NULL; - goto out; - } + buffer_get_bignum2(&b, key->dsa->p); + buffer_get_bignum2(&b, key->dsa->q); + buffer_get_bignum2(&b, key->dsa->g); + buffer_get_bignum2(&b, key->dsa->pub_key); #ifdef DEBUG_PK DSA_print_fp(stderr, key->dsa, 8); #endif @@ -731,14 +717,12 @@ break; default: error("key_from_blob: cannot handle type %s", ktype); - goto out; + break; } rlen = buffer_len(&b); if (key != NULL && rlen != 0) error("key_from_blob: remaining bytes in key blob %d", rlen); - out: - if (ktype != NULL) - xfree(ktype); + xfree(ktype); buffer_free(&b); return key; }