Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/crypto/external/bsd/openssh/lib merge openssh-8.1



details:   https://anonhg.NetBSD.org/src/rev/454b05e1e6be
branches:  trunk
changeset: 966061:454b05e1e6be
user:      christos <christos%NetBSD.org@localhost>
date:      Sat Oct 12 18:32:21 2019 +0000

description:
merge openssh-8.1

diffstat:

 crypto/external/bsd/openssh/bin/sftp-server/Makefile    |    4 +-
 crypto/external/bsd/openssh/bin/ssh-keygen/Makefile     |    4 +-
 crypto/external/bsd/openssh/bin/sshd/Makefile           |    4 +-
 crypto/external/bsd/openssh/dist/auth-options.c         |   81 +-
 crypto/external/bsd/openssh/dist/auth-options.h         |    7 +-
 crypto/external/bsd/openssh/dist/auth-rhosts.c          |   16 +-
 crypto/external/bsd/openssh/dist/auth.c                 |   22 +-
 crypto/external/bsd/openssh/dist/auth.h                 |    4 +-
 crypto/external/bsd/openssh/dist/auth2-chall.c          |    8 +-
 crypto/external/bsd/openssh/dist/auth2-hostbased.c      |    7 +-
 crypto/external/bsd/openssh/dist/auth2-kbdint.c         |   10 +-
 crypto/external/bsd/openssh/dist/auth2-passwd.c         |    9 +-
 crypto/external/bsd/openssh/dist/auth2-pubkey.c         |   76 +-
 crypto/external/bsd/openssh/dist/auth2.c                |   10 +-
 crypto/external/bsd/openssh/dist/authfd.c               |   40 +-
 crypto/external/bsd/openssh/dist/authfd.h               |    7 +-
 crypto/external/bsd/openssh/dist/authfile.c             |   62 +-
 crypto/external/bsd/openssh/dist/authfile.h             |    9 +-
 crypto/external/bsd/openssh/dist/canohost.c             |   10 +-
 crypto/external/bsd/openssh/dist/channels.c             |  105 +-
 crypto/external/bsd/openssh/dist/cipher.c               |    9 +-
 crypto/external/bsd/openssh/dist/cipher.h               |    6 +-
 crypto/external/bsd/openssh/dist/clientloop.c           |   23 +-
 crypto/external/bsd/openssh/dist/crc32.c                |  109 --
 crypto/external/bsd/openssh/dist/crc32.h                |   31 -
 crypto/external/bsd/openssh/dist/dh.c                   |   13 +-
 crypto/external/bsd/openssh/dist/dh.h                   |    9 +-
 crypto/external/bsd/openssh/dist/hmac.c                 |    5 +-
 crypto/external/bsd/openssh/dist/hostfile.c             |   14 +-
 crypto/external/bsd/openssh/dist/kex.c                  |  109 ++-
 crypto/external/bsd/openssh/dist/kex.h                  |   18 +-
 crypto/external/bsd/openssh/dist/kexgen.c               |   10 +-
 crypto/external/bsd/openssh/dist/krl.c                  |    9 +-
 crypto/external/bsd/openssh/dist/krl.h                  |    6 +-
 crypto/external/bsd/openssh/dist/log.h                  |    6 +-
 crypto/external/bsd/openssh/dist/mac.c                  |    8 +-
 crypto/external/bsd/openssh/dist/match.c                |    8 +-
 crypto/external/bsd/openssh/dist/misc.c                 |  143 +++-
 crypto/external/bsd/openssh/dist/misc.h                 |   10 +-
 crypto/external/bsd/openssh/dist/moduli-gen/moduli.2048 |  158 ++-
 crypto/external/bsd/openssh/dist/moduli-gen/moduli.3072 |  150 ++--
 crypto/external/bsd/openssh/dist/moduli-gen/moduli.4096 |  146 +-
 crypto/external/bsd/openssh/dist/moduli-gen/moduli.6144 |  138 +-
 crypto/external/bsd/openssh/dist/moduli-gen/moduli.7680 |  146 +-
 crypto/external/bsd/openssh/dist/moduli-gen/moduli.8192 |  134 +-
 crypto/external/bsd/openssh/dist/moduli.c               |   10 +-
 crypto/external/bsd/openssh/dist/monitor.c              |   16 +-
 crypto/external/bsd/openssh/dist/monitor_wrap.c         |    8 +-
 crypto/external/bsd/openssh/dist/monitor_wrap.h         |    6 +-
 crypto/external/bsd/openssh/dist/mux.c                  |   12 +-
 crypto/external/bsd/openssh/dist/nchan.c                |   10 +-
 crypto/external/bsd/openssh/dist/packet.c               |   21 +-
 crypto/external/bsd/openssh/dist/packet.h               |   16 +-
 crypto/external/bsd/openssh/dist/progressmeter.c        |   10 +-
 crypto/external/bsd/openssh/dist/readconf.c             |   37 +-
 crypto/external/bsd/openssh/dist/readpass.c             |   14 +-
 crypto/external/bsd/openssh/dist/scp.1                  |    8 +-
 crypto/external/bsd/openssh/dist/scp.c                  |   30 +-
 crypto/external/bsd/openssh/dist/servconf.c             |   34 +-
 crypto/external/bsd/openssh/dist/servconf.h             |    6 +-
 crypto/external/bsd/openssh/dist/serverloop.c           |   12 +-
 crypto/external/bsd/openssh/dist/session.c              |   52 +-
 crypto/external/bsd/openssh/dist/sftp-client.c          |   16 +-
 crypto/external/bsd/openssh/dist/sftp-glob.c            |    7 +-
 crypto/external/bsd/openssh/dist/sftp-server-main.c     |    8 +-
 crypto/external/bsd/openssh/dist/sftp-server.c          |   33 +-
 crypto/external/bsd/openssh/dist/sftp.1                 |   46 +-
 crypto/external/bsd/openssh/dist/sftp.c                 |   33 +-
 crypto/external/bsd/openssh/dist/ssh-add.c              |   16 +-
 crypto/external/bsd/openssh/dist/ssh-agent.c            |   25 +-
 crypto/external/bsd/openssh/dist/ssh-keygen.1           |  196 ++++-
 crypto/external/bsd/openssh/dist/ssh-keygen.c           |  600 +++++++++++++--
 crypto/external/bsd/openssh/dist/ssh-keyscan.c          |   26 +-
 crypto/external/bsd/openssh/dist/ssh-keysign.c          |   17 +-
 crypto/external/bsd/openssh/dist/ssh-pkcs11-helper.c    |   29 +-
 crypto/external/bsd/openssh/dist/ssh-pkcs11.c           |   79 +-
 crypto/external/bsd/openssh/dist/ssh.1                  |    8 +-
 crypto/external/bsd/openssh/dist/ssh.c                  |   41 +-
 crypto/external/bsd/openssh/dist/ssh_api.c              |   50 +-
 crypto/external/bsd/openssh/dist/ssh_config.5           |   86 +-
 crypto/external/bsd/openssh/dist/sshbuf-getput-basic.c  |  166 ++++-
 crypto/external/bsd/openssh/dist/sshbuf-misc.c          |   98 ++-
 crypto/external/bsd/openssh/dist/sshbuf.h               |   64 +-
 crypto/external/bsd/openssh/dist/sshconnect.c           |   70 +-
 crypto/external/bsd/openssh/dist/sshconnect.h           |   11 +-
 crypto/external/bsd/openssh/dist/sshconnect2.c          |   49 +-
 crypto/external/bsd/openssh/dist/sshd.c                 |   44 +-
 crypto/external/bsd/openssh/dist/sshd_config.5          |   56 +-
 crypto/external/bsd/openssh/dist/sshkey-xmss.c          |   34 +-
 crypto/external/bsd/openssh/dist/sshkey.c               |  455 ++++++++++-
 crypto/external/bsd/openssh/dist/sshkey.h               |   33 +-
 crypto/external/bsd/openssh/dist/sshlogin.c             |    9 +-
 crypto/external/bsd/openssh/dist/sshpty.c               |   29 +-
 crypto/external/bsd/openssh/dist/sshsig.c               |    8 +-
 crypto/external/bsd/openssh/dist/uidswap.c              |   23 +-
 crypto/external/bsd/openssh/dist/umac.h                 |    8 +-
 crypto/external/bsd/openssh/dist/uuencode.c             |   96 --
 crypto/external/bsd/openssh/dist/uuencode.h             |   30 -
 crypto/external/bsd/openssh/dist/version.h              |    8 +-
 crypto/external/bsd/openssh/dist/xmalloc.c              |   14 +-
 crypto/external/bsd/openssh/dist/xmalloc.h              |    5 +-
 crypto/external/bsd/openssh/lib/Makefile                |    4 +-
 crypto/external/bsd/openssh/lib/shlib_version           |    4 +-
 103 files changed, 3034 insertions(+), 1815 deletions(-)

diffs (truncated from 10153 to 300 lines):

diff -r efcb2bec0c0b -r 454b05e1e6be crypto/external/bsd/openssh/bin/sftp-server/Makefile
--- a/crypto/external/bsd/openssh/bin/sftp-server/Makefile      Sat Oct 12 17:50:56 2019 +0000
+++ b/crypto/external/bsd/openssh/bin/sftp-server/Makefile      Sat Oct 12 18:32:21 2019 +0000
@@ -1,9 +1,9 @@
-#      $NetBSD: Makefile,v 1.1 2009/06/07 22:38:45 christos Exp $
+#      $NetBSD: Makefile,v 1.2 2019/10/12 18:32:21 christos Exp $
 
 BINDIR=        /usr/libexec
 
 PROG=  sftp-server
-SRCS=  sftp-server.c sftp-common.c sftp-server-main.c
+SRCS=  sftp-server.c sftp-common.c sftp-server-main.c sftp-realpath.c
 MAN=   sftp-server.8
 
 .include <bsd.prog.mk>
diff -r efcb2bec0c0b -r 454b05e1e6be crypto/external/bsd/openssh/bin/ssh-keygen/Makefile
--- a/crypto/external/bsd/openssh/bin/ssh-keygen/Makefile       Sat Oct 12 17:50:56 2019 +0000
+++ b/crypto/external/bsd/openssh/bin/ssh-keygen/Makefile       Sat Oct 12 18:32:21 2019 +0000
@@ -1,9 +1,9 @@
-#      $NetBSD: Makefile,v 1.4 2012/08/10 12:20:12 joerg Exp $
+#      $NetBSD: Makefile,v 1.5 2019/10/12 18:32:21 christos Exp $
 
 BINDIR=        /usr/bin
 
 PROG=  ssh-keygen
-SRCS=  ssh-keygen.c moduli.c
+SRCS=  ssh-keygen.c moduli.c sshsig.c
 
 COPTS.ssh-keygen.c=    -Wno-pointer-sign
 
diff -r efcb2bec0c0b -r 454b05e1e6be crypto/external/bsd/openssh/bin/sshd/Makefile
--- a/crypto/external/bsd/openssh/bin/sshd/Makefile     Sat Oct 12 17:50:56 2019 +0000
+++ b/crypto/external/bsd/openssh/bin/sshd/Makefile     Sat Oct 12 18:32:21 2019 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: Makefile,v 1.17 2019/04/20 17:16:40 christos Exp $
+#      $NetBSD: Makefile,v 1.18 2019/10/12 18:32:21 christos Exp $
 
 .include <bsd.own.mk>
 
@@ -15,7 +15,7 @@
        auth2-none.c auth2-passwd.c auth2-pubkey.c \
        monitor.c monitor_wrap.c \
        kexgexs.c sftp-server.c sftp-common.c \
-       sandbox-rlimit.c pfilter.c
+       sftp-realpath.c sandbox-rlimit.c pfilter.c
 
 COPTS.auth-options.c+= -Wno-pointer-sign
 COPTS.ldapauth.c+=     -Wno-format-nonliteral  # XXX: should fix
diff -r efcb2bec0c0b -r 454b05e1e6be crypto/external/bsd/openssh/dist/auth-options.c
--- a/crypto/external/bsd/openssh/dist/auth-options.c   Sat Oct 12 17:50:56 2019 +0000
+++ b/crypto/external/bsd/openssh/dist/auth-options.c   Sat Oct 12 18:32:21 2019 +0000
@@ -1,5 +1,5 @@
-/*     $NetBSD: auth-options.c,v 1.20 2019/04/20 17:16:40 christos Exp $       */
-/* $OpenBSD: auth-options.c,v 1.84 2018/10/03 06:38:35 djm Exp $ */
+/*     $NetBSD: auth-options.c,v 1.21 2019/10/12 18:32:22 christos Exp $       */
+/* $OpenBSD: auth-options.c,v 1.89 2019/09/13 04:36:43 dtucker Exp $ */
 /*
  * Copyright (c) 2018 Damien Miller <djm%mindrot.org@localhost>
  *
@@ -17,10 +17,11 @@
  */
 
 #include "includes.h"
-__RCSID("$NetBSD: auth-options.c,v 1.20 2019/04/20 17:16:40 christos Exp $");
+__RCSID("$NetBSD: auth-options.c,v 1.21 2019/10/12 18:32:22 christos Exp $");
 #include <sys/types.h>
 #include <sys/queue.h>
 
+#include <stdlib.h>
 #include <netdb.h>
 #include <pwd.h>
 #include <string.h>
@@ -40,75 +41,6 @@
 #include "ssh2.h"
 #include "auth-options.h"
 
-/*
- * Match flag 'opt' in *optsp, and if allow_negate is set then also match
- * 'no-opt'. Returns -1 if option not matched, 1 if option matches or 0
- * if negated option matches.
- * If the option or negated option matches, then *optsp is updated to
- * point to the first character after the option.
- */
-static int
-opt_flag(const char *opt, int allow_negate, const char **optsp)
-{
-       size_t opt_len = strlen(opt);
-       const char *opts = *optsp;
-       int negate = 0;
-
-       if (allow_negate && strncasecmp(opts, "no-", 3) == 0) {
-               opts += 3;
-               negate = 1;
-       }
-       if (strncasecmp(opts, opt, opt_len) == 0) {
-               *optsp = opts + opt_len;
-               return negate ? 0 : 1;
-       }
-       return -1;
-}
-
-static char *
-opt_dequote(const char **sp, const char **errstrp)
-{
-       const char *s = *sp;
-       char *ret;
-       size_t i;
-
-       *errstrp = NULL;
-       if (*s != '"') {
-               *errstrp = "missing start quote";
-               return NULL;
-       }
-       s++;
-       if ((ret = malloc(strlen((s)) + 1)) == NULL) {
-               *errstrp = "memory allocation failed";
-               return NULL;
-       }
-       for (i = 0; *s != '\0' && *s != '"';) {
-               if (s[0] == '\\' && s[1] == '"')
-                       s++;
-               ret[i++] = *s++;
-       }
-       if (*s == '\0') {
-               *errstrp = "missing end quote";
-               free(ret);
-               return NULL;
-       }
-       ret[i] = '\0';
-       s++;
-       *sp = s;
-       return ret;
-}
-
-static int
-opt_match(const char **opts, const char *term)
-{
-       if (strncasecmp((*opts), term, strlen(term)) == 0 &&
-           (*opts)[strlen(term)] == '=') {
-               *opts += strlen(term) + 1;
-               return 1;
-       }
-       return 0;
-}
-
 static int
 dup_strings(char ***dstp, size_t *ndstp, char **src, size_t nsrc)
 {
@@ -321,7 +253,7 @@
        size_t npermits = *npermitsp;
        const char *errstr = "unknown error";
 
-       if (npermits > INT_MAX) {
+       if (npermits > SSH_AUTHOPT_PERMIT_MAX) {
                *errstrp = "too many permission directives";
                return -1;
        }
@@ -333,7 +265,8 @@
                 * Allow a bare port number in permitlisten to indicate a
                 * listen_host wildcard.
                 */
-               if (asprintf(&tmp, "*:%s", opt) < 0) {
+               if (asprintf(&tmp, "*:%s", opt) == -1) {
+                       free(opt);
                        *errstrp = "memory allocation failed";
                        return -1;
                }
diff -r efcb2bec0c0b -r 454b05e1e6be crypto/external/bsd/openssh/dist/auth-options.h
--- a/crypto/external/bsd/openssh/dist/auth-options.h   Sat Oct 12 17:50:56 2019 +0000
+++ b/crypto/external/bsd/openssh/dist/auth-options.h   Sat Oct 12 18:32:21 2019 +0000
@@ -1,5 +1,5 @@
-/*     $NetBSD: auth-options.h,v 1.11 2018/08/26 07:46:36 christos Exp $       */
-/* $OpenBSD: auth-options.h,v 1.27 2018/06/06 18:23:32 djm Exp $ */
+/*     $NetBSD: auth-options.h,v 1.12 2019/10/12 18:32:22 christos Exp $       */
+/* $OpenBSD: auth-options.h,v 1.28 2019/07/09 04:15:00 djm Exp $ */
 
 /*
  * Copyright (c) 2018 Damien Miller <djm%mindrot.org@localhost>
@@ -23,6 +23,9 @@
 struct passwd;
 struct sshkey;
 
+/* Maximum number of permitopen/permitlisten directives to accept */
+#define SSH_AUTHOPT_PERMIT_MAX 4096
+
 /*
  * sshauthopt represents key options parsed from authorized_keys or
  * from certificate extensions/options.
diff -r efcb2bec0c0b -r 454b05e1e6be crypto/external/bsd/openssh/dist/auth-rhosts.c
--- a/crypto/external/bsd/openssh/dist/auth-rhosts.c    Sat Oct 12 17:50:56 2019 +0000
+++ b/crypto/external/bsd/openssh/dist/auth-rhosts.c    Sat Oct 12 18:32:21 2019 +0000
@@ -1,6 +1,5 @@
-/*     $NetBSD: auth-rhosts.c,v 1.10 2019/01/27 02:08:33 pgoyette Exp $        */
-/* $OpenBSD: auth-rhosts.c,v 1.49 2018/07/09 21:35:50 markus Exp $ */
-
+/*     $NetBSD: auth-rhosts.c,v 1.11 2019/10/12 18:32:22 christos Exp $        */
+/* $OpenBSD: auth-rhosts.c,v 1.51 2019/10/02 00:42:30 djm Exp $ */
 /*
  * Author: Tatu Ylonen <ylo%cs.hut.fi@localhost>
  * Copyright (c) 1995 Tatu Ylonen <ylo%cs.hut.fi@localhost>, Espoo, Finland
@@ -17,7 +16,7 @@
  */
 
 #include "includes.h"
-__RCSID("$NetBSD: auth-rhosts.c,v 1.10 2019/01/27 02:08:33 pgoyette Exp $");
+__RCSID("$NetBSD: auth-rhosts.c,v 1.11 2019/10/12 18:32:22 christos Exp $");
 #include <sys/types.h>
 #include <sys/stat.h>
 
@@ -38,7 +37,6 @@
 #include "sshkey.h"
 #include "servconf.h"
 #include "canohost.h"
-#include "sshkey.h"
 #include "hostfile.h"
 #include "auth.h"
 
@@ -222,8 +220,8 @@
         * are no system-wide files.
         */
        if (!rhosts_files[rhosts_file_index] &&
-           stat(_PATH_RHOSTS_EQUIV, &st) < 0 &&
-           stat(_PATH_SSH_HOSTS_EQUIV, &st) < 0) {
+           stat(_PATH_RHOSTS_EQUIV, &st) == -1 &&
+           stat(_PATH_SSH_HOSTS_EQUIV, &st) == -1) {
                debug3("%s: no hosts access files exist", __func__);
                return 0;
        }
@@ -253,7 +251,7 @@
         * Check that the home directory is owned by root or the user, and is
         * not group or world writable.
         */
-       if (stat(pw->pw_dir, &st) < 0) {
+       if (stat(pw->pw_dir, &st) == -1) {
                logit("Rhosts authentication refused for %.100s: "
                    "no home directory %.200s", pw->pw_name, pw->pw_dir);
                auth_debug_add("Rhosts authentication refused for %.100s: "
@@ -278,7 +276,7 @@
                /* Check users .rhosts or .shosts. */
                snprintf(buf, sizeof buf, "%.500s/%.100s",
                         pw->pw_dir, rhosts_files[rhosts_file_index]);
-               if (stat(buf, &st) < 0)
+               if (stat(buf, &st) == -1)
                        continue;
 
                /*
diff -r efcb2bec0c0b -r 454b05e1e6be crypto/external/bsd/openssh/dist/auth.c
--- a/crypto/external/bsd/openssh/dist/auth.c   Sat Oct 12 17:50:56 2019 +0000
+++ b/crypto/external/bsd/openssh/dist/auth.c   Sat Oct 12 18:32:21 2019 +0000
@@ -1,5 +1,5 @@
-/*     $NetBSD: auth.c,v 1.24 2019/04/20 17:16:40 christos Exp $       */
-/* $OpenBSD: auth.c,v 1.138 2019/01/19 21:41:18 djm Exp $ */
+/*     $NetBSD: auth.c,v 1.25 2019/10/12 18:32:22 christos Exp $       */
+/* $OpenBSD: auth.c,v 1.141 2019/10/02 00:42:30 djm Exp $ */
 /*
  * Copyright (c) 2000 Markus Friedl.  All rights reserved.
  *
@@ -25,12 +25,13 @@
  */
 
 #include "includes.h"
-__RCSID("$NetBSD: auth.c,v 1.24 2019/04/20 17:16:40 christos Exp $");
+__RCSID("$NetBSD: auth.c,v 1.25 2019/10/12 18:32:22 christos Exp $");
 #include <sys/types.h>
 #include <sys/stat.h>
 #include <sys/socket.h>
 #include <sys/wait.h>
 
+#include <stdlib.h>
 #include <errno.h>
 #include <fcntl.h>
 #include <login_cap.h>
@@ -63,7 +64,6 @@
 #endif
 #include "authfile.h"
 #include "monitor_wrap.h"
-#include "authfile.h"
 #include "ssherr.h"
 #include "compat.h"
 #include "channels.h"
@@ -226,7 +226,7 @@
                char *shell = xstrdup((pw->pw_shell[0] == '\0') ?
                    _PATH_BSHELL : pw->pw_shell); /* empty = /bin/sh */
 
-               if (stat(shell, &st) != 0) {
+               if (stat(shell, &st) == -1) {
                        logit("User %.100s not allowed because shell %.100s "
                            "does not exist", pw->pw_name, shell);
                        free(shell);
@@ -557,7 +557,7 @@
                return NULL;
        }
 
-       if (fstat(fd, &st) < 0) {
+       if (fstat(fd, &st) == -1) {
                close(fd);
                return NULL;
        }
@@ -771,7 +771,7 @@
        fromlen = sizeof(from);



Home | Main Index | Thread Index | Old Index