From Fedora Project Wiki
(The bug should be fixed in updates testing)
(missing selinux boolean configuration)
Line 10: Line 10:
# Attempt to connect to localhost using ssh: <code>ssh localhost</code>
# Attempt to connect to localhost using ssh: <code>ssh localhost</code>
# Update SELinux policy packages from Updates testing: <code>dnf update selinux-policy* --enablerepo="*testing"</code>
# Update SELinux policy packages from Updates testing: <code>dnf update selinux-policy* --enablerepo="*testing"</code>
# Change SELinux boolen to allow tcpd to start sshd: <code>semanage boolean -m --on ssh_use_tcpd</code>
# Configure the socket-activated sshd service with <code>tcpd</code> as described in the [[Changes/Deprecate_TCP_wrappers#Migration_to_tcpd|change page, section "Migration to tcpd"]].
# Configure the socket-activated sshd service with <code>tcpd</code> as described in the [[Changes/Deprecate_TCP_wrappers#Migration_to_tcpd|change page, section "Migration to tcpd"]].
# Verify, that the connection is rejected with the configuration from step 3:  <code>ssh localhost</code>
# Verify, that the connection is rejected with the configuration from step 3:  <code>ssh localhost</code>
Line 18: Line 19:
# Step #1 should not return anything
# Step #1 should not return anything
# Step #3 completes successfully (there is either password prompt or you are allowed in by public key authentication)
# Step #3 completes successfully (there is either password prompt or you are allowed in by public key authentication)
# Step #7 should reject the connection.
# Step #8 should reject the connection.
# Step #9 should connect successfully again (there is either password prompt or you are allowed in by public key authentication)
# Step #10 should connect successfully again (there is either password prompt or you are allowed in by public key authentication)
|optional=If you see some issues, investigate the logs in journal, make sure the services are running.
|optional=If you see some issues, investigate the logs in journal, make sure the services are running.
# If you have problems with <code>tcpd</code>, try to run with SELinux in permissive mode or look for update of <code>selinux-policy</code>. The bug [https://bugzilla.redhat.com/show_bug.cgi?id=1482554 #1482554] should be fixed in updates-testing by now.
# If you have problems with <code>tcpd</code>, try to run with SELinux in permissive mode or look for update of <code>selinux-policy</code>. The bug [https://bugzilla.redhat.com/show_bug.cgi?id=1482554 #1482554] should be fixed in updates-testing by now.
}}
}}

Revision as of 09:54, 22 March 2018

Description

Verify that OpenSSH works without tcp_wrappers and is not affected by its configuration by default

Setup

Make sure OpenSSH packages (client and server) are installed. Check that tcp_wrappers package is installed:

rpm -q openssh-server openssh-clients tcp_wrappers

How to test

  1. Check openssh server is NOT linked against libwrap: ldd /usr/sbin/sshd |grep libwrap
  2. Make sure there is no allowing rule in /etc/hosts.allow (the file contains only commented-out lines)
  3. Insert the following blocking rule in the /etc/hosts.deny: sshd: localhost
  4. Attempt to connect to localhost using ssh: ssh localhost
  5. Update SELinux policy packages from Updates testing: dnf update selinux-policy* --enablerepo="*testing"
  6. Change SELinux boolen to allow tcpd to start sshd: semanage boolean -m --on ssh_use_tcpd
  7. Configure the socket-activated sshd service with tcpd as described in the change page, section "Migration to tcpd".
  8. Verify, that the connection is rejected with the configuration from step 3: ssh localhost
  9. Remove the blocking rule that we added in step 3 from /etc/hosts.deny
  10. Verify that you can connect successfully now: ssh localhost

Expected Results

The following must be true to consider this a successful test run. Be brief ... but explicit.

  1. Step #1 should not return anything
  2. Step #3 completes successfully (there is either password prompt or you are allowed in by public key authentication)
  3. Step #8 should reject the connection.
  4. Step #10 should connect successfully again (there is either password prompt or you are allowed in by public key authentication)

Optional

If you see some issues, investigate the logs in journal, make sure the services are running.

  1. If you have problems with tcpd, try to run with SELinux in permissive mode or look for update of selinux-policy. The bug #1482554 should be fixed in updates-testing by now.