upstream commit
Sanitise escape sequences in key comments sent to printf but preserve valid UTF-8 when the locale supports it; bz#2520 ok dtucker@ Upstream-ID: e8eed28712ba7b22d49be534237eed019875bd1e
This commit is contained in:
parent
e40269be38
commit
a287c5ad1e
12
ssh-keygen.c
12
ssh-keygen.c
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: ssh-keygen.c,v 1.293 2017/02/08 20:32:43 millert Exp $ */
|
/* $OpenBSD: ssh-keygen.c,v 1.294 2017/02/10 03:36:40 djm Exp $ */
|
||||||
/*
|
/*
|
||||||
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
||||||
* Copyright (c) 1994 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
* Copyright (c) 1994 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
||||||
|
@ -37,6 +37,7 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
|
#include <locale.h>
|
||||||
|
|
||||||
#include "xmalloc.h"
|
#include "xmalloc.h"
|
||||||
#include "sshkey.h"
|
#include "sshkey.h"
|
||||||
|
@ -57,6 +58,7 @@
|
||||||
#include "atomicio.h"
|
#include "atomicio.h"
|
||||||
#include "krl.h"
|
#include "krl.h"
|
||||||
#include "digest.h"
|
#include "digest.h"
|
||||||
|
#include "utf8.h"
|
||||||
|
|
||||||
#ifdef WITH_OPENSSL
|
#ifdef WITH_OPENSSL
|
||||||
# define DEFAULT_KEY_TYPE_NAME "rsa"
|
# define DEFAULT_KEY_TYPE_NAME "rsa"
|
||||||
|
@ -843,7 +845,7 @@ fingerprint_one_key(const struct sshkey *public, const char *comment)
|
||||||
ra = sshkey_fingerprint(public, fingerprint_hash, SSH_FP_RANDOMART);
|
ra = sshkey_fingerprint(public, fingerprint_hash, SSH_FP_RANDOMART);
|
||||||
if (fp == NULL || ra == NULL)
|
if (fp == NULL || ra == NULL)
|
||||||
fatal("%s: sshkey_fingerprint failed", __func__);
|
fatal("%s: sshkey_fingerprint failed", __func__);
|
||||||
printf("%u %s %s (%s)\n", sshkey_size(public), fp,
|
mprintf("%u %s %s (%s)\n", sshkey_size(public), fp,
|
||||||
comment ? comment : "no comment", sshkey_type(public));
|
comment ? comment : "no comment", sshkey_type(public));
|
||||||
if (log_level >= SYSLOG_LEVEL_VERBOSE)
|
if (log_level >= SYSLOG_LEVEL_VERBOSE)
|
||||||
printf("%s\n", ra);
|
printf("%s\n", ra);
|
||||||
|
@ -1166,7 +1168,7 @@ known_hosts_find_delete(struct hostkey_foreach_line *l, void *_ctx)
|
||||||
known_hosts_hash(l, ctx);
|
known_hosts_hash(l, ctx);
|
||||||
else if (print_fingerprint) {
|
else if (print_fingerprint) {
|
||||||
fp = sshkey_fingerprint(l->key, fptype, rep);
|
fp = sshkey_fingerprint(l->key, fptype, rep);
|
||||||
printf("%s %s %s %s\n", ctx->host,
|
mprintf("%s %s %s %s\n", ctx->host,
|
||||||
sshkey_type(l->key), fp, l->comment);
|
sshkey_type(l->key), fp, l->comment);
|
||||||
free(fp);
|
free(fp);
|
||||||
} else
|
} else
|
||||||
|
@ -1317,7 +1319,7 @@ do_change_passphrase(struct passwd *pw)
|
||||||
fatal("Failed to load key %s: %s", identity_file, ssh_err(r));
|
fatal("Failed to load key %s: %s", identity_file, ssh_err(r));
|
||||||
}
|
}
|
||||||
if (comment)
|
if (comment)
|
||||||
printf("Key has comment '%s'\n", comment);
|
mprintf("Key has comment '%s'\n", comment);
|
||||||
|
|
||||||
/* Ask the new passphrase (twice). */
|
/* Ask the new passphrase (twice). */
|
||||||
if (identity_new_passphrase) {
|
if (identity_new_passphrase) {
|
||||||
|
@ -2283,6 +2285,8 @@ main(int argc, char **argv)
|
||||||
|
|
||||||
seed_rng();
|
seed_rng();
|
||||||
|
|
||||||
|
msetlocale();
|
||||||
|
|
||||||
/* we need this for the home * directory. */
|
/* we need this for the home * directory. */
|
||||||
pw = getpwuid(getuid());
|
pw = getpwuid(getuid());
|
||||||
if (!pw)
|
if (!pw)
|
||||||
|
|
Loading…
Reference in New Issue