diff options
| author | Lennart Poettering <lennart@poettering.net> | 2014-03-24 20:07:42 +0100 | 
|---|---|---|
| committer | Lennart Poettering <lennart@poettering.net> | 2014-03-24 20:07:42 +0100 | 
| commit | 7f8aa67131cfc03ddcbd31c0420754864fc122f0 (patch) | |
| tree | 656e59465be5daa450fa4d34dcf2cc3bf298bf93 /src/core/tcpwrap.c | |
| parent | 1cfc57e8847ab2b138e5a8fcff4f881b3b1a9b60 (diff) | |
core: remove tcpwrap support
tcpwrap is legacy code, that is barely maintained upstream. It's APIs
are awful, and the feature set it exposes (such as DNS and IDENT
access control) questionnable. We should not support this natively in
systemd.
Hence, let's remove the code. If people want to continue making use of
this, they can do so by plugging in "tcpd" for the processes they start.
With that scheme things are as well or badly supported as they were from
traditional inetd, hence no functionality is really lost.
Diffstat (limited to 'src/core/tcpwrap.c')
| -rw-r--r-- | src/core/tcpwrap.c | 68 | 
1 files changed, 0 insertions, 68 deletions
| diff --git a/src/core/tcpwrap.c b/src/core/tcpwrap.c deleted file mode 100644 index 6c630fac60..0000000000 --- a/src/core/tcpwrap.c +++ /dev/null @@ -1,68 +0,0 @@ -/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/ - -/*** -  This file is part of systemd. - -  Copyright 2010 Lennart Poettering - -  systemd is free software; you can redistribute it and/or modify it -  under the terms of the GNU Lesser General Public License as published by -  the Free Software Foundation; either version 2.1 of the License, or -  (at your option) any later version. - -  systemd is distributed in the hope that it will be useful, but -  WITHOUT ANY WARRANTY; without even the implied warranty of -  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -  Lesser General Public License for more details. - -  You should have received a copy of the GNU Lesser General Public License -  along with systemd; If not, see <http://www.gnu.org/licenses/>. -***/ - -#include <sys/socket.h> -#include <sys/un.h> -#include <arpa/inet.h> -#include <netinet/in.h> - -#ifdef HAVE_LIBWRAP -#include <tcpd.h> -#endif - -#include "tcpwrap.h" -#include "log.h" - -bool socket_tcpwrap(int fd, const char *name) { -#ifdef HAVE_LIBWRAP -        struct request_info req; -        union { -                struct sockaddr sa; -                struct sockaddr_in in; -                struct sockaddr_in6 in6; -                struct sockaddr_un un; -                struct sockaddr_storage storage; -        } sa_union; -        socklen_t l = sizeof(sa_union); - -        if (getsockname(fd, &sa_union.sa, &l) < 0) -                return true; - -        if (sa_union.sa.sa_family != AF_INET && -            sa_union.sa.sa_family != AF_INET6) -                return true; - -        request_init(&req, -                     RQ_DAEMON, name, -                     RQ_FILE, fd, -                     NULL); - -        fromhost(&req); - -        if (!hosts_access(&req)) { -                log_warning("Connection refused by tcpwrap."); -                return false; -        } - -        log_debug("Connection accepted by tcpwrap."); -#endif -        return true; -} | 
