1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
|
#!/usr/bin/env python
#
# Seccomp Library test program
#
# Copyright (c) 2016 Red Hat <pmoore@redhat.com>
# Author: Paul Moore <paul@paul-moore.com>
#
#
# This library is free software; you can redistribute it and/or modify it
# under the terms of version 2.1 of the GNU Lesser General Public License as
# published by the Free Software Foundation.
#
# This library 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 this library; if not, see <http://www.gnu.org/licenses>.
#
import argparse
import sys
import util
from seccomp import *
def test(args):
f = SyscallFilter(KILL)
f.remove_arch(Arch())
f.add_arch(Arch("x86"))
f.add_arch(Arch("x86_64"))
f.add_arch(Arch("x32"))
f.add_arch(Arch("ppc64le"))
f.add_arch(Arch("mipsel"))
f.add_arch(Arch("sh"))
f.add_rule(ALLOW, "socket")
f.add_rule(ALLOW, "bind")
f.add_rule(ALLOW, "connect")
f.add_rule(ALLOW, "listen")
f.add_rule(ALLOW, "accept")
f.add_rule(ALLOW, "accept4")
f.add_rule(ALLOW, "getsockname")
f.add_rule(ALLOW, "getpeername")
f.add_rule(ALLOW, "socketpair")
f.add_rule(ALLOW, "send")
f.add_rule(ALLOW, "recv")
f.add_rule(ALLOW, "sendto")
f.add_rule(ALLOW, "recvfrom")
f.add_rule(ALLOW, "shutdown")
f.add_rule(ALLOW, "setsockopt")
f.add_rule(ALLOW, "getsockopt")
f.add_rule(ALLOW, "sendmsg")
f.add_rule(ALLOW, "recvmsg")
f.add_rule(ALLOW, "accept4")
f.add_rule(ALLOW, "sendmmsg")
f.add_rule(ALLOW, "recvmmsg")
return f
args = util.get_opt()
ctx = test(args)
util.filter_output(args, ctx)
# kate: syntax python;
# kate: indent-mode python; space-indent on; indent-width 4; mixedindent off;
|