vishalmishra434 / rpms / openssh

Forked from rpms/openssh 3 months ago
Clone
Petr Lautrbach 94c6f8
diff --git a/auth.c b/auth.c
Petr Lautrbach 94c6f8
index 9a36f1d..420a85b 100644
Petr Lautrbach 94c6f8
--- a/auth.c
Petr Lautrbach 94c6f8
+++ b/auth.c
Petr Lautrbach 84822b
@@ -685,9 +685,10 @@ auth_key_is_revoked(Key *key)
Petr Lautrbach 84822b
 	case 1:
Petr Lautrbach 84822b
  revoked:
Petr Lautrbach 84822b
 		/* Key revoked */
Petr Lautrbach 84822b
-		key_fp = key_fingerprint(key, SSH_FP_MD5, SSH_FP_HEX);
Petr Lautrbach 84822b
+		key_fp = key_selected_fingerprint(key, SSH_FP_HEX);
Petr Lautrbach 84822b
 		error("WARNING: authentication attempt with a revoked "
Petr Lautrbach 84822b
-		    "%s key %s ", key_type(key), key_fp);
Petr Lautrbach 84822b
+		    "%s key %s%s ", key_type(key),
Petr Lautrbach 84822b
+		    key_fingerprint_prefix(), key_fp);
Petr Lautrbach 84822b
 		free(key_fp);
Petr Lautrbach 84822b
 		return 1;
Petr Lautrbach 84822b
 	}
Petr Lautrbach 94c6f8
diff --git a/auth2-hostbased.c b/auth2-hostbased.c
Petr Lautrbach 94c6f8
index 488008f..eca0069 100644
Petr Lautrbach 94c6f8
--- a/auth2-hostbased.c
Petr Lautrbach 94c6f8
+++ b/auth2-hostbased.c
Petr Lautrbach 94c6f8
@@ -206,16 +206,18 @@ hostbased_key_allowed(struct passwd *pw, const char *cuser, char *chost,
Jan F aefa65
 
Jan F aefa65
 	if (host_status == HOST_OK) {
Jan F aefa65
 		if (key_is_cert(key)) {
Jan F aefa65
-			fp = key_fingerprint(key->cert->signature_key,
Jan F aefa65
-			    SSH_FP_MD5, SSH_FP_HEX);
Jan F aefa65
+			fp = key_selected_fingerprint(key->cert->signature_key,
Petr Lautrbach 84822b
+			    SSH_FP_HEX);		
Jan F aefa65
 			verbose("Accepted certificate ID \"%s\" signed by "
Jan F aefa65
-			    "%s CA %s from %s@%s", key->cert->key_id,
Jan F aefa65
-			    key_type(key->cert->signature_key), fp,
Jan F aefa65
+			    "%s CA %s%s from %s@%s", key->cert->key_id,
Jan F aefa65
+			    key_type(key->cert->signature_key),
Jan F aefa65
+			    key_fingerprint_prefix(), fp,
Jan F aefa65
 			    cuser, lookup);
Jan F aefa65
 		} else {
Jan F aefa65
-			fp = key_fingerprint(key, SSH_FP_MD5, SSH_FP_HEX);
Jan F aefa65
-			verbose("Accepted %s public key %s from %s@%s",
Jan F aefa65
-			    key_type(key), fp, cuser, lookup);
Jan F aefa65
+			fp = key_selected_fingerprint(key, SSH_FP_HEX);
Jan F aefa65
+			verbose("Accepted %s public key %s%s from %s@%s",
Jan F aefa65
+			    key_type(key), key_fingerprint_prefix(),
Jan F aefa65
+			    fp, cuser, lookup);
Jan F aefa65
 		}
Petr Lautrbach 84822b
 		free(fp);
Jan F aefa65
 	}
Petr Lautrbach 94c6f8
diff --git a/auth2-pubkey.c b/auth2-pubkey.c
Petr Lautrbach 94c6f8
index 0fd27bb..749b11a 100644
Petr Lautrbach 94c6f8
--- a/auth2-pubkey.c
Petr Lautrbach 94c6f8
+++ b/auth2-pubkey.c
Petr Lautrbach 94c6f8
@@ -365,10 +365,10 @@ check_authkeys_file(FILE *f, char *file, Key* key, struct passwd *pw)
Jan F aefa65
 				continue;
Jan F aefa65
 			if (!key_is_cert_authority)
Jan F aefa65
 				continue;
Jan F aefa65
-			fp = key_fingerprint(found, SSH_FP_MD5,
Jan F aefa65
-			    SSH_FP_HEX);
Jan F aefa65
-			debug("matching CA found: file %s, line %lu, %s %s",
Jan F aefa65
-			    file, linenum, key_type(found), fp);
Jan F aefa65
+			fp = key_selected_fingerprint(found, SSH_FP_HEX);
Jan F aefa65
+			debug("matching CA found: file %s, line %lu, %s %s%s",
Jan F aefa65
+			    file, linenum, key_type(found),
Jan F aefa65
+			    key_fingerprint_prefix(), fp);
Jan F aefa65
 			/*
Jan F aefa65
 			 * If the user has specified a list of principals as
Jan F aefa65
 			 * a key option, then prefer that list to matching
Petr Lautrbach 94c6f8
@@ -406,9 +406,9 @@ check_authkeys_file(FILE *f, char *file, Key* key, struct passwd *pw)
Petr Lautrbach 84822b
 			if (key_is_cert_authority)
Petr Lautrbach 84822b
 				continue;
Jan F aefa65
 			found_key = 1;
Jan F aefa65
-			fp = key_fingerprint(found, SSH_FP_MD5, SSH_FP_HEX);
Petr Lautrbach 84822b
-			debug("matching key found: file %s, line %lu %s %s",
Petr Lautrbach 84822b
-			    file, linenum, key_type(found), fp);
Jan F aefa65
+			fp = key_selected_fingerprint(found, SSH_FP_HEX);
Jan F aefa65
+			verbose("Found matching %s key: %s%s",
Jan F aefa65
+			    key_type(found), key_fingerprint_prefix(), fp);
Petr Lautrbach 84822b
 			free(fp);
Jan F aefa65
 			break;
Jan F aefa65
 		}
Petr Lautrbach 94c6f8
@@ -431,13 +431,13 @@ user_cert_trusted_ca(struct passwd *pw, Key *key)
Jan F aefa65
 	if (!key_is_cert(key) || options.trusted_user_ca_keys == NULL)
Jan F aefa65
 		return 0;
Jan F aefa65
 
Jan F aefa65
-	ca_fp = key_fingerprint(key->cert->signature_key,
Jan F aefa65
-	    SSH_FP_MD5, SSH_FP_HEX);
Jan F aefa65
+	ca_fp = key_selected_fingerprint(key->cert->signature_key, SSH_FP_HEX);
Jan F aefa65
 
Jan F aefa65
 	if (key_in_file(key->cert->signature_key,
Jan F aefa65
 	    options.trusted_user_ca_keys, 1) != 1) {
Jan F aefa65
-		debug2("%s: CA %s %s is not listed in %s", __func__,
Jan F aefa65
-		    key_type(key->cert->signature_key), ca_fp,
Jan F aefa65
+		debug2("%s: CA %s%s %s is not listed in %s", __func__,
Jan F aefa65
+		    key_type(key->cert->signature_key),
Jan F aefa65
+		    key_fingerprint_prefix(), ca_fp,
Jan F aefa65
 		    options.trusted_user_ca_keys);
Jan F aefa65
 		goto out;
Jan F aefa65
 	}
Petr Lautrbach 94c6f8
diff --git a/key.c b/key.c
Petr Lautrbach 94c6f8
index 168e1b7..eb98ea8 100644
Petr Lautrbach 94c6f8
--- a/key.c
Petr Lautrbach 94c6f8
+++ b/key.c
Petr Lautrbach 94c6f8
@@ -628,6 +628,34 @@ key_fingerprint(const Key *k, enum fp_type dgst_type, enum fp_rep dgst_rep)
Jan F aefa65
 	return retval;
Jan F aefa65
 }
Jan F aefa65
 
Jan F 48446f
+enum fp_type
Jan F aefa65
+key_fingerprint_selection(void)
Jan F aefa65
+{
Jan F 48446f
+	static enum fp_type rv;
Jan F 48446f
+	static char rv_defined = 0;
Jan F aefa65
+	char *env;
Jan F aefa65
+
Jan F 48446f
+	if (!rv_defined) {
Jan F aefa65
+		env = getenv("SSH_FINGERPRINT_TYPE");
Jan F 48446f
+		rv = (env && !strcmp (env, "sha")) ?
Jan F 48446f
+			SSH_FP_SHA1 : SSH_FP_MD5;
Jan F 48446f
+		rv_defined = 1;
Jan F aefa65
+	}
Jan F aefa65
+	return rv;
Jan F aefa65
+}
Jan F aefa65
+
Jan F aefa65
+char *
Jan F aefa65
+key_selected_fingerprint(Key *k, enum fp_rep dgst_rep)
Jan F aefa65
+{
Jan F 48446f
+	return key_fingerprint(k, key_fingerprint_selection(), dgst_rep);
Jan F aefa65
+}
Jan F aefa65
+
Jan F aefa65
+char *
Jan F aefa65
+key_fingerprint_prefix(void)
Jan F aefa65
+{
Jan F 48446f
+	return key_fingerprint_selection() == SSH_FP_SHA1 ? "sha1:" : "";
Jan F aefa65
+}
Jan F aefa65
+
Jan F aefa65
 /*
Jan F aefa65
  * Reads a multiple-precision integer in decimal from the buffer, and advances
Jan F aefa65
  * the pointer.  The integer must already be initialized.  This function is
Petr Lautrbach 94c6f8
diff --git a/key.h b/key.h
Petr Lautrbach 94c6f8
index d8ad13d..0e3eea5 100644
Petr Lautrbach 94c6f8
--- a/key.h
Petr Lautrbach 94c6f8
+++ b/key.h
Petr Lautrbach 94c6f8
@@ -104,6 +104,9 @@ int		 key_equal_public(const Key *, const Key *);
Jan F aefa65
 int		 key_equal(const Key *, const Key *);
Petr Lautrbach 84822b
 char		*key_fingerprint(const Key *, enum fp_type, enum fp_rep);
Petr Lautrbach 8a29de
 u_char		*key_fingerprint_raw(const Key *, enum fp_type, u_int *);
Jan F 48446f
+enum fp_type	 key_fingerprint_selection(void);
Jan F aefa65
+char		*key_selected_fingerprint(Key *, enum fp_rep);
Jan F aefa65
+char		*key_fingerprint_prefix(void);
Jan F aefa65
 const char	*key_type(const Key *);
Jan F aefa65
 const char	*key_cert_type(const Key *);
Jan F aefa65
 int		 key_write(const Key *, FILE *);
Petr Lautrbach 94c6f8
diff --git a/ssh-add.c b/ssh-add.c
Petr Lautrbach 94c6f8
index 3421452..691949f 100644
Petr Lautrbach 94c6f8
--- a/ssh-add.c
Petr Lautrbach 94c6f8
+++ b/ssh-add.c
Petr Lautrbach 94c6f8
@@ -330,10 +330,10 @@ list_identities(AuthenticationConnection *ac, int do_fp)
Jan F aefa65
 		    key = ssh_get_next_identity(ac, &comment, version)) {
Jan F aefa65
 			had_identities = 1;
Jan F aefa65
 			if (do_fp) {
Jan F aefa65
-				fp = key_fingerprint(key, SSH_FP_MD5,
Jan F aefa65
-				    SSH_FP_HEX);
Jan F aefa65
-				printf("%d %s %s (%s)\n",
Jan F aefa65
-				    key_size(key), fp, comment, key_type(key));
Jan F aefa65
+				fp = key_selected_fingerprint(key, SSH_FP_HEX);
Jan F aefa65
+				printf("%d %s%s %s (%s)\n",
Jan F aefa65
+				    key_size(key), key_fingerprint_prefix(),
Jan F aefa65
+				    fp, comment, key_type(key));
Petr Lautrbach 84822b
 				free(fp);
Jan F aefa65
 			} else {
Jan F aefa65
 				if (!key_write(key, stdout))
Petr Lautrbach 94c6f8
diff --git a/ssh-agent.c b/ssh-agent.c
Petr Lautrbach 94c6f8
index ba24612..117fdde 100644
Petr Lautrbach 94c6f8
--- a/ssh-agent.c
Petr Lautrbach 94c6f8
+++ b/ssh-agent.c
Petr Lautrbach 84822b
@@ -198,9 +198,9 @@ confirm_key(Identity *id)
Jan F aefa65
 	char *p;
Jan F aefa65
 	int ret = -1;
Jan F aefa65
 
Jan F aefa65
-	p = key_fingerprint(id->key, SSH_FP_MD5, SSH_FP_HEX);
Jan F aefa65
-	if (ask_permission("Allow use of key %s?\nKey fingerprint %s.",
Jan F aefa65
-	    id->comment, p))
Jan F aefa65
+	p = key_selected_fingerprint(id->key, SSH_FP_HEX);
Jan F aefa65
+	if (ask_permission("Allow use of key %s?\nKey fingerprint %s%s.",
Jan F aefa65
+	    id->comment, key_fingerprint_prefix(), p))
Jan F aefa65
 		ret = 0;
Petr Lautrbach 84822b
 	free(p);
Jan F aefa65
 
Petr Lautrbach 94c6f8
diff --git a/ssh-keygen.c b/ssh-keygen.c
Petr Lautrbach 94c6f8
index 2a316bc..482dc1c 100644
Petr Lautrbach 94c6f8
--- a/ssh-keygen.c
Petr Lautrbach 94c6f8
+++ b/ssh-keygen.c
Petr Lautrbach 94c6f8
@@ -783,13 +783,14 @@ do_fingerprint(struct passwd *pw)
Jan F aefa65
 {
Jan F aefa65
 	FILE *f;
Jan F aefa65
 	Key *public;
Jan F aefa65
-	char *comment = NULL, *cp, *ep, line[16*1024], *fp, *ra;
Jan F aefa65
+	char *comment = NULL, *cp, *ep, line[16*1024], *fp, *ra, *pfx;
Jan F aefa65
 	int i, skip = 0, num = 0, invalid = 1;
Jan F aefa65
 	enum fp_rep rep;
Jan F aefa65
 	enum fp_type fptype;
Jan F aefa65
 	struct stat st;
Jan F aefa65
 
Jan F aefa65
-	fptype = print_bubblebabble ? SSH_FP_SHA1 : SSH_FP_MD5;
Jan F aefa65
+	fptype = print_bubblebabble ? SSH_FP_SHA1 : key_fingerprint_selection();
Jan F aefa65
+	pfx =	 print_bubblebabble ? "" : key_fingerprint_prefix();
Jan F aefa65
 	rep =    print_bubblebabble ? SSH_FP_BUBBLEBABBLE : SSH_FP_HEX;
Jan F aefa65
 
Jan F aefa65
 	if (!have_identity)
Petr Lautrbach 94c6f8
@@ -801,8 +802,8 @@ do_fingerprint(struct passwd *pw)
Jan F aefa65
 	public = key_load_public(identity_file, &comment);
Jan F aefa65
 	if (public != NULL) {
Jan F aefa65
 		fp = key_fingerprint(public, fptype, rep);
Jan F aefa65
-		ra = key_fingerprint(public, SSH_FP_MD5, SSH_FP_RANDOMART);
Jan F aefa65
-		printf("%u %s %s (%s)\n", key_size(public), fp, comment,
Jan F aefa65
+		ra = key_selected_fingerprint(public, SSH_FP_RANDOMART);
Jan F aefa65
+		printf("%u %s%s %s (%s)\n", key_size(public), pfx, fp, comment,
Jan F aefa65
 		    key_type(public));
Jan F aefa65
 		if (log_level >= SYSLOG_LEVEL_VERBOSE)
Jan F aefa65
 			printf("%s\n", ra);
Petr Lautrbach 94c6f8
@@ -867,8 +868,8 @@ do_fingerprint(struct passwd *pw)
Jan F aefa65
 		}
Jan F aefa65
 		comment = *cp ? cp : comment;
Jan F aefa65
 		fp = key_fingerprint(public, fptype, rep);
Jan F aefa65
-		ra = key_fingerprint(public, SSH_FP_MD5, SSH_FP_RANDOMART);
Jan F aefa65
-		printf("%u %s %s (%s)\n", key_size(public), fp,
Jan F aefa65
+		ra = key_selected_fingerprint(public, SSH_FP_RANDOMART);
Jan F aefa65
+		printf("%u %s%s %s (%s)\n", key_size(public), pfx, fp,
Jan F aefa65
 		    comment ? comment : "no comment", key_type(public));
Jan F aefa65
 		if (log_level >= SYSLOG_LEVEL_VERBOSE)
Jan F aefa65
 			printf("%s\n", ra);
Petr Lautrbach 94c6f8
@@ -986,13 +987,15 @@ printhost(FILE *f, const char *name, Key *public, int ca, int hash)
Jan F aefa65
 	if (print_fingerprint) {
Jan F aefa65
 		enum fp_rep rep;
Jan F aefa65
 		enum fp_type fptype;
Jan F aefa65
-		char *fp, *ra;
Jan F aefa65
+		char *fp, *ra, *pfx;
Jan F aefa65
 
Jan F aefa65
-		fptype = print_bubblebabble ? SSH_FP_SHA1 : SSH_FP_MD5;
Jan F aefa65
+		fptype = print_bubblebabble ? SSH_FP_SHA1 : key_fingerprint_selection();
Jan F aefa65
+		pfx =	 print_bubblebabble ? "" : key_fingerprint_prefix();
Jan F aefa65
 		rep =    print_bubblebabble ? SSH_FP_BUBBLEBABBLE : SSH_FP_HEX;
Jan F aefa65
+
Jan F aefa65
 		fp = key_fingerprint(public, fptype, rep);
Jan F aefa65
-		ra = key_fingerprint(public, SSH_FP_MD5, SSH_FP_RANDOMART);
Jan F aefa65
-		printf("%u %s %s (%s)\n", key_size(public), fp, name,
Jan F aefa65
+		ra = key_selected_fingerprint(public, SSH_FP_RANDOMART);
Jan F aefa65
+		printf("%u %s%s %s (%s)\n", key_size(public), pfx, fp, name,
Jan F aefa65
 		    key_type(public));
Jan F aefa65
 		if (log_level >= SYSLOG_LEVEL_VERBOSE)
Jan F aefa65
 			printf("%s\n", ra);
Petr Lautrbach 94c6f8
@@ -1878,16 +1881,17 @@ do_show_cert(struct passwd *pw)
Jan F aefa65
 		fatal("%s is not a certificate", identity_file);
Jan F aefa65
 	v00 = key->type == KEY_RSA_CERT_V00 || key->type == KEY_DSA_CERT_V00;
Jan F aefa65
 
Jan F aefa65
-	key_fp = key_fingerprint(key, SSH_FP_MD5, SSH_FP_HEX);
Jan F aefa65
-	ca_fp = key_fingerprint(key->cert->signature_key,
Jan F aefa65
-	    SSH_FP_MD5, SSH_FP_HEX);
Jan F aefa65
+	key_fp = key_selected_fingerprint(key, SSH_FP_HEX);
Jan F aefa65
+	ca_fp = key_selected_fingerprint(key->cert->signature_key, SSH_FP_HEX);
Jan F aefa65
 
Jan F aefa65
 	printf("%s:\n", identity_file);
Jan F aefa65
 	printf("        Type: %s %s certificate\n", key_ssh_name(key),
Jan F aefa65
 	    key_cert_type(key));
Jan F aefa65
-	printf("        Public key: %s %s\n", key_type(key), key_fp);
Jan F aefa65
-	printf("        Signing CA: %s %s\n",
Jan F aefa65
-	    key_type(key->cert->signature_key), ca_fp);
Jan F aefa65
+	printf("        Public key: %s %s%s\n", key_type(key),
Jan F aefa65
+	    key_fingerprint_prefix(), key_fp);
Jan F aefa65
+	printf("        Signing CA: %s %s%s\n",
Jan F aefa65
+	    key_type(key->cert->signature_key),
Jan F aefa65
+	    key_fingerprint_prefix(), ca_fp);
Jan F aefa65
 	printf("        Key ID: \"%s\"\n", key->cert->key_id);
Jan F aefa65
 	if (!v00) {
Jan F aefa65
 		printf("        Serial: %llu\n",
Petr Lautrbach 94c6f8
@@ -2686,13 +2690,12 @@ passphrase_again:
Jan F aefa65
 	fclose(f);
Jan F aefa65
 
Jan F aefa65
 	if (!quiet) {
Jan F aefa65
-		char *fp = key_fingerprint(public, SSH_FP_MD5, SSH_FP_HEX);
Jan F aefa65
-		char *ra = key_fingerprint(public, SSH_FP_MD5,
Jan F aefa65
-		    SSH_FP_RANDOMART);
Jan F aefa65
+		char *fp = key_selected_fingerprint(public, SSH_FP_HEX);
Jan F aefa65
+		char *ra = key_selected_fingerprint(public, SSH_FP_RANDOMART);
Jan F aefa65
 		printf("Your public key has been saved in %s.\n",
Jan F aefa65
 		    identity_file);
Jan F aefa65
 		printf("The key fingerprint is:\n");
Jan F aefa65
-		printf("%s %s\n", fp, comment);
Jan F aefa65
+		printf("%s%s %s\n", key_fingerprint_prefix(), fp, comment);
Jan F aefa65
 		printf("The key's randomart image is:\n");
Jan F aefa65
 		printf("%s\n", ra);
Petr Lautrbach 84822b
 		free(ra);
Petr Lautrbach 94c6f8
diff --git a/sshconnect.c b/sshconnect.c
Petr Lautrbach 94c6f8
index 573d7a8..394cca8 100644
Petr Lautrbach 94c6f8
--- a/sshconnect.c
Petr Lautrbach 94c6f8
+++ b/sshconnect.c
Petr Lautrbach 94c6f8
@@ -914,10 +914,10 @@ check_host_key(char *hostname, struct sockaddr *hostaddr, u_short port,
Petr Lautrbach 84822b
 				    "key for IP address '%.128s' to the list "
Petr Lautrbach 84822b
 				    "of known hosts.", type, ip);
Petr Lautrbach 84822b
 		} else if (options.visual_host_key) {
Petr Lautrbach 84822b
-			fp = key_fingerprint(host_key, SSH_FP_MD5, SSH_FP_HEX);
Petr Lautrbach 84822b
-			ra = key_fingerprint(host_key, SSH_FP_MD5,
Petr Lautrbach 84822b
-			    SSH_FP_RANDOMART);
Petr Lautrbach 84822b
-			logit("Host key fingerprint is %s\n%s\n", fp, ra);
Petr Lautrbach 84822b
+			fp = key_selected_fingerprint(host_key, SSH_FP_HEX);
Petr Lautrbach 84822b
+			ra = key_selected_fingerprint(host_key, SSH_FP_RANDOMART);
Petr Lautrbach 84822b
+			logit("Host key fingerprint is %s%s\n%s\n",
Petr Lautrbach 84822b
+			    key_fingerprint_prefix(), fp, ra);
Petr Lautrbach 84822b
 			free(ra);
Petr Lautrbach 84822b
 			free(fp);
Petr Lautrbach 84822b
 		}
Petr Lautrbach 94c6f8
@@ -955,9 +955,8 @@ check_host_key(char *hostname, struct sockaddr *hostaddr, u_short port,
Petr Lautrbach 84822b
 			else
Petr Lautrbach 84822b
 				snprintf(msg1, sizeof(msg1), ".");
Petr Lautrbach 84822b
 			/* The default */
Petr Lautrbach 84822b
-			fp = key_fingerprint(host_key, SSH_FP_MD5, SSH_FP_HEX);
Petr Lautrbach 84822b
-			ra = key_fingerprint(host_key, SSH_FP_MD5,
Petr Lautrbach 84822b
-			    SSH_FP_RANDOMART);
Petr Lautrbach 84822b
+			fp = key_selected_fingerprint(host_key, SSH_FP_HEX);
Petr Lautrbach 84822b
+			ra = key_selected_fingerprint(host_key, SSH_FP_RANDOMART);
Petr Lautrbach 84822b
 			msg2[0] = '\0';
Petr Lautrbach 84822b
 			if (options.verify_host_key_dns) {
Petr Lautrbach 84822b
 				if (matching_host_key_dns)
Petr Lautrbach 94c6f8
@@ -972,10 +971,11 @@ check_host_key(char *hostname, struct sockaddr *hostaddr, u_short port,
Petr Lautrbach 84822b
 			snprintf(msg, sizeof(msg),
Petr Lautrbach 84822b
 			    "The authenticity of host '%.200s (%s)' can't be "
Petr Lautrbach 84822b
 			    "established%s\n"
Petr Lautrbach 84822b
-			    "%s key fingerprint is %s.%s%s\n%s"
Petr Lautrbach 84822b
+			    "%s key fingerprint is %s%s.%s%s\n%s"
Petr Lautrbach 84822b
 			    "Are you sure you want to continue connecting "
Petr Lautrbach 84822b
 			    "(yes/no)? ",
Petr Lautrbach 84822b
-			    host, ip, msg1, type, fp,
Petr Lautrbach 84822b
+			    host, ip, msg1, type,
Petr Lautrbach 84822b
+			    key_fingerprint_prefix(), fp,
Petr Lautrbach 84822b
 			    options.visual_host_key ? "\n" : "",
Petr Lautrbach 84822b
 			    options.visual_host_key ? ra : "",
Petr Lautrbach 84822b
 			    msg2);
Petr Lautrbach 94c6f8
@@ -1220,8 +1220,9 @@ verify_host_key(char *host, struct sockaddr *hostaddr, Key *host_key)
Petr Lautrbach 84822b
 	int flags = 0;
Petr Lautrbach 84822b
 	char *fp;
Petr Lautrbach 84822b
 
Petr Lautrbach 84822b
-	fp = key_fingerprint(host_key, SSH_FP_MD5, SSH_FP_HEX);
Petr Lautrbach 84822b
-	debug("Server host key: %s %s", key_type(host_key), fp);
Petr Lautrbach 84822b
+	fp = key_selected_fingerprint(host_key, SSH_FP_HEX);
Petr Lautrbach 84822b
+	debug("Server host key: %s %s%s", key_type(host_key),
Petr Lautrbach 84822b
+	    key_fingerprint_prefix(), fp);
Petr Lautrbach 84822b
 	free(fp);
Petr Lautrbach 84822b
 
Petr Lautrbach 84822b
 	/* XXX certs are not yet supported for DNS */
Petr Lautrbach 94c6f8
@@ -1327,14 +1328,15 @@ show_other_keys(struct hostkeys *hostkeys, Key *key)
Petr Lautrbach 84822b
 			continue;
Petr Lautrbach 84822b
 		if (!lookup_key_in_hostkeys_by_type(hostkeys, type[i], &found))
Petr Lautrbach 84822b
 			continue;
Petr Lautrbach 84822b
-		fp = key_fingerprint(found->key, SSH_FP_MD5, SSH_FP_HEX);
Petr Lautrbach 84822b
-		ra = key_fingerprint(found->key, SSH_FP_MD5, SSH_FP_RANDOMART);
Petr Lautrbach 84822b
+		fp = key_selected_fingerprint(found->key, SSH_FP_HEX);
Petr Lautrbach 84822b
+		ra = key_selected_fingerprint(found->key, SSH_FP_RANDOMART);
Petr Lautrbach 84822b
 		logit("WARNING: %s key found for host %s\n"
Petr Lautrbach 84822b
 		    "in %s:%lu\n"
Petr Lautrbach 84822b
-		    "%s key fingerprint %s.",
Petr Lautrbach 84822b
+		    "%s key fingerprint %s%s.",
Petr Lautrbach 84822b
 		    key_type(found->key),
Petr Lautrbach 84822b
 		    found->host, found->file, found->line,
Petr Lautrbach 84822b
-		    key_type(found->key), fp);
Petr Lautrbach 84822b
+		    key_type(found->key),
Petr Lautrbach 84822b
+		    key_fingerprint_prefix(), fp);
Petr Lautrbach 84822b
 		if (options.visual_host_key)
Petr Lautrbach 84822b
 			logit("%s", ra);
Petr Lautrbach 84822b
 		free(ra);
Petr Lautrbach 94c6f8
@@ -1349,7 +1351,7 @@ warn_changed_key(Key *host_key)
Petr Lautrbach 84822b
 {
Petr Lautrbach 84822b
 	char *fp;
Petr Lautrbach 84822b
 
Petr Lautrbach 84822b
-	fp = key_fingerprint(host_key, SSH_FP_MD5, SSH_FP_HEX);
Petr Lautrbach 84822b
+	fp = key_selected_fingerprint(host_key, SSH_FP_HEX);
Petr Lautrbach 84822b
 
Petr Lautrbach 84822b
 	error("@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@");
Petr Lautrbach 84822b
 	error("@    WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!     @");
Petr Lautrbach 94c6f8
@@ -1357,8 +1359,8 @@ warn_changed_key(Key *host_key)
Petr Lautrbach 84822b
 	error("IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY!");
Petr Lautrbach 84822b
 	error("Someone could be eavesdropping on you right now (man-in-the-middle attack)!");
Petr Lautrbach 84822b
 	error("It is also possible that a host key has just been changed.");
Petr Lautrbach 84822b
-	error("The fingerprint for the %s key sent by the remote host is\n%s.",
Petr Lautrbach 84822b
-	    key_type(host_key), fp);
Petr Lautrbach 84822b
+	error("The fingerprint for the %s key sent by the remote host is\n%s%s.",
Petr Lautrbach 84822b
+	    key_type(host_key),key_fingerprint_prefix(),  fp);
Petr Lautrbach 84822b
 	error("Please contact your system administrator.");
Petr Lautrbach 84822b
 
Petr Lautrbach 84822b
 	free(fp);
Petr Lautrbach 94c6f8
diff --git a/sshconnect2.c b/sshconnect2.c
Petr Lautrbach 94c6f8
index 7f4ff41..adbbfc7 100644
Petr Lautrbach 94c6f8
--- a/sshconnect2.c
Petr Lautrbach 94c6f8
+++ b/sshconnect2.c
Petr Lautrbach 94c6f8
@@ -577,8 +577,9 @@ input_userauth_pk_ok(int type, u_int32_t seq, void *ctxt)
Petr Lautrbach 84822b
 		    key->type, pktype);
Petr Lautrbach 84822b
 		goto done;
Petr Lautrbach 84822b
 	}
Petr Lautrbach 84822b
-	fp = key_fingerprint(key, SSH_FP_MD5, SSH_FP_HEX);
Petr Lautrbach 84822b
-	debug2("input_userauth_pk_ok: fp %s", fp);
Petr Lautrbach 84822b
+	fp = key_selected_fingerprint(key, SSH_FP_HEX);
Petr Lautrbach 84822b
+	debug2("input_userauth_pk_ok: fp %s%s",
Petr Lautrbach 84822b
+	    key_fingerprint_prefix(), fp);
Petr Lautrbach 84822b
 	free(fp);
Petr Lautrbach 84822b
 
Petr Lautrbach 84822b
 	/*
Petr Lautrbach 94c6f8
@@ -986,8 +987,9 @@ sign_and_send_pubkey(Authctxt *authctxt, Identity *id)
Petr Lautrbach 84822b
 	int have_sig = 1;
Petr Lautrbach 84822b
 	char *fp;
Petr Lautrbach 84822b
 
Petr Lautrbach 84822b
-	fp = key_fingerprint(id->key, SSH_FP_MD5, SSH_FP_HEX);
Petr Lautrbach 84822b
-	debug3("sign_and_send_pubkey: %s %s", key_type(id->key), fp);
Petr Lautrbach 84822b
+	fp = key_selected_fingerprint(id->key, SSH_FP_HEX);
Petr Lautrbach 84822b
+	debug3("sign_and_send_pubkey: %s %s%s", key_type(id->key),
Petr Lautrbach 84822b
+	    key_fingerprint_prefix(), fp);
Petr Lautrbach 84822b
 	free(fp);
Petr Lautrbach 84822b
 
Petr Lautrbach 84822b
 	if (key_to_blob(id->key, &blob, &bloblen) == 0) {