osquery-defense-kit/detection/persistence/yara-suspicious-strings-pro...

146 lines
3.9 KiB
SQL

-- Currently running program with Linux red flags
--
-- reference:
-- * https://github.com/timb-machine/linux-malware/blob/725aad34e216cc024c93b04964b289f10f819e6e/defensive/yara/personal-malware-bazaar/unixredflags3.yara
--
-- tags: persistent
-- interval: 7200
-- platform: linux
SELECT
yara.strings,
-- Child
p0.pid AS p0_pid,
p0.path AS p0_path,
p0.name AS p0_name,
p0.start_time AS p0_start,
p0.cmdline AS p0_cmd,
p0.cwd AS p0_cwd,
p0.cgroup_path AS p0_cgroup,
p0.euid AS p0_euid,
p0_hash.sha256 AS p0_sha256,
-- Parent
p0.parent AS p1_pid,
p1.path AS p1_path,
p1.name AS p1_name,
p1.start_time AS p1_start,
p1.euid AS p1_euid,
p1.cmdline AS p1_cmd,
p1_hash.sha256 AS p1_sha256,
-- Grandparent
p1.parent AS p2_pid,
p2.name AS p2_name,
p2.start_time AS p2_start,
p2.path AS p2_path,
p2.cmdline AS p2_cmd,
p2_hash.sha256 AS p2_sha256
FROM
processes p0
JOIN yara ON p0.path = yara.path
LEFT JOIN hash p0_hash ON p0.path = p0_hash.path
LEFT JOIN processes p1 ON p0.parent = p1.pid
LEFT JOIN hash p1_hash ON p1.path = p1_hash.path
LEFT JOIN processes p2 ON p1.parent = p2.pid
LEFT JOIN hash p2_hash ON p2.path = p2_hash.path
WHERE
p0.pid IN (
SELECT
pid
FROM
processes
WHERE
start_time > (strftime('%s', 'now') - 7200)
AND path != ""
GROUP BY
path
)
AND yara.sigrule = '
rule redflags {
strings:
$bash_history = ".bash_history"
$google_chrome = "google-chrome"
$cron = "cron"
$dev_shm = "/dev/shm"
$dev_tcp = "/dev/tcp"
$dev_udp = "/dev/udp"
$iptables = "iptables"
$ld_so = "ld.so.conf"
$proc = "/proc"
$sudo = "sudo"
$systemctl = "systemctl"
$useradd = "useradd"
$var_tmp = "/var/tmp"
$var_run = "/var/run"
$dev_mqueue = "/dev/mqueue"
$bin_sh = "/bin/sh"
$pickup = "pickup -l"
$avahi = "avahi-daemon:"
$redhat4 = "Red Hat 4"
condition:
filesize < 25MB and 4 of them
}'
AND yara.count > 0
AND p0.name NOT IN (
'chrome_crashpad',
'X',
'systemd',
'NetworkManager',
'systemd-journal',
'Xorg',
'slirp4netns',
'nacl_helper'
)
AND p0.path NOT LIKE '%/google/chrome/%'
AND p0.path NOT LIKE '%/chrome_crashpad_handler'
AND p0.path NOT LIKE '/nix/store/%/bin/%'
AND p0.path NOT LIKE '/nix/store/%/libexec/%'
AND p0.path NOT LIKE '/usr/local/aws-cli/%/aws'
AND p0.path NOT LIKE '/usr/local/kolide-k2/bin/launcher-updates/%/launcher'
AND p0.path NOT IN (
'/bin/bash',
'/bin/containerd-shim-runc-v2',
'/bin/fish',
'/usr/bin/bash',
'/usr/lib/snapd/snapd',
'/usr/bin/snap',
'/usr/bin/containerd-shim-runc-v2',
'/usr/bin/docker-proxy',
'/usr/bin/fish',
'/usr/bin/gnome-software',
'/usr/bin/gpg-agent',
'/usr/bin/ibus-daemon',
'/usr/bin/make',
'/usr/bin/NetworkManager',
'/usr/bin/nvidia-persistenced',
'/usr/bin/nvim',
'/opt/Elastic/Endpoint/elastic-endpoint',
'/usr/bin/pulseaudio',
'/usr/bin/sshd',
'/usr/bin/sudo',
'/usr/bin/udevadm',
'/usr/bin/update-notifier',
'/usr/bin/Xwayland',
'/usr/lib/bluetooth/bluetoothd',
'/usr/lib/bluetooth/obexd',
'/usr/libexec/accounts-daemon',
'/usr/libexec/bluetooth/bluetoothd',
'/usr/libexec/bluetooth/obexd',
'/usr/libexec/flatpak-system-helper',
'/usr/libexec/sssd/sssd_kcm',
'/usr/libexec/xdg-desktop-portal',
'/usr/lib/systemd/systemd',
'/usr/lib/systemd/systemd-journald',
'/usr/lib/systemd/systemd-machined',
'/usr/local/bin/rootlesskit',
'/usr/local/kolide-k2/bin/launcher',
'/usr/sbin/acpid',
'/usr/sbin/auditd',
'/usr/sbin/cron',
'/usr/sbin/crond',
'/usr/sbin/gdm',
'/usr/sbin/gssproxy',
'/usr/sbin/mcelog',
'/usr/sbin/NetworkManager',
'/usr/sbin/rsyslogd',
'/usr/sbin/smartd'
)