Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fpr: bpftool, curl, pulumi, Docker Desktop, go tests #402

Merged
merged 1 commit into from
Oct 23, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions detection/c2/unexpected-dns-traffic.sql
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ WHERE
)
-- Some applications hard-code a safe DNS resolver, or allow the user to configure one
AND s.remote_address NOT IN (
'1.0.0.1', -- Cloudflare
'1.1.1.1', -- Cloudflare
'1.1.1.2', -- Cloudflare
'8.8.8.8', -- Google
Expand All @@ -92,6 +93,7 @@ WHERE
'/opt/podman/bin/gvproxy',
'/System/Volumes/Preboot/Cryptexes/Incoming/OS/System/Library/Frameworks/WebKit.framework/Versions/A/XPCServices/com.apple.WebKit.Networking.xpc/Contents/MacOS/com.apple.WebKit.Networking',
'/usr/bin/tailscaled',
'/sbin/apk',
'/usr/lib/systemd/systemd-resolved',
'/usr/sbin/mDNSResponder'
)
Expand Down
1 change: 1 addition & 0 deletions detection/credentials/unexpected-dev-opener-linux.sql
Original file line number Diff line number Diff line change
Expand Up @@ -228,6 +228,7 @@ WHERE
'/dev/video,obs',
'/dev/video,obs-ffmpeg-mux',
'/dev/video,pipewire',
'/dev/net/tun,pasta.avx2',
'/dev/video,signal-desktop',
'/dev/video,slack',
'/dev/video,v4l2-relayd',
Expand Down
2 changes: 1 addition & 1 deletion detection/evasion/hidden-cwd.sql
Original file line number Diff line number Diff line change
Expand Up @@ -143,7 +143,7 @@ WHERE p0.pid IN (
'~/.hunter/_Base',
'~/.zsh'
)
OR top_dir IN ('~/Sync')
OR top_dir IN ('~/Sync', '~/src', '~/workspace')
OR dir LIKE '/Library/Apple/System/Library/InstallerSandboxes/.PKInstallSandboxManager-SystemSoftware/%'
OR dir LIKE '/opt/homebrew/%/.cache/%'
OR dir LIKE '~/%enterprise-packages/.chainguard'
Expand Down
1 change: 1 addition & 0 deletions detection/evasion/hidden-executable.sql
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,7 @@ WHERE (
'~/.pnpm',
'~/.rbenv',
'~/.rustup',
'~/.pulumi',
'~/Code',
'~/code',
'~/Projects',
Expand Down
44 changes: 11 additions & 33 deletions detection/evasion/parent-missing-from-disk-linux.sql
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ SELECT -- Child
p0.parent AS p1_pid,
p1.cgroup_path AS p1_cgroup,
p1.path AS p1_path,
REGEX_MATCH (p1.path, '(.*)/', 1) AS p1_dirname,
p1.name AS p1_name,
p1.cmdline AS p1_cmd,
p1_hash.sha256 AS p1_sha256,
Expand All @@ -47,38 +48,14 @@ WHERE
AND p0.on_disk = 1
AND NOT p0.pid IN (1, 2)
AND NOT p1.pid IN (1, 2) -- launchd, kthreadd
AND NOT p1.path IN (
'/opt/brave.com/brave/brave',
'/opt/google/chrome/chrome',
'/usr/bin/alacritty',
'/usr/bin/roxterm',
'/usr/bin/doas',
'/usr/bin/dockerd',
'/usr/bin/fusermount3',
'/usr/libexec/at-spi-bus-launcher',
'/usr/bin/gnome-shell',
'/usr/bin/ibus-daemon',
'/usr/bin/kitty',
'/usr/lib/electron22/electron',
'/usr/bin/osqueryd',
'/usr/bin/make',
'/usr/bin/ninja',
'/usr/bin/cmake',
'/usr/libexec/gvfsd',
'/usr/bin/sudo',
'/usr/bin/tmux',
'/usr/bin/python3',
'/usr/bin/yay',
'/usr/libexec/gdm-wayland-session',
'/usr/libexec/gdm-x-session',
'/usr/libexec/gnome-terminal-server',
'/usr/lib/gnome-session-binary',
'/usr/lib/systemd/systemd',
'/usr/lib/xdg-document-portal',
'/usr/sbin/auditd',
'/usr/sbin/gdm3',
'/usr/sbin/sshd',
'/usr/share/code/code'
-- Probably a software upgrade
AND NOT p1_dirname IN (
'/usr/lib/electron22',
'/usr/bin',
'/usr/libexec',
'/usr/lib/systemd',
'/usr/lib',
'/usr/share/code'
) -- long-running launchers
AND NOT p1.name IN (
'bash',
Expand All @@ -91,11 +68,12 @@ WHERE
'gnome-shell',
'kubelet',
'kube-proxy',
'Docker Desktop',
'lightdm',
'nvim',
'sh',
'slack'
) -- These alerts were unfortunately useless - lots of spam on macOS
)
AND NOT (
p1.path LIKE '/app/%'
AND p1.cgroup_path LIKE '/user.slice/user-1000.slice/user@1000.service/app.slice/%'
Expand Down
2 changes: 2 additions & 0 deletions detection/evasion/unusual-executable-name-macos.sql
Original file line number Diff line number Diff line change
Expand Up @@ -93,6 +93,7 @@ WHERE
'at.obdev.littlesnitch.networkextension',
'com.microsoft.teams2.notificationcenter',
'cpu',
'test',
'dynamiclinkmanager',
'EcammLiveVideoOutAssistantXPCHelper',
'launchd_startx',
Expand All @@ -104,6 +105,7 @@ WHERE
AND NOT pname LIKE 'cody-engine-%'
AND NOT pname LIKE '__%go_build_%'
AND NOT pname LIKE '__%go_test_%'
AND NOT pname LIKE '__Test%'
-- example: 85C27NK92C.com.flexibits.fantastical2.mac.helper
AND NOT pname LIKE "%.com.flexibits.fantastical2.mac.helper"
AND NOT s.authority = "Software Signing"
11 changes: 11 additions & 0 deletions detection/execution/sketchy-fetcher-events.sql
Original file line number Diff line number Diff line change
Expand Up @@ -172,6 +172,17 @@ WHERE
AND pe.cmdline NOT LIKE '%-o%'
AND pe.cmdline NOT LIKE '%-O%'
)
AND NOT (
pe.euid > 500
-- /usr/bin/curl https://34.117.0.114:443 -k
AND REGEX_MATCH(pe.cmdline, '(curl https://[\w\.\:\/]+ -k)$', 1) != ""
)
AND NOT (
pe.euid > 500
-- /usr/bin/curl -k https://34.117.0.114:443
AND REGEX_MATCH(pe.cmdline, '(curl -k https://[\w\.\:\/]+)$', 1) != ""
)

-- These are typically curl -k calls
-- We need the addr "IS NOT NULL" to avoid filtering out
-- NULL entries
Expand Down
8 changes: 2 additions & 6 deletions detection/execution/tiny-executable-events.sql
Original file line number Diff line number Diff line change
Expand Up @@ -43,8 +43,9 @@ WHERE
AND p.path NOT LIKE '%.rb'
AND p.path NOT IN (
'/sbin/ldconfig',
'/usr/sbin/ldconfig',
'/usr/bin/c_rehash',
'/usr/sbin/bpftool',
'/usr/sbin/ldconfig',
'/usr/sbin/update-ca-certificates'
)
AND NOT p.path LIKE '%/bin/firefox'
Expand All @@ -60,8 +61,3 @@ WHERE
p.path = "/"
AND file.size < 8192
)
AND NOT p.cmdline IN (
'bpftool --version',
'bpftool --help',
'bpftool -V'
)
Loading