diff options
author | djm@openbsd.org <djm@openbsd.org> | 2019-09-03 10:30:47 +0200 |
---|---|---|
committer | Damien Miller <djm@mindrot.org> | 2019-09-03 10:39:31 +0200 |
commit | dd8002fbe63d903ffea5be7b7f5fc2714acab4a0 (patch) | |
tree | ac6cf10455cbf734c7d257288ab265e6113f2e42 /auth2-pubkey.c | |
parent | upstream: move skip_space() to misc.c and make it public; ok (diff) | |
download | openssh-dd8002fbe63d903ffea5be7b7f5fc2714acab4a0.tar.xz openssh-dd8002fbe63d903ffea5be7b7f5fc2714acab4a0.zip |
upstream: move advance_past_options to authfile.c and make it
public; ok markus@
OpenBSD-Commit-ID: edda2fbba2c5b1f48e60f857a2010479e80c5f3c
Diffstat (limited to 'auth2-pubkey.c')
-rw-r--r-- | auth2-pubkey.c | 26 |
1 files changed, 2 insertions, 24 deletions
diff --git a/auth2-pubkey.c b/auth2-pubkey.c index 65db116ed..d567f527c 100644 --- a/auth2-pubkey.c +++ b/auth2-pubkey.c @@ -1,4 +1,4 @@ -/* $OpenBSD: auth2-pubkey.c,v 1.92 2019/09/03 08:29:58 djm Exp $ */ +/* $OpenBSD: auth2-pubkey.c,v 1.93 2019/09/03 08:30:47 djm Exp $ */ /* * Copyright (c) 2000 Markus Friedl. All rights reserved. * @@ -539,28 +539,6 @@ match_principals_command(struct ssh *ssh, struct passwd *user_pw, } /* - * Advanced *cpp past the end of key options, defined as the first unquoted - * whitespace character. Returns 0 on success or -1 on failure (e.g. - * unterminated quotes). - */ -static int -advance_past_options(char **cpp) -{ - char *cp = *cpp; - int quoted = 0; - - for (; *cp && (quoted || (*cp != ' ' && *cp != '\t')); cp++) { - if (*cp == '\\' && cp[1] == '"') - cp++; /* Skip both */ - else if (*cp == '"') - quoted = !quoted; - } - *cpp = cp; - /* return failure for unterminated quotes */ - return (*cp == '\0' && quoted) ? -1 : 0; -} - -/* * Check a single line of an authorized_keys-format file. Returns 0 if key * matches, -1 otherwise. Will return key/cert options via *authoptsp * on success. "loc" is used as file/line location in log messages. @@ -590,7 +568,7 @@ check_authkey_line(struct ssh *ssh, struct passwd *pw, struct sshkey *key, /* no key? check for options */ debug2("%s: check options: '%s'", loc, cp); key_options = cp; - if (advance_past_options(&cp) != 0) { + if (sshkey_advance_past_options(&cp) != 0) { reason = "invalid key option string"; goto fail_reason; } |