]> www.infradead.org Git - users/dwmw2/linux.git/commit
netfilter: nfnetlink_cthelper: Add missing permission checks
authorKevin Cernekee <cernekee@chromium.org>
Sun, 3 Dec 2017 20:12:45 +0000 (12:12 -0800)
committerPablo Neira Ayuso <pablo@netfilter.org>
Mon, 4 Dec 2017 10:30:09 +0000 (11:30 +0100)
commit4b380c42f7d00a395feede754f0bc2292eebe6e5
tree726c117ca7fb8f101fc0245840972f27ac59b19e
parent8b1836c4b64386e9bc580438cae386ed31a43ab9
netfilter: nfnetlink_cthelper: Add missing permission checks

The capability check in nfnetlink_rcv() verifies that the caller
has CAP_NET_ADMIN in the namespace that "owns" the netlink socket.
However, nfnl_cthelper_list is shared by all net namespaces on the
system.  An unprivileged user can create user and net namespaces
in which he holds CAP_NET_ADMIN to bypass the netlink_net_capable()
check:

    $ nfct helper list
    nfct v1.4.4: netlink error: Operation not permitted
    $ vpnns -- nfct helper list
    {
            .name = ftp,
            .queuenum = 0,
            .l3protonum = 2,
            .l4protonum = 6,
            .priv_data_len = 24,
            .status = enabled,
    };

Add capable() checks in nfnetlink_cthelper, as this is cleaner than
trying to generalize the solution.

Signed-off-by: Kevin Cernekee <cernekee@chromium.org>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
net/netfilter/nfnetlink_cthelper.c