~ubuntu-branches/ubuntu/trusty/systemd/trusty

« back to all changes in this revision

Viewing changes to src/tcpwrap.c

  • Committer: Package Import Robot
  • Author(s): Michael Biebl, Michael Biebl, Michael Stapelberg, Daniel Schaal, Ondrej Balaz
  • Date: 2013-09-12 00:13:11 UTC
  • mfrom: (1.1.11) (9.1.2 experimental)
  • mto: This revision was merged to the branch mainline in revision 53.
  • Revision ID: package-import@ubuntu.com-20130912001311-dz35it34wr2lbday
Tags: 204-3
[ Michael Biebl ]
* Upload to unstable.
* Use /bin/bash in debug-shell.service as Debian doesn't have /sbin/sushell.
* Only import net.ifaces cmdline property for network devices.
* Generate strict dependencies between the binary packages using a
  shlibs.local file and add an explicit versioned dependency on
  libsystemd-login0 to systemd to ensure packages are upgraded in sync.
  Closes: #719444
* Drop obsolete Replaces: libudev0 from udev package.
* Use correct paths for various binaries, like /sbin/quotaon, which are
  installed in / and not /usr in Debian.  Closes: #721347
* Don't install kernel-install(8) man page since we don't install the
  corresponding binary either.  Closes: #722180
* Cherry-pick upstream fixes to make switching runlevels and starting
  reboot via ctrl-alt-del more robust.
* Cherry-pick upstream fix to properly apply ACLs to Journal files.

[ Michael Stapelberg ]
* Make systemctl enable|disable call update-rc.d for SysV init scripts.
  Closes: #709780
* Don't mount /tmp as tmpfs by default and make it possible to enable this
  feature via "systemctl enable tmp.mount".

[ Daniel Schaal ]
* Add bug-script to systemd and udev.  Closes: #711245

[ Ondrej Balaz ]
* Recognize discard option in /etc/crypttab.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2
 
 
3
 
/***
4
 
  This file is part of systemd.
5
 
 
6
 
  Copyright 2010 Lennart Poettering
7
 
 
8
 
  systemd is free software; you can redistribute it and/or modify it
9
 
  under the terms of the GNU General Public License as published by
10
 
  the Free Software Foundation; either version 2 of the License, or
11
 
  (at your option) any later version.
12
 
 
13
 
  systemd is distributed in the hope that it will be useful, but
14
 
  WITHOUT ANY WARRANTY; without even the implied warranty of
15
 
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16
 
  General Public License for more details.
17
 
 
18
 
  You should have received a copy of the GNU General Public License
19
 
  along with systemd; If not, see <http://www.gnu.org/licenses/>.
20
 
***/
21
 
 
22
 
#include <sys/socket.h>
23
 
#include <sys/un.h>
24
 
#include <arpa/inet.h>
25
 
#include <netinet/in.h>
26
 
 
27
 
#ifdef HAVE_LIBWRAP
28
 
#include <tcpd.h>
29
 
#endif
30
 
 
31
 
#include "tcpwrap.h"
32
 
#include "log.h"
33
 
 
34
 
bool socket_tcpwrap(int fd, const char *name) {
35
 
#ifdef HAVE_LIBWRAP
36
 
        struct request_info req;
37
 
        union {
38
 
                struct sockaddr sa;
39
 
                struct sockaddr_in in;
40
 
                struct sockaddr_in6 in6;
41
 
                struct sockaddr_un un;
42
 
                struct sockaddr_storage storage;
43
 
        } sa_union;
44
 
        socklen_t l = sizeof(sa_union);
45
 
 
46
 
        if (getsockname(fd, &sa_union.sa, &l) < 0)
47
 
                return true;
48
 
 
49
 
        if (sa_union.sa.sa_family != AF_INET &&
50
 
            sa_union.sa.sa_family != AF_INET6)
51
 
                return true;
52
 
 
53
 
        request_init(&req,
54
 
                     RQ_DAEMON, name,
55
 
                     RQ_FILE, fd,
56
 
                     NULL);
57
 
 
58
 
        fromhost(&req);
59
 
 
60
 
        if (!hosts_access(&req)) {
61
 
                log_warning("Connection refused by tcpwrap.");
62
 
                return false;
63
 
        }
64
 
 
65
 
        log_debug("Connection accepted by tcpwrap.");
66
 
#endif
67
 
        return true;
68
 
}