47 lines
1.2 KiB
SQL
47 lines
1.2 KiB
SQL
-- Find root-run processes which link against libpf
|
|
--
|
|
-- WARNING: This check consumes an unusual amount of system memory (up to 225MB)
|
|
--
|
|
-- references:
|
|
-- * https://attack.mitre.org/techniques/T1205/001/ (Traffic Signaling: Port Knocking)
|
|
--
|
|
-- platform: posix
|
|
-- tags: persistent state process sniffer
|
|
SELECT
|
|
pmm.pid,
|
|
pmm.path AS lib_path,
|
|
p.path,
|
|
p.name,
|
|
p.cmdline,
|
|
p.cwd,
|
|
p.euid,
|
|
p.parent,
|
|
pp.path AS parent_path,
|
|
pp.name AS parent_name,
|
|
pp.cmdline AS parent_cmdline,
|
|
pp.cwd AS parent_cwd,
|
|
pp.euid AS parent_euid,
|
|
hash.sha256 AS child_sha256,
|
|
phash.sha256 AS parent_sha256
|
|
-- Using processes is much faster than process_memory_map
|
|
FROM
|
|
processes p
|
|
LEFT JOIN process_memory_map pmm ON p.pid = pmm.pid
|
|
LEFT JOIN processes pp ON p.parent = pp.pid
|
|
LEFT JOIN hash ON p.path = hash.path
|
|
LEFT JOIN hash AS phash ON pp.path = phash.path
|
|
WHERE
|
|
p.euid = 0
|
|
AND (
|
|
lib_path LIKE '%:bpf%'
|
|
OR lib_path LIKE '%libbpf%'
|
|
)
|
|
AND p.path NOT IN (
|
|
'/usr/bin/qemu-system-x86_64',
|
|
'/usr/lib/systemd/systemd'
|
|
)
|
|
AND p.cmdline != '/usr/bin/python3 /usr/sbin/execsnoop-bpfcc'
|
|
AND p.path NOT LIKE '/nix/store/%/lib/systemd/systemd'
|
|
GROUP BY
|
|
pmm.pid
|