From e2a48fe9b11975ebab421bdf222edea4ea239965 Mon Sep 17 00:00:00 2001 From: Simon Tatham Date: Thu, 30 Aug 2012 18:44:33 +0000 Subject: [PATCH] Avoid leaking file handles in load_openssh_key(), as reported by David Wedderwille. [originally from svn r9642] --- import.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/import.c b/import.c index 05cfdc14..2ba2f9a0 100644 --- a/import.c +++ b/import.c @@ -321,7 +321,7 @@ static struct openssh_key *load_openssh_key(const Filename *filename, const char **errmsg_p) { struct openssh_key *ret; - FILE *fp; + FILE *fp = NULL; char *line = NULL; char *errmsg, *p; int headers_done; @@ -453,6 +453,9 @@ static struct openssh_key *load_openssh_key(const Filename *filename, line = NULL; } + fclose(fp); + fp = NULL; + if (ret->keyblob_len == 0 || !ret->keyblob) { errmsg = "key body not present"; goto error; @@ -483,6 +486,7 @@ static struct openssh_key *load_openssh_key(const Filename *filename, sfree(ret); } if (errmsg_p) *errmsg_p = errmsg; + if (fp) fclose(fp); return NULL; }