vishalmishra434 / rpms / openssh

Forked from rpms/openssh a month ago
Clone
Jakub Jelen bc4ef0
diff -up openssh-7.0p1/gss-genr.c.gsskexalg openssh-7.0p1/gss-genr.c
Jakub Jelen bc4ef0
--- openssh-7.0p1/gss-genr.c.gsskexalg	2015-08-19 12:28:38.024518959 +0200
Jakub Jelen bc4ef0
+++ openssh-7.0p1/gss-genr.c	2015-08-19 12:28:38.078518839 +0200
Jakub Jelen bc4ef0
@@ -78,7 +78,8 @@ ssh_gssapi_oid_table_ok() {
Jakub Jelen bc4ef0
  */
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
 char *
Jakub Jelen bc4ef0
-ssh_gssapi_client_mechanisms(const char *host, const char *client) {
Jakub Jelen bc4ef0
+ssh_gssapi_client_mechanisms(const char *host, const char *client,
Jakub Jelen bc4ef0
+    const char *kex) {
Jakub Jelen bc4ef0
 	gss_OID_set gss_supported;
Jakub Jelen bc4ef0
 	OM_uint32 min_status;
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
@@ -86,12 +87,12 @@ ssh_gssapi_client_mechanisms(const char
Jakub Jelen bc4ef0
 		return NULL;
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
 	return(ssh_gssapi_kex_mechs(gss_supported, ssh_gssapi_check_mechanism,
Jakub Jelen bc4ef0
-	    host, client));
Jakub Jelen bc4ef0
+	    host, client, kex));
Jakub Jelen bc4ef0
 }
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
 char *
Jakub Jelen bc4ef0
 ssh_gssapi_kex_mechs(gss_OID_set gss_supported, ssh_gssapi_check_fn *check,
Jakub Jelen bc4ef0
-    const char *host, const char *client) {
Jakub Jelen bc4ef0
+    const char *host, const char *client, const char *kex) {
Jakub Jelen bc4ef0
 	Buffer buf;
Jakub Jelen bc4ef0
 	size_t i;
Jakub Jelen bc4ef0
 	int oidpos, enclen;
Jakub Jelen bc4ef0
@@ -100,6 +101,7 @@ ssh_gssapi_kex_mechs(gss_OID_set gss_sup
Jakub Jelen bc4ef0
 	char deroid[2];
Jakub Jelen bc4ef0
 	const EVP_MD *evp_md = EVP_md5();
Jakub Jelen bc4ef0
 	EVP_MD_CTX md;
Jakub Jelen bc4ef0
+	char *s, *cp, *p;
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
 	if (gss_enc2oid != NULL) {
Jakub Jelen bc4ef0
 		for (i = 0; gss_enc2oid[i].encoded != NULL; i++)
Jakub Jelen bc4ef0
@@ -113,6 +115,7 @@ ssh_gssapi_kex_mechs(gss_OID_set gss_sup
Jakub Jelen bc4ef0
 	buffer_init(&buf;;
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
 	oidpos = 0;
Jakub Jelen bc4ef0
+	s = cp = xstrdup(kex);
Jakub Jelen bc4ef0
 	for (i = 0; i < gss_supported->count; i++) {
Jakub Jelen bc4ef0
 		if (gss_supported->elements[i].length < 128 &&
Jakub Jelen bc4ef0
 		    (*check)(NULL, &(gss_supported->elements[i]), host, client)) {
Jakub Jelen bc4ef0
@@ -131,26 +134,22 @@ ssh_gssapi_kex_mechs(gss_OID_set gss_sup
Jakub Jelen bc4ef0
 			enclen = __b64_ntop(digest, EVP_MD_size(evp_md),
Jakub Jelen bc4ef0
 			    encoded, EVP_MD_size(evp_md) * 2);
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
-			if (oidpos != 0)
Jakub Jelen bc4ef0
-				buffer_put_char(&buf, ',');
Jakub Jelen bc4ef0
-
Jakub Jelen bc4ef0
-			buffer_append(&buf, KEX_GSS_GEX_SHA1_ID,
Jakub Jelen bc4ef0
-			    sizeof(KEX_GSS_GEX_SHA1_ID) - 1);
Jakub Jelen bc4ef0
-			buffer_append(&buf, encoded, enclen);
Jakub Jelen bc4ef0
-			buffer_put_char(&buf, ',');
Jakub Jelen bc4ef0
-			buffer_append(&buf, KEX_GSS_GRP1_SHA1_ID, 
Jakub Jelen bc4ef0
-			    sizeof(KEX_GSS_GRP1_SHA1_ID) - 1);
Jakub Jelen bc4ef0
-			buffer_append(&buf, encoded, enclen);
Jakub Jelen bc4ef0
-			buffer_put_char(&buf, ',');
Jakub Jelen bc4ef0
-			buffer_append(&buf, KEX_GSS_GRP14_SHA1_ID,
Jakub Jelen bc4ef0
-			    sizeof(KEX_GSS_GRP14_SHA1_ID) - 1);
Jakub Jelen bc4ef0
-			buffer_append(&buf, encoded, enclen);
Jakub Jelen bc4ef0
+			cp = strncpy(s, kex, strlen(kex));
Jakub Jelen bc4ef0
+			for ((p = strsep(&cp, ",")); p && *p != '\0';
Jakub Jelen bc4ef0
+				(p = strsep(&cp, ","))) {
Jakub Jelen bc4ef0
+				if (buffer_len(&buf) != 0)
Jakub Jelen bc4ef0
+					buffer_put_char(&buf, ',');
Jakub Jelen bc4ef0
+				buffer_append(&buf, p,
Jakub Jelen bc4ef0
+				    strlen(p));
Jakub Jelen bc4ef0
+				buffer_append(&buf, encoded, enclen);
Jakub Jelen bc4ef0
+			}
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
 			gss_enc2oid[oidpos].oid = &(gss_supported->elements[i]);
Jakub Jelen bc4ef0
 			gss_enc2oid[oidpos].encoded = encoded;
Jakub Jelen bc4ef0
 			oidpos++;
Jakub Jelen bc4ef0
 		}
Jakub Jelen bc4ef0
 	}
Jakub Jelen bc4ef0
+	free(s);
Jakub Jelen bc4ef0
 	gss_enc2oid[oidpos].oid = NULL;
Jakub Jelen bc4ef0
 	gss_enc2oid[oidpos].encoded = NULL;
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
diff -up openssh-7.0p1/gss-serv.c.gsskexalg openssh-7.0p1/gss-serv.c
Jakub Jelen bc4ef0
--- openssh-7.0p1/gss-serv.c.gsskexalg	2015-08-19 12:28:38.024518959 +0200
Jakub Jelen bc4ef0
+++ openssh-7.0p1/gss-serv.c	2015-08-19 12:28:38.078518839 +0200
Jakub Jelen bc4ef0
@@ -150,7 +150,7 @@ ssh_gssapi_server_mechanisms() {
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
 	ssh_gssapi_supported_oids(&supported);
Jakub Jelen bc4ef0
 	return (ssh_gssapi_kex_mechs(supported, &ssh_gssapi_server_check_mech,
Jakub Jelen bc4ef0
-	    NULL, NULL));
Jakub Jelen bc4ef0
+	    NULL, NULL, options.gss_kex_algorithms));
Jakub Jelen bc4ef0
 }
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
 /* Unprivileged */
Jakub Jelen bc4ef0
diff -up openssh-7.0p1/kex.c.gsskexalg openssh-7.0p1/kex.c
Jakub Jelen bc4ef0
--- openssh-7.0p1/kex.c.gsskexalg	2015-08-19 12:28:38.078518839 +0200
Jakub Jelen bc4ef0
+++ openssh-7.0p1/kex.c	2015-08-19 12:30:13.249306371 +0200
Jakub Jelen c4c52b
@@ -50,6 +50,7 @@
Jakub Jelen c4c52b
 #include "dispatch.h"
Jakub Jelen c4c52b
 #include "monitor.h"
Jakub Jelen c4c52b
 #include "roaming.h"
Jakub Jelen c4c52b
+#include "xmalloc.h"
Jakub Jelen c4c52b
 
Jakub Jelen c4c52b
 #include "ssherr.h"
Jakub Jelen c4c52b
 #include "sshbuf.h"
Jakub Jelen bc4ef0
@@ -232,6 +232,29 @@ kex_assemble_names(const char *def, char
Jakub Jelen bc4ef0
 	return 0;
Jakub Jelen bc4ef0
 }
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
+/* Validate GSS KEX method name list */
Jakub Jelen bc4ef0
+int
Jakub Jelen bc4ef0
+gss_kex_names_valid(const char *names)
Jakub Jelen bc4ef0
+{
Jakub Jelen bc4ef0
+	char *s, *cp, *p;
Jakub Jelen bc4ef0
+
Jakub Jelen bc4ef0
+	if (names == NULL || *names == '\0')
Jakub Jelen bc4ef0
+		return 0;
Jakub Jelen bc4ef0
+	s = cp = xstrdup(names);
Jakub Jelen bc4ef0
+	for ((p = strsep(&cp, ",")); p && *p != '\0';
Jakub Jelen bc4ef0
+	    (p = strsep(&cp, ","))) {
Jakub Jelen bc4ef0
+		if (strncmp(p, "gss-", 4) != 0
Jakub Jelen bc4ef0
+		  || kex_alg_by_name(p) == NULL) {
Jakub Jelen bc4ef0
+			error("Unsupported KEX algorithm \"%.100s\"", p);
Jakub Jelen bc4ef0
+			free(s);
Jakub Jelen bc4ef0
+			return 0;
Jakub Jelen bc4ef0
+		}
Jakub Jelen bc4ef0
+	}
Jakub Jelen bc4ef0
+	debug3("gss kex names ok: [%s]", names);
Jakub Jelen bc4ef0
+	free(s);
Jakub Jelen bc4ef0
+	return 1;
Jakub Jelen bc4ef0
+}
Jakub Jelen bc4ef0
+
Jakub Jelen bc4ef0
 /* put algorithm proposal into buffer */
Jakub Jelen bc4ef0
 int
Jakub Jelen bc4ef0
 kex_prop2buf(struct sshbuf *b, char *proposal[PROPOSAL_MAX])
Jakub Jelen bc4ef0
diff -up openssh-7.0p1/kex.h.gsskexalg openssh-7.0p1/kex.h
Jakub Jelen bc4ef0
--- openssh-7.0p1/kex.h.gsskexalg	2015-08-19 12:28:38.078518839 +0200
Jakub Jelen bc4ef0
+++ openssh-7.0p1/kex.h	2015-08-19 12:30:52.404218958 +0200
Jakub Jelen bc4ef0
@@ -173,6 +173,7 @@ int	 kex_names_valid(const char *);
Jakub Jelen bc4ef0
 char	*kex_alg_list(char);
Jakub Jelen bc4ef0
 char	*kex_names_cat(const char *, const char *);
Jakub Jelen bc4ef0
 int	 kex_assemble_names(const char *, char **);
Jakub Jelen bc4ef0
+int	 gss_kex_names_valid(const char *);
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
 int	 kex_new(struct ssh *, char *[PROPOSAL_MAX], struct kex **);
Jakub Jelen bc4ef0
 int	 kex_setup(struct ssh *, char *[PROPOSAL_MAX]);
Jakub Jelen bc4ef0
diff -up openssh-7.0p1/readconf.c.gsskexalg openssh-7.0p1/readconf.c
Jakub Jelen bc4ef0
--- openssh-7.0p1/readconf.c.gsskexalg	2015-08-19 12:28:38.026518955 +0200
Jakub Jelen bc4ef0
+++ openssh-7.0p1/readconf.c	2015-08-19 12:31:28.333138747 +0200
Jakub Jelen bc4ef0
@@ -61,6 +61,7 @@
Jakub Jelen bc4ef0
 #include "uidswap.h"
Jakub Jelen bc4ef0
 #include "myproposal.h"
Jakub Jelen bc4ef0
 #include "digest.h"
Jakub Jelen bc4ef0
+#include "ssh-gss.h"
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
 /* Format of the configuration file:
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
@@ -148,7 +149,7 @@ typedef enum {
Jakub Jelen bc4ef0
 	oEnableSSHKeysign, oRekeyLimit, oVerifyHostKeyDNS, oConnectTimeout,
Jakub Jelen bc4ef0
 	oAddressFamily, oGssAuthentication, oGssDelegateCreds,
Jakub Jelen bc4ef0
 	oGssTrustDns, oGssKeyEx, oGssClientIdentity, oGssRenewalRekey,
Jakub Jelen bc4ef0
-	oGssServerIdentity, 
Jakub Jelen bc4ef0
+	oGssServerIdentity, oGssKexAlgorithms,
Jakub Jelen bc4ef0
 	oServerAliveInterval, oServerAliveCountMax, oIdentitiesOnly,
Jakub Jelen bc4ef0
 	oSendEnv, oControlPath, oControlMaster, oControlPersist,
Jakub Jelen bc4ef0
 	oHashKnownHosts,
Jakub Jelen bc4ef0
@@ -200,6 +201,7 @@ static struct {
Jakub Jelen bc4ef0
 	{ "gssapiclientidentity", oGssClientIdentity },
Jakub Jelen bc4ef0
 	{ "gssapiserveridentity", oGssServerIdentity },
Jakub Jelen bc4ef0
 	{ "gssapirenewalforcesrekey", oGssRenewalRekey },
Jakub Jelen bc4ef0
+	{ "gssapikexalgorithms", oGssKexAlgorithms },
Jakub Jelen bc4ef0
 #else
Jakub Jelen bc4ef0
 	{ "gssapiauthentication", oUnsupported },
Jakub Jelen bc4ef0
 	{ "gssapikeyexchange", oUnsupported },
Jakub Jelen bc4ef0
@@ -207,6 +209,7 @@ static struct {
Jakub Jelen bc4ef0
 	{ "gssapitrustdns", oUnsupported },
Jakub Jelen bc4ef0
 	{ "gssapiclientidentity", oUnsupported },
Jakub Jelen bc4ef0
 	{ "gssapirenewalforcesrekey", oUnsupported },
Jakub Jelen bc4ef0
+	{ "gssapikexalgorithms", oUnsupported },
Jakub Jelen bc4ef0
 #endif
Jakub Jelen bc4ef0
 	{ "fallbacktorsh", oDeprecated },
Jakub Jelen bc4ef0
 	{ "usersh", oDeprecated },
Jakub Jelen bc4ef0
@@ -929,6 +932,18 @@ parse_time:
Jakub Jelen bc4ef0
 		intptr = &options->gss_renewal_rekey;
Jakub Jelen bc4ef0
 		goto parse_flag;
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
+	case oGssKexAlgorithms:
Jakub Jelen bc4ef0
+		arg = strdelim(&s);
Jakub Jelen bc4ef0
+		if (!arg || *arg == '\0')
Jakub Jelen bc4ef0
+			fatal("%.200s line %d: Missing argument.",
Jakub Jelen bc4ef0
+			    filename, linenum);
Jakub Jelen bc4ef0
+		if (!gss_kex_names_valid(arg))
Jakub Jelen bc4ef0
+			fatal("%.200s line %d: Bad GSSAPI KexAlgorithms '%s'.",
Jakub Jelen bc4ef0
+			    filename, linenum, arg ? arg : "<NONE>");
Jakub Jelen bc4ef0
+		if (*activep && options->gss_kex_algorithms == NULL)
Jakub Jelen bc4ef0
+			options->gss_kex_algorithms = xstrdup(arg);
Jakub Jelen bc4ef0
+		break;
Jakub Jelen bc4ef0
+
Jakub Jelen bc4ef0
 	case oBatchMode:
Jakub Jelen bc4ef0
 		intptr = &options->batch_mode;
Jakub Jelen bc4ef0
 		goto parse_flag;
Jakub Jelen bc4ef0
@@ -1638,6 +1653,7 @@ initialize_options(Options * options)
Jakub Jelen bc4ef0
 	options->gss_renewal_rekey = -1;
Jakub Jelen bc4ef0
 	options->gss_client_identity = NULL;
Jakub Jelen bc4ef0
 	options->gss_server_identity = NULL;
Jakub Jelen bc4ef0
+	options->gss_kex_algorithms = NULL;
Jakub Jelen bc4ef0
 	options->password_authentication = -1;
Jakub Jelen bc4ef0
 	options->kbd_interactive_authentication = -1;
Jakub Jelen bc4ef0
 	options->kbd_interactive_devices = NULL;
Jakub Jelen bc4ef0
@@ -1773,6 +1789,8 @@ fill_default_options(Options * options)
Jakub Jelen bc4ef0
 		options->gss_trust_dns = 0;
Jakub Jelen bc4ef0
 	if (options->gss_renewal_rekey == -1)
Jakub Jelen bc4ef0
 		options->gss_renewal_rekey = 0;
Jakub Jelen bc4ef0
+	if (options->gss_kex_algorithms == NULL)
Jakub Jelen bc4ef0
+		options->gss_kex_algorithms = strdup(GSS_KEX_DEFAULT_KEX);
Jakub Jelen bc4ef0
 	if (options->password_authentication == -1)
Jakub Jelen bc4ef0
 		options->password_authentication = 1;
Jakub Jelen bc4ef0
 	if (options->kbd_interactive_authentication == -1)
Jakub Jelen bc4ef0
diff -up openssh-7.0p1/readconf.h.gsskexalg openssh-7.0p1/readconf.h
Jakub Jelen bc4ef0
--- openssh-7.0p1/readconf.h.gsskexalg	2015-08-19 12:28:38.026518955 +0200
Jakub Jelen bc4ef0
+++ openssh-7.0p1/readconf.h	2015-08-19 12:28:38.079518836 +0200
Jakub Jelen bc4ef0
@@ -51,6 +51,7 @@ typedef struct {
Jakub Jelen bc4ef0
 	int	gss_renewal_rekey;	/* Credential renewal forces rekey */
Jakub Jelen bc4ef0
 	char    *gss_client_identity;   /* Principal to initiate GSSAPI with */
Jakub Jelen bc4ef0
 	char    *gss_server_identity;   /* GSSAPI target principal */
Jakub Jelen bc4ef0
+	char   *gss_kex_algorithms;	/* GSSAPI kex methods to be offered by client. */
Jakub Jelen bc4ef0
 	int     password_authentication;	/* Try password
Jakub Jelen bc4ef0
 						 * authentication. */
Jakub Jelen bc4ef0
 	int     kbd_interactive_authentication; /* Try keyboard-interactive auth. */
Jakub Jelen bc4ef0
diff -up openssh-7.0p1/servconf.c.gsskexalg openssh-7.0p1/servconf.c
Jakub Jelen bc4ef0
--- openssh-7.0p1/servconf.c.gsskexalg	2015-08-19 12:28:38.074518847 +0200
Jakub Jelen bc4ef0
+++ openssh-7.0p1/servconf.c	2015-08-19 12:33:13.599902732 +0200
Jakub Jelen bc4ef0
@@ -57,6 +57,7 @@
Jakub Jelen bc4ef0
 #include "auth.h"
Jakub Jelen bc4ef0
 #include "myproposal.h"
Jakub Jelen bc4ef0
 #include "digest.h"
Jakub Jelen bc4ef0
+#include "ssh-gss.h"
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
 static void add_listen_addr(ServerOptions *, char *, int);
Jakub Jelen bc4ef0
 static void add_one_listen_addr(ServerOptions *, char *, int);
Jakub Jelen bc4ef0
@@ -121,6 +122,7 @@ initialize_server_options(ServerOptions
Jakub Jelen bc4ef0
 	options->gss_cleanup_creds = -1;
Jakub Jelen bc4ef0
 	options->gss_strict_acceptor = -1;
Jakub Jelen bc4ef0
 	options->gss_store_rekey = -1;
Jakub Jelen bc4ef0
+	options->gss_kex_algorithms = NULL;
Jakub Jelen bc4ef0
 	options->password_authentication = -1;
Jakub Jelen bc4ef0
 	options->kbd_interactive_authentication = -1;
Jakub Jelen bc4ef0
 	options->challenge_response_authentication = -1;
Jakub Jelen bc4ef0
@@ -288,6 +290,8 @@ fill_default_server_options(ServerOption
Jakub Jelen bc4ef0
 		options->gss_strict_acceptor = 0;
Jakub Jelen bc4ef0
 	if (options->gss_store_rekey == -1)
Jakub Jelen bc4ef0
 		options->gss_store_rekey = 0;
Jakub Jelen bc4ef0
+	if (options->gss_kex_algorithms == NULL)
Jakub Jelen bc4ef0
+		options->gss_kex_algorithms = strdup(GSS_KEX_DEFAULT_KEX);
Jakub Jelen bc4ef0
 	if (options->password_authentication == -1)
Jakub Jelen bc4ef0
 		options->password_authentication = 1;
Jakub Jelen bc4ef0
 	if (options->kbd_interactive_authentication == -1)
Jakub Jelen bc4ef0
@@ -427,7 +431,7 @@ typedef enum {
Jakub Jelen bc4ef0
 	sHostKeyAlgorithms,
Jakub Jelen bc4ef0
 	sClientAliveInterval, sClientAliveCountMax, sAuthorizedKeysFile,
Jakub Jelen bc4ef0
 	sGssAuthentication, sGssCleanupCreds, sGssEnablek5users, sGssStrictAcceptor,
Jakub Jelen bc4ef0
-	sGssKeyEx, sGssStoreRekey, sAcceptEnv, sPermitTunnel,
Jakub Jelen bc4ef0
+	sGssKeyEx, sGssStoreRekey, sGssKexAlgorithms, sAcceptEnv, sPermitTunnel,
Jakub Jelen bc4ef0
 	sMatch, sPermitOpen, sForceCommand, sChrootDirectory,
Jakub Jelen bc4ef0
 	sUsePrivilegeSeparation, sAllowAgentForwarding,
Jakub Jelen bc4ef0
 	sHostCertificate,
Jakub Jelen bc4ef0
@@ -506,6 +510,7 @@ static struct {
Jakub Jelen bc4ef0
 	{ "gssapikeyexchange", sGssKeyEx, SSHCFG_GLOBAL },
Jakub Jelen bc4ef0
 	{ "gssapistorecredentialsonrekey", sGssStoreRekey, SSHCFG_GLOBAL },
Jakub Jelen bc4ef0
 	{ "gssapienablek5users", sGssEnablek5users, SSHCFG_ALL },
Jakub Jelen bc4ef0
+	{ "gssapikexalgorithms", sGssKexAlgorithms, SSHCFG_GLOBAL },
Jakub Jelen bc4ef0
 #else
Jakub Jelen bc4ef0
 	{ "gssapiauthentication", sUnsupported, SSHCFG_ALL },
Jakub Jelen bc4ef0
 	{ "gssapicleanupcredentials", sUnsupported, SSHCFG_GLOBAL },
Jakub Jelen bc4ef0
@@ -513,6 +518,7 @@ static struct {
Jakub Jelen bc4ef0
 	{ "gssapikeyexchange", sUnsupported, SSHCFG_GLOBAL },
Jakub Jelen bc4ef0
 	{ "gssapistorecredentialsonrekey", sUnsupported, SSHCFG_GLOBAL },
Jakub Jelen bc4ef0
 	{ "gssapienablek5users", sUnsupported, SSHCFG_ALL },
Jakub Jelen bc4ef0
+	{ "gssapikexalgorithms", sUnsupported, SSHCFG_GLOBAL },
Jakub Jelen bc4ef0
 #endif
Jakub Jelen bc4ef0
 	{ "gssusesessionccache", sUnsupported, SSHCFG_GLOBAL },
Jakub Jelen bc4ef0
 	{ "gssapiusesessioncredcache", sUnsupported, SSHCFG_GLOBAL },
Jakub Jelen bc4ef0
@@ -1273,6 +1279,18 @@ process_server_config_line(ServerOptions
Jakub Jelen bc4ef0
 		intptr = &options->gss_store_rekey;
Jakub Jelen bc4ef0
 		goto parse_flag;
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
+	case sGssKexAlgorithms:
Jakub Jelen bc4ef0
+		arg = strdelim(&cp;;
Jakub Jelen bc4ef0
+		if (!arg || *arg == '\0')
Jakub Jelen bc4ef0
+			fatal("%.200s line %d: Missing argument.",
Jakub Jelen bc4ef0
+			    filename, linenum);
Jakub Jelen bc4ef0
+		if (!gss_kex_names_valid(arg))
Jakub Jelen bc4ef0
+			fatal("%.200s line %d: Bad GSSAPI KexAlgorithms '%s'.",
Jakub Jelen bc4ef0
+			    filename, linenum, arg ? arg : "<NONE>");
Jakub Jelen bc4ef0
+		if (*activep && options->gss_kex_algorithms == NULL)
Jakub Jelen bc4ef0
+			options->gss_kex_algorithms = xstrdup(arg);
Jakub Jelen bc4ef0
+		break;
Jakub Jelen bc4ef0
+
Jakub Jelen bc4ef0
 	case sPasswordAuthentication:
Jakub Jelen bc4ef0
 		intptr = &options->password_authentication;
Jakub Jelen bc4ef0
 		goto parse_flag;
Jakub Jelen bc4ef0
@@ -2304,6 +2322,7 @@ dump_config(ServerOptions *o)
Jakub Jelen bc4ef0
 	dump_cfg_fmtint(sGssKeyEx, o->gss_keyex);
Jakub Jelen bc4ef0
 	dump_cfg_fmtint(sGssStrictAcceptor, o->gss_strict_acceptor);
Jakub Jelen bc4ef0
 	dump_cfg_fmtint(sGssStoreRekey, o->gss_store_rekey);
Jakub Jelen bc4ef0
+	dump_cfg_string(sGssKexAlgorithms, o->gss_kex_algorithms);
Jakub Jelen bc4ef0
 #endif
Jakub Jelen bc4ef0
 	dump_cfg_fmtint(sPasswordAuthentication, o->password_authentication);
Jakub Jelen bc4ef0
 	dump_cfg_fmtint(sKbdInteractiveAuthentication,
Jakub Jelen bc4ef0
diff -up openssh-7.0p1/servconf.h.gsskexalg openssh-7.0p1/servconf.h
Jakub Jelen bc4ef0
--- openssh-7.0p1/servconf.h.gsskexalg	2015-08-19 12:28:38.080518834 +0200
Jakub Jelen bc4ef0
+++ openssh-7.0p1/servconf.h	2015-08-19 12:34:46.328693944 +0200
Jakub Jelen bc4ef0
@@ -122,6 +122,7 @@ typedef struct {
Jakub Jelen bc4ef0
 	int     gss_cleanup_creds;	/* If true, destroy cred cache on logout */
Jakub Jelen bc4ef0
 	int     gss_strict_acceptor;	/* If true, restrict the GSSAPI acceptor name */
Jakub Jelen bc4ef0
 	int 	gss_store_rekey;
Jakub Jelen bc4ef0
+	char   *gss_kex_algorithms;	/* GSSAPI kex methods to be offered by client. */
Jakub Jelen bc4ef0
 	int     password_authentication;	/* If true, permit password
Jakub Jelen bc4ef0
 						 * authentication. */
Jakub Jelen bc4ef0
 	int     kbd_interactive_authentication;	/* If true, permit */
Jakub Jelen bc4ef0
diff -up openssh-7.0p1/ssh.1.gsskexalg openssh-7.0p1/ssh.1
Jakub Jelen bc4ef0
--- openssh-7.0p1/ssh.1.gsskexalg	2015-08-19 12:28:38.081518832 +0200
Jakub Jelen bc4ef0
+++ openssh-7.0p1/ssh.1	2015-08-19 12:35:31.741591692 +0200
Jakub Jelen bc4ef0
@@ -496,6 +496,7 @@ For full details of the options listed b
Jakub Jelen bc4ef0
 .It GSSAPIDelegateCredentials
Jakub Jelen bc4ef0
 .It GSSAPIRenewalForcesRekey
Jakub Jelen bc4ef0
 .It GSSAPITrustDNS
Jakub Jelen bc4ef0
+.It GSSAPIKexAlgorithms
Jakub Jelen bc4ef0
 .It HashKnownHosts
Jakub Jelen bc4ef0
 .It Host
Jakub Jelen bc4ef0
 .It HostbasedAuthentication
Jakub Jelen bc4ef0
diff -up openssh-7.0p1/ssh_config.5.gsskexalg openssh-7.0p1/ssh_config.5
Jakub Jelen bc4ef0
--- openssh-7.0p1/ssh_config.5.gsskexalg	2015-08-19 12:28:38.028518950 +0200
Jakub Jelen bc4ef0
+++ openssh-7.0p1/ssh_config.5	2015-08-19 12:28:38.082518830 +0200
Jakub Jelen bc4ef0
@@ -786,6 +786,18 @@ command line will be passed untouched to
Jakub Jelen bc4ef0
 The default is
Jakub Jelen bc4ef0
 .Dq no .
Jakub Jelen bc4ef0
 This option only applies to protocol version 2 connections using GSSAPI.
Jakub Jelen bc4ef0
+.It Cm GSSAPIKexAlgorithms
Jakub Jelen bc4ef0
+The list of key exchange algorithms that are offered for GSSAPI
Jakub Jelen bc4ef0
+key exchange. Possible values are
Jakub Jelen bc4ef0
+.Bd -literal -offset 3n
Jakub Jelen bc4ef0
+gss-gex-sha1-,
Jakub Jelen bc4ef0
+gss-group1-sha1-,
Jakub Jelen bc4ef0
+gss-group14-sha1-
Jakub Jelen bc4ef0
+.Ed
Jakub Jelen bc4ef0
+.Pp
Jakub Jelen bc4ef0
+The default is
Jakub Jelen bc4ef0
+.Dq gss-gex-sha1-,gss-group14-sha1- .
Jakub Jelen bc4ef0
+This option only applies to protocol version 2 connections using GSSAPI.
Jakub Jelen bc4ef0
 .It Cm HashKnownHosts
Jakub Jelen bc4ef0
 Indicates that
Jakub Jelen bc4ef0
 .Xr ssh 1
Jakub Jelen bc4ef0
diff -up openssh-7.0p1/sshconnect2.c.gsskexalg openssh-7.0p1/sshconnect2.c
Jakub Jelen bc4ef0
--- openssh-7.0p1/sshconnect2.c.gsskexalg	2015-08-19 12:28:38.045518912 +0200
Jakub Jelen bc4ef0
+++ openssh-7.0p1/sshconnect2.c	2015-08-19 12:28:38.081518832 +0200
Jakub Jelen bc4ef0
@@ -179,7 +179,8 @@ ssh_kex2(char *host, struct sockaddr *ho
Jakub Jelen bc4ef0
 		else
Jakub Jelen bc4ef0
 			gss_host = host;
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
-		gss = ssh_gssapi_client_mechanisms(gss_host, options.gss_client_identity);
Jakub Jelen bc4ef0
+		gss = ssh_gssapi_client_mechanisms(gss_host,
Jakub Jelen bc4ef0
+		    options.gss_client_identity, options.gss_kex_algorithms);
Jakub Jelen bc4ef0
 		if (gss) {
Jakub Jelen bc4ef0
 			debug("Offering GSSAPI proposal: %s", gss);
Jakub Jelen 9a804f
 			xasprintf(&options.kex_algorithms,
Jakub Jelen bc4ef0
diff -up openssh-7.0p1/sshd_config.5.gsskexalg openssh-7.0p1/sshd_config.5
Jakub Jelen bc4ef0
--- openssh-7.0p1/sshd_config.5.gsskexalg	2015-08-19 12:28:38.082518830 +0200
Jakub Jelen bc4ef0
+++ openssh-7.0p1/sshd_config.5	2015-08-19 12:36:25.121471501 +0200
Jakub Jelen bc4ef0
@@ -659,6 +659,18 @@ Controls whether the user's GSSAPI crede
Jakub Jelen bc4ef0
 successful connection rekeying. This option can be used to accepted renewed 
Jakub Jelen bc4ef0
 or updated credentials from a compatible client. The default is
Jakub Jelen bc4ef0
 .Dq no .
Jakub Jelen bc4ef0
+.It Cm GSSAPIKexAlgorithms
Jakub Jelen bc4ef0
+The list of key exchange algorithms that are accepted by GSSAPI
Jakub Jelen bc4ef0
+key exchange. Possible values are
Jakub Jelen bc4ef0
+.Bd -literal -offset 3n
Jakub Jelen bc4ef0
+gss-gex-sha1-,
Jakub Jelen bc4ef0
+gss-group1-sha1-,
Jakub Jelen bc4ef0
+gss-group14-sha1-
Jakub Jelen bc4ef0
+.Ed
Jakub Jelen bc4ef0
+.Pp
Jakub Jelen bc4ef0
+The default is
Jakub Jelen bc4ef0
+.Dq gss-gex-sha1-,gss-group14-sha1- .
Jakub Jelen bc4ef0
+This option only applies to protocol version 2 connections using GSSAPI.
Jakub Jelen bc4ef0
 .It Cm HostbasedAcceptedKeyTypes
Jakub Jelen bc4ef0
 Specifies the key types that will be accepted for hostbased authentication
Jakub Jelen bc4ef0
 as a comma-separated pattern list.
Jakub Jelen bc4ef0
diff -up openssh-7.0p1/ssh-gss.h.gsskexalg openssh-7.0p1/ssh-gss.h
Jakub Jelen bc4ef0
--- openssh-7.0p1/ssh-gss.h.gsskexalg	2015-08-19 12:28:38.031518944 +0200
Jakub Jelen bc4ef0
+++ openssh-7.0p1/ssh-gss.h	2015-08-19 12:28:38.081518832 +0200
Jakub Jelen bc4ef0
@@ -76,6 +76,10 @@ extern char **k5users_allowed_cmds;
Jakub Jelen bc4ef0
 #define KEX_GSS_GRP14_SHA1_ID				"gss-group14-sha1-"
Jakub Jelen bc4ef0
 #define KEX_GSS_GEX_SHA1_ID				"gss-gex-sha1-"
Jakub Jelen bc4ef0
 
Jakub Jelen bc4ef0
+#define        GSS_KEX_DEFAULT_KEX \
Jakub Jelen bc4ef0
+	KEX_GSS_GEX_SHA1_ID "," \
Jakub Jelen bc4ef0
+	KEX_GSS_GRP14_SHA1_ID
Jakub Jelen bc4ef0
+
Jakub Jelen bc4ef0
 typedef struct {
Jakub Jelen bc4ef0
 	char *filename;
Jakub Jelen bc4ef0
 	char *envvar;
Jakub Jelen bc4ef0
@@ -147,9 +151,9 @@ int ssh_gssapi_credentials_updated(Gssct
Jakub Jelen bc4ef0
 /* In the server */
Jakub Jelen bc4ef0
 typedef int ssh_gssapi_check_fn(Gssctxt **, gss_OID, const char *, 
Jakub Jelen bc4ef0
     const char *);
Jakub Jelen bc4ef0
-char *ssh_gssapi_client_mechanisms(const char *, const char *);
Jakub Jelen bc4ef0
+char *ssh_gssapi_client_mechanisms(const char *, const char *, const char *);
Jakub Jelen bc4ef0
 char *ssh_gssapi_kex_mechs(gss_OID_set, ssh_gssapi_check_fn *, const char *,
Jakub Jelen bc4ef0
-    const char *);
Jakub Jelen bc4ef0
+    const char *, const char *);
Jakub Jelen bc4ef0
 gss_OID ssh_gssapi_id_kex(Gssctxt *, char *, int);
Jakub Jelen bc4ef0
 int ssh_gssapi_server_check_mech(Gssctxt **,gss_OID, const char *, 
Jakub Jelen bc4ef0
     const char *);