Parent Missing From Disk Linux

osquery
A program where the parent PID is not on disk
Author

Chainguard

Published

January 29, 2025

Description

ODK (osquery-defense-kit) is unique in that the queries are designed to be used as part of a production detection & response pipeline. The detection queries are formulated to return zero rows during normal expected behavior, so that they may be configured to generate alerts when rows are returned.

Query

-- A program where the parent PID is not on disk
--
-- Reveals boopkit if a child is spawned
-- TODO: Make mount namespace aware
--
-- false positives:
--   * none observed
--
-- references:
--   * https://attack.mitre.org/techniques/T1070/004/ (Indicator Removal on Host: File Deletion)
--
-- false positives:
--   * none observed
--
-- tags: persistent daemon
SELECT -- Child
  p0.pid AS p0_pid,
  p0.path AS p0_path,
  p0.name AS p0_name,
  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.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,
  -- Grandparent
  p1.parent AS p2_pid,
  p2.name AS p2_name,
  p2.path AS p2_path,
  p2.cmdline AS p2_cmd,
  p2_hash.sha256 AS p2_sha256
FROM
  processes p0
  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
  p1.on_disk != 1
  AND p0.on_disk = 1
  AND NOT p0.pid IN (1, 2)
  AND NOT p1.pid IN (1, 2) -- launchd, kthreadd
  -- Probably a software upgrade
  AND NOT p1_dirname IN (
    '/opt/google/chrome',
    '/opt/microsoft/msedge',
    '/usr/bin',
    '/usr/lib',
    '/usr/lib/electron22',
    '/usr/lib/go/bin',
    '/usr/lib/systemd',
    '/usr/libexec',
    '/usr/sbin/gdm3',
    '/usr/share/code',
    '/usr/share/codium'
  ) -- long-running launchers
  AND NOT p1.name IN (
    'bash',
    'chrome',
    'dnf',
    'Docker Desktop',
    'electron',
    'fish',
    'gnome-shell',
    'gnome-terminal',
    'kube-proxy',
    'kubelet',
    'lightdm',
    'make',
    'ninja',
    'nvim',
    'sh',
    'slack',
    'zed-editor'
  )
  AND NOT (
    p1.path LIKE '/app/%'
    AND p1.cgroup_path LIKE '/user.slice/user-1000.slice/[email protected]/app.slice/%'
  )
  AND NOT (
    p1.path LIKE '/home/build/%'
    AND p1.cgroup_path LIKE '/user.slice/user-1000.slice/[email protected]/app.slice/%'
  )
  AND NOT p2.name = 'bwrap'
  AND p1.cgroup_path NOT LIKE '/system.slice/docker-%'
  AND p1.cgroup_path NOT IN (
    '/system.slice/containerd.service',
    '/system.slice/docker.service'
  )
  AND p1.cgroup_path NOT LIKE '/lxc.monitor.n%'
  AND p1.cgroup_path NOT LIKE '/user.slice/user-1000.slice/[email protected]/app.slice/app-steam@%'
  AND p1.cgroup_path NOT LIKE '/user.slice/user-1000.slice/[email protected]/user.slice/libpod-%'
  AND p1.cgroup_path NOT LIKE '/user.slice/user-1000.slice/[email protected]/user.slice/nerdctl-%'
  AND p1.path NOT LIKE '/opt/homebrew/Cellar/%'
  AND p1.path NOT LIKE '/tmp/.mount_%/%'
  AND p1.path NOT LIKE '%google-cloud-sdk/.install/.backup%'
  AND NOT (
    p1.name LIKE 'kworker/%+events_unbound'
    AND p0.name IN ('modprobe')
  )

tags: SStagSS

Reference

https://github.com/chainguard-dev/osquery-defense-kit