summaryrefslogtreecommitdiffstats
path: root/usr.bin/ssh/ssh-add.c
diff options
context:
space:
mode:
authordtucker <dtucker@openbsd.org>2006-03-13 10:26:52 +0000
committerdtucker <dtucker@openbsd.org>2006-03-13 10:26:52 +0000
commit4f25ae33ee31a8934d5d70fd3177cc7de399492f (patch)
treebf99b0c3d0bbf6ead90a923b1a2398806e5351fd /usr.bin/ssh/ssh-add.c
parentAllow config directives to contain whitespace by surrounding them by double (diff)
downloadwireguard-openbsd-4f25ae33ee31a8934d5d70fd3177cc7de399492f.tar.xz
wireguard-openbsd-4f25ae33ee31a8934d5d70fd3177cc7de399492f.zip
Make ssh-add check file permissions before attempting to load private
key files multiple times; it will fail anyway and this prevents confusing multiple prompts and warnings. mindrot #1138, ok djm@
Diffstat (limited to 'usr.bin/ssh/ssh-add.c')
-rw-r--r--usr.bin/ssh/ssh-add.c17
1 files changed, 13 insertions, 4 deletions
diff --git a/usr.bin/ssh/ssh-add.c b/usr.bin/ssh/ssh-add.c
index 2e1998b78ad..1bf5744cf3a 100644
--- a/usr.bin/ssh/ssh-add.c
+++ b/usr.bin/ssh/ssh-add.c
@@ -35,7 +35,7 @@
*/
#include "includes.h"
-RCSID("$OpenBSD: ssh-add.c,v 1.75 2006/02/20 17:19:54 stevesk Exp $");
+RCSID("$OpenBSD: ssh-add.c,v 1.76 2006/03/13 10:26:52 dtucker Exp $");
#include <sys/types.h>
#include <sys/stat.h>
@@ -127,16 +127,25 @@ delete_all(AuthenticationConnection *ac)
static int
add_file(AuthenticationConnection *ac, const char *filename)
{
- struct stat st;
Key *private;
char *comment = NULL;
char msg[1024];
- int ret = -1;
+ int fd, perms_ok, ret = -1;
- if (stat(filename, &st) < 0) {
+ if ((fd = open(filename, 0)) < 0) {
perror(filename);
return -1;
}
+
+ /*
+ * Since we'll try to load a keyfile multiple times, permission errors
+ * will occur multiple times, so check perms first and bail if wrong.
+ */
+ perms_ok = key_perm_ok(fd, filename);
+ close(fd);
+ if (!perms_ok)
+ return -1;
+
/* At first, try empty passphrase */
private = key_load_private(filename, "", &comment);
if (comment == NULL)