vishalmishra434 / rpms / openssh

Forked from rpms/openssh 3 months ago
Clone
Tomas Mraz fc87f2
diff -up openssh-5.9p1/auth2-pubkey.c.akc openssh-5.9p1/auth2-pubkey.c
Petr Lautrbach d9e618
--- openssh-5.9p1/auth2-pubkey.c.akc	2012-02-06 20:47:36.641814218 +0100
Petr Lautrbach d9e618
+++ openssh-5.9p1/auth2-pubkey.c	2012-02-06 20:47:36.665095838 +0100
Jan F. Chadima 69dd72
@@ -27,6 +27,7 @@
Jan F. Chadima 69dd72
 
Jan F. Chadima 69dd72
 #include <sys/types.h>
Jan F. Chadima 69dd72
 #include <sys/stat.h>
Jan F. Chadima 69dd72
+#include <sys/wait.h>
Jan F. Chadima 69dd72
 
Jan F. Chadima 69dd72
 #include <fcntl.h>
Jan F. Chadima 69dd72
 #include <pwd.h>
Jan F. Chadima 69dd72
@@ -276,27 +277,15 @@ match_principals_file(char *file, struct
Jan F. Chadima 69dd72
 
Jan F. Chadima 69dd72
 /* return 1 if user allows given key */
Jan F. Chadima 69dd72
 static int
Jan F. Chadima 69dd72
-user_key_allowed2(struct passwd *pw, Key *key, char *file)
Jan F. Chadima 69dd72
+user_search_key_in_file(FILE *f, char *file, Key* key, struct passwd *pw)
Jan F. Chadima 69dd72
 {
Jan F. Chadima 69dd72
 	char line[SSH_MAX_PUBKEY_BYTES];
Jan F. Chadima 69dd72
 	const char *reason;
Jan F. Chadima 69dd72
 	int found_key = 0;
Jan F. Chadima 69dd72
-	FILE *f;
Jan F. Chadima 69dd72
 	u_long linenum = 0;
Jan F. Chadima 69dd72
 	Key *found;
Jan F. Chadima 69dd72
 	char *fp;
Jan F. Chadima 69dd72
 
Jan F. Chadima 69dd72
-	/* Temporarily use the user's uid. */
Jan F. Chadima 69dd72
-	temporarily_use_uid(pw);
Jan F. Chadima 69dd72
-
Jan F. Chadima 69dd72
-	debug("trying public key file %s", file);
Jan F. Chadima 69dd72
-	f = auth_openkeyfile(file, pw, options.strict_modes);
Jan F. Chadima 69dd72
-
Jan F. Chadima 69dd72
-	if (!f) {
Jan F. Chadima 69dd72
-		restore_uid();
Jan F. Chadima 69dd72
-		return 0;
Jan F. Chadima 69dd72
-	}
Jan F. Chadima 69dd72
-
Jan F. Chadima 69dd72
 	found_key = 0;
Jan F. Chadima 69dd72
 	found = key_new(key_is_cert(key) ? KEY_UNSPEC : key->type);
Jan F. Chadima 69dd72
 
Jan F. Chadima 69dd72
@@ -389,8 +378,6 @@ user_key_allowed2(struct passwd *pw, Key
Jan F. Chadima 69dd72
 			break;
Jan F. Chadima 69dd72
 		}
Jan F. Chadima 69dd72
 	}
Jan F. Chadima 69dd72
-	restore_uid();
Jan F. Chadima 69dd72
-	fclose(f);
Jan F. Chadima 69dd72
 	key_free(found);
Jan F. Chadima 69dd72
 	if (!found_key)
Jan F. Chadima 69dd72
 		debug2("key not found");
Jan F. Chadima ea97ff
@@ -452,13 +439,191 @@ user_cert_trusted_ca(struct passwd *pw,
Jan F. Chadima 69dd72
 	return ret;
Jan F. Chadima 69dd72
 }
Jan F. Chadima 69dd72
 
Jan F. Chadima 69dd72
-/* check whether given key is in .ssh/authorized_keys* */
Jan F. Chadima 69dd72
+/* return 1 if user allows given key */
Jan F. Chadima 69dd72
+static int
Jan F. Chadima 69dd72
+user_key_allowed2(struct passwd *pw, Key *key, char *file)
Jan F. Chadima 69dd72
+{
Jan F. Chadima 69dd72
+	FILE *f;
Jan F. Chadima 69dd72
+	int found_key = 0;
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	/* Temporarily use the user's uid. */
Jan F. Chadima 69dd72
+	temporarily_use_uid(pw);
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	debug("trying public key file %s", file);
Jan F. Chadima 69dd72
+	f = auth_openkeyfile(file, pw, options.strict_modes);
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+ 	if (f) {
Jan F. Chadima 69dd72
+ 		found_key = user_search_key_in_file (f, file, key, pw);
Jan F. Chadima 69dd72
+		fclose(f);
Jan F. Chadima 69dd72
+	}
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	restore_uid();
Jan F. Chadima 69dd72
+	return found_key;
Jan F. Chadima 69dd72
+}
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+#ifdef WITH_AUTHORIZED_KEYS_COMMAND
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+#define WHITESPACE " \t\r\n"
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+/* return 1 if user allows given key */
Jan F. Chadima 69dd72
+static int
Jan F. Chadima 69dd72
+user_key_via_command_allowed2(struct passwd *pw, Key *key)
Jan F. Chadima 69dd72
+{
Jan F. Chadima 69dd72
+	FILE *f;
Jan F. Chadima 69dd72
+	int found_key = 0;
Jan F. Chadima 69dd72
+	char *progname = NULL;
Jan F. Chadima 69dd72
+	char *cp;
Jan F. Chadima 69dd72
+	struct passwd *runas_pw;
Jan F. Chadima 69dd72
+	struct stat st;
Jan F. Chadima 69dd72
+	int childdescriptors[2], i;
Jan F. Chadima 69dd72
+	pid_t pstat, pid, child;
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	if (options.authorized_keys_command == NULL || options.authorized_keys_command[0] != '/')
Jan F. Chadima 1df0cf
+		return 0;
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	/* get the run as identity from config */
Jan F. Chadima 69dd72
+	runas_pw = (options.authorized_keys_command_runas == NULL)? pw
Jan F. Chadima 69dd72
+	    : getpwnam (options.authorized_keys_command_runas);
Jan F. Chadima 69dd72
+	if (!runas_pw) {
Jan F. Chadima 69dd72
+		error("%s: getpwnam(\"%s\"): %s", __func__,
Jan F. Chadima 69dd72
+		    options.authorized_keys_command_runas, strerror(errno));
Jan F. Chadima 69dd72
+		return 0;
Jan F. Chadima 69dd72
+	}
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	/* Temporarily use the specified uid. */
Jan F. Chadima 69dd72
+	if (runas_pw->pw_uid != 0)
Jan F. Chadima 69dd72
+		temporarily_use_uid(runas_pw);
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	progname = xstrdup(options.authorized_keys_command);
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	debug3("%s: checking program '%s'", __func__, progname);
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	if (stat (progname, &st) < 0) {
Jan F. Chadima 69dd72
+		error("%s: stat(\"%s\"): %s", __func__,
Jan F. Chadima 69dd72
+		    progname, strerror(errno));
Jan F. Chadima 69dd72
+		goto go_away;
Jan F. Chadima 69dd72
+	}
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	if (st.st_uid != 0 || (st.st_mode & 022) != 0) {
Jan F. Chadima 69dd72
+		error("bad ownership or modes for AuthorizedKeysCommand \"%s\"",
Jan F. Chadima 69dd72
+		    progname);
Jan F. Chadima 69dd72
+		goto go_away;
Jan F. Chadima 69dd72
+	}
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	if (!S_ISREG(st.st_mode)) {
Jan F. Chadima 69dd72
+		error("AuthorizedKeysCommand \"%s\" is not a regular file",
Jan F. Chadima 69dd72
+		    progname);
Jan F. Chadima 69dd72
+		goto go_away;
Jan F. Chadima 69dd72
+	}
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	/*
Jan F. Chadima 69dd72
+	 * Descend the path, checking that each component is a
Jan F. Chadima 69dd72
+	 * root-owned directory with strict permissions.
Jan F. Chadima 69dd72
+	 */
Jan F. Chadima 69dd72
+	do {
Jan F. Chadima 69dd72
+		if ((cp = strrchr(progname, '/')) == NULL)
Jan F. Chadima 69dd72
+			break;
Petr Lautrbach d9e618
+		else
Jan F. Chadima 69dd72
+			*cp = '\0';
Jan F. Chadima 69dd72
+	
Jan F. Chadima 69dd72
+		debug3("%s: checking component '%s'", __func__, (*progname == '\0' ? "/" : progname));
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+		if (stat((*progname == '\0' ? "/" : progname), &st) != 0) {
Jan F. Chadima 69dd72
+			error("%s: stat(\"%s\"): %s", __func__,
Jan F. Chadima 69dd72
+			    progname, strerror(errno));
Jan F. Chadima 69dd72
+			goto go_away;
Jan F. Chadima 69dd72
+		}
Jan F. Chadima 69dd72
+		if (st.st_uid != 0 || (st.st_mode & 022) != 0) {
Jan F. Chadima 69dd72
+			error("bad ownership or modes for AuthorizedKeysCommand path component \"%s\"",
Jan F. Chadima 69dd72
+			    progname);
Jan F. Chadima 69dd72
+			goto go_away;
Jan F. Chadima 69dd72
+		}
Jan F. Chadima 69dd72
+		if (!S_ISDIR(st.st_mode)) {
Jan F. Chadima 69dd72
+			error("AuthorizedKeysCommand path component \"%s\" is not a directory",
Jan F. Chadima 69dd72
+			    progname);
Jan F. Chadima 69dd72
+			goto go_away;
Jan F. Chadima 69dd72
+		}
Jan F. Chadima 69dd72
+	} while (1);
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	/* open the pipe and read the keys */
Jan F. Chadima 69dd72
+	if (pipe(childdescriptors)) {
Jan F. Chadima 69dd72
+		error("failed to pipe(2) for AuthorizedKeysCommand: %s",
Jan F. Chadima 69dd72
+		    strerror(errno));
Jan F. Chadima 69dd72
+		goto go_away;
Jan F. Chadima 69dd72
+	}
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	child = fork();
Jan F. Chadima 69dd72
+	if (child == -1) {
Jan F. Chadima 69dd72
+		error("failed to fork(2) for AuthorizedKeysCommand: %s",
Jan F. Chadima 69dd72
+		    strerror(errno));
Jan F. Chadima 69dd72
+		goto go_away;
Jan F. Chadima 69dd72
+	} else if (child == 0) {
Jan F. Chadima 69dd72
+		/* we're in the child process here -- we should never return from this block. */
Jan F. Chadima 69dd72
+		/* permanently drop privs in child process */
Jan F. Chadima 69dd72
+		if (runas_pw->pw_uid != 0) {
Jan F. Chadima 69dd72
+			restore_uid();
Jan F. Chadima 69dd72
+			permanently_set_uid(runas_pw);
Jan F. Chadima 69dd72
+	  	}
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+		close(childdescriptors[0]);
Jan F. Chadima 69dd72
+		/* put the write end of the pipe on stdout (FD 1) */
Jan F. Chadima 69dd72
+		if (dup2(childdescriptors[1], 1) == -1) {
Jan F. Chadima 69dd72
+			error("failed to dup2(2) from AuthorizedKeysCommand: %s",
Jan F. Chadima 69dd72
+			    strerror(errno));
Jan F. Chadima 69dd72
+			_exit(127);
Jan F. Chadima 69dd72
+		}
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+		debug3("about to execl() AuthorizedKeysCommand: \"%s\" \"%s\"", options.authorized_keys_command, pw->pw_name);
Jan F. Chadima 69dd72
+		/* see session.c:child_close_fds() */
Jan F. Chadima 69dd72
+		for (i = 3; i < 64; ++i) {
Jan F. Chadima 69dd72
+			close(i);
Jan F. Chadima 69dd72
+		}
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+		execl(options.authorized_keys_command, options.authorized_keys_command, pw->pw_name, NULL);
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+		/* if we got here, it didn't work */
Jan F. Chadima 69dd72
+		error("failed to execl AuthorizedKeysCommand: %s", strerror(errno)); /* this won't work because we closed the fds above */
Jan F. Chadima 69dd72
+		_exit(127);
Jan F. Chadima 69dd72
+	}
Jan F. Chadima 69dd72
+	
Jan F. Chadima 69dd72
+	close(childdescriptors[1]);
Jan F. Chadima 69dd72
+	f = fdopen(childdescriptors[0], "r");
Jan F. Chadima 69dd72
+	if (!f) {
Jan F. Chadima 69dd72
+		error("%s: could not buffer FDs from AuthorizedKeysCommand (\"%s\", \"r\"): %s", __func__,
Jan F. Chadima 69dd72
+		    options.authorized_keys_command, strerror (errno));
Jan F. Chadima 69dd72
+		goto go_away;
Jan F. Chadima 69dd72
+	}
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	found_key = user_search_key_in_file (f, options.authorized_keys_command, key, pw);
Jan F. Chadima 69dd72
+	fclose (f);
Jan F. Chadima 69dd72
+	do {
Jan F. Chadima 69dd72
+		pid = waitpid(child, &pstat, 0);
Jan F. Chadima 69dd72
+	} while (pid == -1 && errno == EINTR);
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	/* what about the return value from the child process? */
Jan F. Chadima 69dd72
+go_away:
Jan F. Chadima 69dd72
+	if (progname)
Jan F. Chadima 69dd72
+		xfree (progname);
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	if (runas_pw->pw_uid != 0)
Jan F. Chadima 69dd72
+		restore_uid();
Jan F. Chadima 69dd72
+	return found_key;
Jan F. Chadima 69dd72
+}
Jan F. Chadima 69dd72
+#endif
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+/* check whether given key is in 
Jan F. Chadima 69dd72
 int
Jan F. Chadima 69dd72
 user_key_allowed(struct passwd *pw, Key *key)
Jan F. Chadima 69dd72
 {
Tomas Mraz fc87f2
 	u_int success, i;
Tomas Mraz fc87f2
 	char *file;
Tomas Mraz fc87f2
 
Tomas Mraz fc87f2
+#ifdef WITH_AUTHORIZED_KEYS_COMMAND
Tomas Mraz fc87f2
+	success = user_key_via_command_allowed2(pw, key);
Tomas Mraz fc87f2
+	if (success > 0)
Tomas Mraz fc87f2
+		return success;
Tomas Mraz fc87f2
+#endif
Tomas Mraz fc87f2
+
Tomas Mraz fc87f2
 	if (auth_key_is_revoked(key))
Tomas Mraz fc87f2
 		return 0;
Tomas Mraz fc87f2
 	if (key_is_cert(key) && auth_key_is_revoked(key->cert->signature_key))
Tomas Mraz fc87f2
diff -up openssh-5.9p1/configure.ac.akc openssh-5.9p1/configure.ac
Petr Lautrbach d9e618
--- openssh-5.9p1/configure.ac.akc	2012-02-06 20:47:36.656046570 +0100
Petr Lautrbach d9e618
+++ openssh-5.9p1/configure.ac	2012-02-06 20:47:36.666095176 +0100
Jan F. Chadima 69dd72
@@ -1421,6 +1421,18 @@ AC_ARG_WITH([audit],
Jan F. Chadima 69dd72
 	esac ]
Jan F. Chadima 69dd72
 )
Jan F. Chadima 69dd72
 
Jan F. Chadima 69dd72
+# Check whether user wants AuthorizedKeysCommand support
Jan F. Chadima 69dd72
+AKC_MSG="no"
Jan F. Chadima 69dd72
+AC_ARG_WITH(authorized-keys-command,
Jan F. Chadima 69dd72
+	[  --with-authorized-keys-command      Enable AuthorizedKeysCommand support],
Jan F. Chadima 69dd72
+	[
Jan F. Chadima 69dd72
+		if test "x$withval" != "xno" ; then
Jan F. Chadima 69dd72
+			AC_DEFINE([WITH_AUTHORIZED_KEYS_COMMAND], 1, [Enable AuthorizedKeysCommand support])
Jan F. Chadima 69dd72
+			AKC_MSG="yes"
Jan F. Chadima 69dd72
+		fi
Jan F. Chadima 69dd72
+	]
Jan F. Chadima 69dd72
+)
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
 dnl    Checks for library functions. Please keep in alphabetical order
Jan F. Chadima 69dd72
 AC_CHECK_FUNCS([ \
Jan F. Chadima 69dd72
 	arc4random \
Jan F. Chadima cff1d0
@@ -4239,6 +4251,7 @@ echo "                   SELinux support
Jan F. Chadima 69dd72
 echo "                 Smartcard support: $SCARD_MSG"
Jan F. Chadima 69dd72
 echo "                     S/KEY support: $SKEY_MSG"
Jan F. Chadima 69dd72
 echo "              TCP Wrappers support: $TCPW_MSG"
Jan F. Chadima 69dd72
+echo "     AuthorizedKeysCommand support: $AKC_MSG"
Jan F. Chadima 69dd72
 echo "              MD5 password support: $MD5_MSG"
Jan F. Chadima 69dd72
 echo "                   libedit support: $LIBEDIT_MSG"
Jan F. Chadima 69dd72
 echo "  Solaris process contract support: $SPC_MSG"
Tomas Mraz fc87f2
diff -up openssh-5.9p1/servconf.c.akc openssh-5.9p1/servconf.c
Petr Lautrbach d9e618
--- openssh-5.9p1/servconf.c.akc	2012-02-06 20:47:36.573033521 +0100
Petr Lautrbach d9e618
+++ openssh-5.9p1/servconf.c	2012-02-06 20:47:36.667106367 +0100
Petr Lautrbach d9e618
@@ -136,6 +136,8 @@ initialize_server_options(ServerOptions
Jan F. Chadima 69dd72
 	options->num_permitted_opens = -1;
Jan F. Chadima 69dd72
 	options->adm_forced_command = NULL;
Jan F. Chadima 69dd72
 	options->chroot_directory = NULL;
Jan F. Chadima 69dd72
+	options->authorized_keys_command = NULL;
Jan F. Chadima 69dd72
+	options->authorized_keys_command_runas = NULL;
Jan F. Chadima 69dd72
 	options->zero_knowledge_password_authentication = -1;
Jan F. Chadima 69dd72
 	options->revoked_keys_file = NULL;
Jan F. Chadima 69dd72
 	options->trusted_user_ca_keys = NULL;
Petr Lautrbach d9e618
@@ -329,6 +331,7 @@ typedef enum {
Jan F. Chadima 69dd72
 	sZeroKnowledgePasswordAuthentication, sHostCertificate,
Jan F. Chadima 69dd72
 	sRevokedKeys, sTrustedUserCAKeys, sAuthorizedPrincipalsFile,
Jan F. Chadima 69dd72
 	sKexAlgorithms, sIPQoS,
Jan F. Chadima 69dd72
+	sAuthorizedKeysCommand, sAuthorizedKeysCommandRunAs,
Jan F. Chadima 69dd72
 	sDeprecated, sUnsupported
Jan F. Chadima 69dd72
 } ServerOpCodes;
Jan F. Chadima 69dd72
 
Petr Lautrbach d9e618
@@ -455,6 +458,13 @@ static struct {
Petr Lautrbach d9e618
 	{ "requiredauthentications1", sRequiredAuthentications1, SSHCFG_ALL },
Petr Lautrbach d9e618
 	{ "requiredauthentications2", sRequiredAuthentications2, SSHCFG_ALL },
Jan F. Chadima 69dd72
 	{ "ipqos", sIPQoS, SSHCFG_ALL },
Jan F. Chadima 69dd72
+#ifdef WITH_AUTHORIZED_KEYS_COMMAND
Jan F. Chadima 69dd72
+	{ "authorizedkeyscommand", sAuthorizedKeysCommand, SSHCFG_ALL },
Jan F. Chadima 69dd72
+	{ "authorizedkeyscommandrunas", sAuthorizedKeysCommandRunAs, SSHCFG_ALL },
Jan F. Chadima 69dd72
+#else
Jan F. Chadima 69dd72
+	{ "authorizedkeyscommand", sUnsupported, SSHCFG_ALL },
Jan F. Chadima 69dd72
+	{ "authorizedkeyscommandrunas", sUnsupported, SSHCFG_ALL },
Jan F. Chadima 69dd72
+#endif
Jan F. Chadima 69dd72
 	{ NULL, sBadOption, 0 }
Jan F. Chadima 69dd72
 };
Jan F. Chadima 69dd72
 
Petr Lautrbach d9e618
@@ -1430,6 +1440,24 @@ process_server_config_line(ServerOptions
Jan F. Chadima 69dd72
 		}
Jan F. Chadima 69dd72
 		break;
Jan F. Chadima 69dd72
 
Jan F. Chadima 69dd72
+	case sAuthorizedKeysCommand:
Jan F. Chadima 69dd72
+		len = strspn(cp, WHITESPACE);
Jan F. Chadima 69dd72
+		if (*activep && options->authorized_keys_command == NULL)
Jan F. Chadima 69dd72
+			options->authorized_keys_command = xstrdup(cp + len);
Jan F. Chadima 69dd72
+		return 0;
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+	case sAuthorizedKeysCommandRunAs:
Jan F. Chadima 69dd72
+		charptr = &options->authorized_keys_command_runas;
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+		arg = strdelim(&cp;;
Jan F. Chadima cff1d0
+		if (!arg || *arg == '\0')
Jan F. Chadima cff1d0
+			fatal("%s line %d: missing account.",
Jan F. Chadima cff1d0
+			    filename, linenum);
Jan F. Chadima cff1d0
+
Jan F. Chadima 69dd72
+		if (*activep && *charptr == NULL)
Jan F. Chadima 69dd72
+			*charptr = xstrdup(arg);
Jan F. Chadima 69dd72
+		break;
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
 	case sDeprecated:
Jan F. Chadima 69dd72
 		logit("%s line %d: Deprecated option %s",
Jan F. Chadima 69dd72
 		    filename, linenum, arg);
Petr Lautrbach d9e618
@@ -1534,6 +1562,8 @@ copy_set_server_options(ServerOptions *d
Petr Lautrbach d9e618
 	M_CP_INTOPT(hostbased_uses_name_from_packet_only);
Petr Lautrbach d9e618
 	M_CP_INTOPT(kbd_interactive_authentication);
Jan F. Chadima 69dd72
 	M_CP_INTOPT(zero_knowledge_password_authentication);
Jan F. Chadima 69dd72
+	M_CP_STROPT(authorized_keys_command);
Jan F. Chadima 69dd72
+	M_CP_STROPT(authorized_keys_command_runas);
Jan F. Chadima 69dd72
 	M_CP_INTOPT(permit_root_login);
Jan F. Chadima 69dd72
 	M_CP_INTOPT(permit_empty_passwd);
Jan F. Chadima 69dd72
 
Petr Lautrbach d9e618
@@ -1793,6 +1823,8 @@ dump_config(ServerOptions *o)
Jan F. Chadima 69dd72
 	dump_cfg_string(sRevokedKeys, o->revoked_keys_file);
Jan F. Chadima 69dd72
 	dump_cfg_string(sAuthorizedPrincipalsFile,
Jan F. Chadima 69dd72
 	    o->authorized_principals_file);
Jan F. Chadima 69dd72
+	dump_cfg_string(sAuthorizedKeysCommand, o->authorized_keys_command);
Jan F. Chadima 69dd72
+	dump_cfg_string(sAuthorizedKeysCommandRunAs, o->authorized_keys_command_runas);
Jan F. Chadima 69dd72
 
Jan F. Chadima 69dd72
 	/* string arguments requiring a lookup */
Jan F. Chadima 69dd72
 	dump_cfg_string(sLogLevel, log_level_name(o->log_level));
Tomas Mraz fc87f2
diff -up openssh-5.9p1/servconf.h.akc openssh-5.9p1/servconf.h
Petr Lautrbach d9e618
--- openssh-5.9p1/servconf.h.akc	2012-02-06 20:47:36.574033734 +0100
Petr Lautrbach d9e618
+++ openssh-5.9p1/servconf.h	2012-02-06 20:47:36.668096740 +0100
Petr Lautrbach d9e618
@@ -169,6 +169,8 @@ typedef struct {
Jan F. Chadima 69dd72
 	char   *revoked_keys_file;
Jan F. Chadima 69dd72
 	char   *trusted_user_ca_keys;
Jan F. Chadima 69dd72
 	char   *authorized_principals_file;
Jan F. Chadima 69dd72
+	char   *authorized_keys_command;
Jan F. Chadima 69dd72
+	char   *authorized_keys_command_runas;
Jan F. Chadima 69dd72
 }       ServerOptions;
Jan F. Chadima 69dd72
 
Jan F. Chadima 69dd72
 /*
Petr Lautrbach d9e618
diff -up openssh-5.9p1/sshd_config.akc openssh-5.9p1/sshd_config
Petr Lautrbach d9e618
--- openssh-5.9p1/sshd_config.akc	2011-05-29 13:39:39.000000000 +0200
Petr Lautrbach d9e618
+++ openssh-5.9p1/sshd_config	2012-02-06 20:47:36.669067546 +0100
Petr Lautrbach d9e618
@@ -49,6 +49,9 @@
Petr Lautrbach d9e618
 # but this is overridden so installations will only check .ssh/authorized_keys
Petr Lautrbach d9e618
 AuthorizedKeysFile	.ssh/authorized_keys
Petr Lautrbach d9e618
 
Petr Lautrbach d9e618
+#AuthorizedKeysCommand none
Petr Lautrbach d9e618
+#AuthorizedKeysCommandRunAs nobody
Petr Lautrbach d9e618
+
Petr Lautrbach d9e618
 # For this to work you will also need host keys in /etc/ssh/ssh_known_hosts
Petr Lautrbach d9e618
 #RhostsRSAAuthentication no
Petr Lautrbach d9e618
 # similar for protocol version 2
Tomas Mraz fc87f2
diff -up openssh-5.9p1/sshd_config.0.akc openssh-5.9p1/sshd_config.0
Tomas Mraz fc87f2
--- openssh-5.9p1/sshd_config.0.akc	2011-09-07 01:16:30.000000000 +0200
Petr Lautrbach d9e618
+++ openssh-5.9p1/sshd_config.0	2012-02-06 20:47:36.669067546 +0100
Jan F. Chadima 69dd72
@@ -71,6 +71,23 @@ DESCRIPTION
Jan F. Chadima 69dd72
 
Jan F. Chadima 69dd72
              See PATTERNS in ssh_config(5) for more information on patterns.
Jan F. Chadima 69dd72
 
Jan F. Chadima 69dd72
+     AuthorizedKeysCommand
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+             Specifies a program to be used for lookup of the user's
Jan F. Chadima 69dd72
+	     public keys.  The program will be invoked with its first
Petr Lautrbach d9e618
+	     argument the name of the user being authorized, and should produce
Petr Lautrbach d9e618
+	     on standard output AuthorizedKeys lines (see AUTHORIZED_KEYS
Jan F. Chadima 69dd72
+	     in sshd(8)).  By default (or when set to the empty string) there is no
Jan F. Chadima 69dd72
+	     AuthorizedKeysCommand run.  If the AuthorizedKeysCommand does not successfully
Jan F. Chadima 69dd72
+	     authorize the user, authorization falls through to the
Jan F. Chadima 69dd72
+	     AuthorizedKeysFile.  Note that this option has an effect
Jan F. Chadima 69dd72
+	     only with PubkeyAuthentication turned on.
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
+     AuthorizedKeysCommandRunAs
Jan F. Chadima 69dd72
+             Specifies the user under whose account the AuthorizedKeysCommand is run.
Jan F. Chadima 69dd72
+             Empty string (the default value) means the user being authorized
Jan F. Chadima 69dd72
+             is used.
Jan F. Chadima 69dd72
+
Jan F. Chadima 69dd72
      AuthorizedKeysFile
Jan F. Chadima 69dd72
              Specifies the file that contains the public keys that can be used
Jan F. Chadima 69dd72
              for user authentication.  The format is described in the
Jan F. Chadima 69dd72
@@ -401,7 +418,8 @@ DESCRIPTION
Jan F. Chadima 69dd72
 
Jan F. Chadima 69dd72
              Only a subset of keywords may be used on the lines following a
Jan F. Chadima 69dd72
              Match keyword.  Available keywords are AllowAgentForwarding,
Jan F. Chadima 69dd72
-             AllowTcpForwarding, AuthorizedKeysFile, AuthorizedPrincipalsFile,
Jan F. Chadima 69dd72
+             AllowTcpForwarding, AuthorizedKeysFile, AuthorizedKeysCommand,
Jan F. Chadima 69dd72
+             AuthorizedKeysCommandRunAs, AuthorizedPrincipalsFile,
Jan F. Chadima 69dd72
              Banner, ChrootDirectory, ForceCommand, GatewayPorts,
Jan F. Chadima 69dd72
              GSSAPIAuthentication, HostbasedAuthentication,
Jan F. Chadima 69dd72
              HostbasedUsesNameFromPacketOnly, KbdInteractiveAuthentication,
Tomas Mraz fc87f2
diff -up openssh-5.9p1/sshd_config.5.akc openssh-5.9p1/sshd_config.5
Petr Lautrbach d9e618
--- openssh-5.9p1/sshd_config.5.akc	2012-02-06 20:47:36.574891218 +0100
Petr Lautrbach d9e618
+++ openssh-5.9p1/sshd_config.5	2012-02-06 20:49:58.913878595 +0100
Petr Lautrbach d9e618
@@ -151,6 +151,19 @@ See
Petr Lautrbach d9e618
 in
Petr Lautrbach d9e618
 .Xr ssh_config 5
Petr Lautrbach d9e618
 for more information on patterns.
Petr Lautrbach d9e618
+.It Cm AuthorizedKeysCommand
Petr Lautrbach d9e618
+Specifies a program to be used for lookup of the user's
Petr Lautrbach d9e618
+public keys.  The program will be invoked with its first
Petr Lautrbach d9e618
+argument the name of the user being authorized, and should produce
Petr Lautrbach d9e618
+on standard output AuthorizedKeys lines (see AUTHORIZED_KEYS
Petr Lautrbach d9e618
+in sshd(8)).  By default (or when set to the empty string) there is no
Petr Lautrbach d9e618
+AuthorizedKeysCommand run.  If the AuthorizedKeysCommand does not successfully
Petr Lautrbach d9e618
+authorize the user, authorization falls through to the
Petr Lautrbach d9e618
+AuthorizedKeysFile.  Note that this option has an effect
Petr Lautrbach d9e618
+only with PubkeyAuthentication turned on.
Petr Lautrbach d9e618
+.It Cm AuthorizedKeysCommandRunAs
Petr Lautrbach d9e618
+Specifies the user under whose account the AuthorizedKeysCommand is run. Empty
Petr Lautrbach d9e618
+string (the default value) means the user being authorized is used.
Petr Lautrbach d9e618
 .It Cm AuthorizedKeysFile
Petr Lautrbach d9e618
 Specifies the file that contains the public keys that can be used
Petr Lautrbach d9e618
 for user authentication.
Petr Lautrbach d9e618
@@ -706,6 +719,8 @@ Available keywords are
Jan F. Chadima 69dd72
 .Cm AllowAgentForwarding ,
Jan F. Chadima 69dd72
 .Cm AllowTcpForwarding ,
Jan F. Chadima 69dd72
 .Cm AuthorizedKeysFile ,
Jan F. Chadima 69dd72
+.Cm AuthorizedKeysCommand ,
Jan F. Chadima 69dd72
+.Cm AuthorizedKeysCommandRunAs ,
Jan F. Chadima 69dd72
 .Cm AuthorizedPrincipalsFile ,
Jan F. Chadima 69dd72
 .Cm Banner ,
Jan F. Chadima 69dd72
 .Cm ChrootDirectory ,
Petr Lautrbach d9e618
@@ -718,6 +733,7 @@ Available keywords are
Jan F. Chadima 69dd72
 .Cm KerberosAuthentication ,
Jan F. Chadima 69dd72
 .Cm MaxAuthTries ,
Jan F. Chadima 69dd72
 .Cm MaxSessions ,
Jan F. Chadima 69dd72
+.Cm PubkeyAuthentication ,
Jan F. Chadima 69dd72
 .Cm PasswordAuthentication ,
Jan F. Chadima 69dd72
 .Cm PermitEmptyPasswords ,
Jan F. Chadima 69dd72
 .Cm PermitOpen ,