2019-04-18 23:13:58 +02:00
|
|
|
--- ./configure.ac.orig 2019-04-17 17:52:57.000000000 -0500
|
|
|
|
+++ ./configure.ac 2019-04-18 15:13:25.404941727 -0500
|
|
|
|
@@ -1494,6 +1494,62 @@
|
2018-08-27 22:27:22 +02:00
|
|
|
AC_MSG_RESULT([no])
|
|
|
|
fi
|
2016-06-30 22:26:57 +02:00
|
|
|
|
|
|
|
+# Check whether user wants TCP wrappers support
|
|
|
|
+TCPW_MSG="no"
|
|
|
|
+AC_ARG_WITH([tcp-wrappers],
|
|
|
|
+ [ --with-tcp-wrappers[[=PATH]] Enable tcpwrappers support (optionally in PATH)],
|
|
|
|
+ [
|
|
|
|
+ if test "x$withval" != "xno" ; then
|
|
|
|
+ saved_LIBS="$LIBS"
|
|
|
|
+ saved_LDFLAGS="$LDFLAGS"
|
|
|
|
+ saved_CPPFLAGS="$CPPFLAGS"
|
|
|
|
+ if test -n "${withval}" && \
|
|
|
|
+ test "x${withval}" != "xyes"; then
|
|
|
|
+ if test -d "${withval}/lib"; then
|
|
|
|
+ if test -n "${need_dash_r}"; then
|
|
|
|
+ LDFLAGS="-L${withval}/lib -R${withval}/lib ${LDFLAGS}"
|
|
|
|
+ else
|
|
|
|
+ LDFLAGS="-L${withval}/lib ${LDFLAGS}"
|
|
|
|
+ fi
|
|
|
|
+ else
|
|
|
|
+ if test -n "${need_dash_r}"; then
|
|
|
|
+ LDFLAGS="-L${withval} -R${withval} ${LDFLAGS}"
|
|
|
|
+ else
|
|
|
|
+ LDFLAGS="-L${withval} ${LDFLAGS}"
|
|
|
|
+ fi
|
|
|
|
+ fi
|
|
|
|
+ if test -d "${withval}/include"; then
|
|
|
|
+ CPPFLAGS="-I${withval}/include ${CPPFLAGS}"
|
|
|
|
+ else
|
|
|
|
+ CPPFLAGS="-I${withval} ${CPPFLAGS}"
|
|
|
|
+ fi
|
|
|
|
+ fi
|
|
|
|
+ LIBS="-lwrap -lnsl $LIBS"
|
|
|
|
+ AC_MSG_CHECKING([for libwrap])
|
|
|
|
+ AC_LINK_IFELSE([AC_LANG_PROGRAM([[
|
|
|
|
+#include <sys/types.h>
|
|
|
|
+#include <sys/socket.h>
|
|
|
|
+#include <netinet/in.h>
|
|
|
|
+#include <tcpd.h>
|
|
|
|
+int deny_severity = 0, allow_severity = 0;
|
|
|
|
+ ]], [[
|
|
|
|
+ hosts_access(0);
|
|
|
|
+ ]])], [
|
|
|
|
+ AC_MSG_RESULT([yes])
|
|
|
|
+ AC_DEFINE([LIBWRAP], [1],
|
|
|
|
+ [Define if you want
|
|
|
|
+ TCP Wrappers support])
|
|
|
|
+ SSHDLIBS="$SSHDLIBS -lwrap -lnsl"
|
|
|
|
+ TCPW_MSG="yes"
|
|
|
|
+ ], [
|
|
|
|
+ AC_MSG_ERROR([*** libwrap missing])
|
|
|
|
+
|
|
|
|
+ ])
|
|
|
|
+ LIBS="$saved_LIBS"
|
|
|
|
+ fi
|
|
|
|
+ ]
|
|
|
|
+)
|
|
|
|
+
|
|
|
|
# Check whether user wants to use ldns
|
|
|
|
LDNS_MSG="no"
|
|
|
|
AC_ARG_WITH(ldns,
|
2019-04-18 23:13:58 +02:00
|
|
|
@@ -5245,6 +5301,7 @@
|
2018-08-27 22:27:22 +02:00
|
|
|
echo " OSF SIA support: $SIA_MSG"
|
2018-05-28 21:12:29 +02:00
|
|
|
echo " KerberosV support: $KRB5_MSG"
|
2016-06-30 22:26:57 +02:00
|
|
|
echo " SELinux support: $SELINUX_MSG"
|
|
|
|
+echo " TCP Wrappers support: $TCPW_MSG"
|
|
|
|
echo " MD5 password support: $MD5_MSG"
|
|
|
|
echo " libedit support: $LIBEDIT_MSG"
|
2018-05-28 21:12:29 +02:00
|
|
|
echo " libldns support: $LDNS_MSG"
|
2019-04-18 23:13:58 +02:00
|
|
|
--- ./sshd.c.orig 2019-04-17 17:52:57.000000000 -0500
|
|
|
|
+++ ./sshd.c 2019-04-18 15:13:25.406941726 -0500
|
2018-05-28 21:12:29 +02:00
|
|
|
@@ -122,6 +122,12 @@
|
|
|
|
#include "auth-options.h"
|
2016-06-30 22:26:57 +02:00
|
|
|
#include "version.h"
|
2018-05-28 21:12:29 +02:00
|
|
|
#include "ssherr.h"
|
2016-06-30 22:26:57 +02:00
|
|
|
+#ifdef LIBWRAP
|
|
|
|
+#include <tcpd.h>
|
|
|
|
+#include <syslog.h>
|
|
|
|
+int allow_severity;
|
|
|
|
+int deny_severity;
|
|
|
|
+#endif /* LIBWRAP */
|
2018-05-28 21:12:29 +02:00
|
|
|
|
|
|
|
/* Re-exec fds */
|
|
|
|
#define REEXEC_DEVCRYPTO_RESERVED_FD (STDERR_FILENO + 1)
|
2019-04-18 23:13:58 +02:00
|
|
|
@@ -2022,6 +2028,26 @@
|
|
|
|
the_active_state = ssh;
|
|
|
|
ssh_packet_set_server(ssh);
|
2018-05-28 21:12:29 +02:00
|
|
|
|
|
|
|
+/* Moved LIBWRAP check here */
|
2016-06-30 22:26:57 +02:00
|
|
|
+#ifdef LIBWRAP
|
2018-05-28 21:12:29 +02:00
|
|
|
+ allow_severity = options.log_facility|LOG_INFO;
|
|
|
|
+ deny_severity = options.log_facility|LOG_WARNING;
|
|
|
|
+ /* Check whether logins are denied from this host. */
|
2019-04-18 23:13:58 +02:00
|
|
|
+ if (ssh_packet_connection_is_on_socket(ssh)) { /* This check must be after ssh_packet_set_connection() */
|
2016-06-30 22:26:57 +02:00
|
|
|
+ struct request_info req;
|
|
|
|
+
|
|
|
|
+ request_init(&req, RQ_DAEMON, __progname, RQ_FILE, sock_in, 0);
|
|
|
|
+ fromhost(&req);
|
|
|
|
+
|
|
|
|
+ if (!hosts_access(&req)) {
|
|
|
|
+ debug("Connection refused by tcp wrapper");
|
|
|
|
+ refuse(&req);
|
|
|
|
+ /* NOTREACHED */
|
|
|
|
+ fatal("libwrap refuse returns");
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+#endif /* LIBWRAP */
|
2018-05-28 21:12:29 +02:00
|
|
|
+
|
|
|
|
check_ip_options(ssh);
|
2016-06-30 22:26:57 +02:00
|
|
|
|
2018-05-28 21:12:29 +02:00
|
|
|
/* Prepare the channels layer */
|
2019-04-18 23:13:58 +02:00
|
|
|
--- ./sshd.8.orig 2019-04-17 17:52:57.000000000 -0500
|
|
|
|
+++ ./sshd.8 2019-04-18 15:13:25.407941726 -0500
|
2018-08-27 22:27:22 +02:00
|
|
|
@@ -873,6 +873,12 @@
|
|
|
|
This file should be writable only by the user, and need not be
|
|
|
|
readable by anyone else.
|
|
|
|
.Pp
|
|
|
|
+.It Pa /etc/hosts.allow
|
|
|
|
+.It Pa /etc/hosts.deny
|
|
|
|
+Access controls that should be enforced by tcp-wrappers are defined here.
|
|
|
|
+Further details are described in
|
|
|
|
+.Xr hosts_access 5 .
|
|
|
|
+.Pp
|
|
|
|
.It Pa /etc/hosts.equiv
|
|
|
|
This file is for host-based authentication (see
|
|
|
|
.Xr ssh 1 ) .
|
|
|
|
@@ -975,6 +981,7 @@
|
|
|
|
.Xr ssh-keygen 1 ,
|
|
|
|
.Xr ssh-keyscan 1 ,
|
|
|
|
.Xr chroot 2 ,
|
|
|
|
+.Xr hosts_access 5 ,
|
|
|
|
.Xr login.conf 5 ,
|
|
|
|
.Xr moduli 5 ,
|
|
|
|
.Xr sshd_config 5 ,
|