Suspicious Windows Process Cluster Spawned by a Host

A machine learning job combination has detected a set of one or more suspicious Windows processes with unusually high scores for malicious probability. These process(es) have been classified as malicious in several ways. The process(es) were predicted to be malicious by the ProblemChild supervised ML model. If the anomaly contains a cluster of suspicious processes, each process has the same host name, and the aggregate score of the event cluster was calculated to be unusually high by an unsupervised ML model. Such a cluster often contains suspicious or malicious activity, possibly involving LOLbins, that may be resistant to detection using conventional search rules.

Elastic rule (View on GitHub)

 1[metadata]
 2creation_date = "2023/10/16"
 3integration = ["problemchild", "endpoint", "windows"]
 4maturity = "production"
 5updated_date = "2024/10/28"
 6min_stack_version = "8.14.0"
 7min_stack_comments = "Breaking change at 8.14.0 for the Windows Integration."
 8
 9[rule]
10anomaly_threshold = 75
11author = ["Elastic"]
12description = """
13A machine learning job combination has detected a set of one or more suspicious Windows processes with unusually high
14scores for malicious probability. These process(es) have been classified as malicious in several ways. The process(es)
15were predicted to be malicious by the ProblemChild supervised ML model. If the anomaly contains a cluster of suspicious
16processes, each process has the same host name, and the aggregate score of the event cluster was calculated to be
17unusually high by an unsupervised ML model. Such a cluster often contains suspicious or malicious activity, possibly
18involving LOLbins, that may be resistant to detection using conventional search rules.
19"""
20from = "now-45m"
21interval = "15m"
22license = "Elastic License v2"
23machine_learning_job_id = "problem_child_high_sum_by_host"
24name = "Suspicious Windows Process Cluster Spawned by a Host"
25references = [
26    "https://www.elastic.co/guide/en/security/current/prebuilt-ml-jobs.html",
27    "https://docs.elastic.co/en/integrations/problemchild",
28    "https://www.elastic.co/security-labs/detecting-living-off-the-land-attacks-with-new-elastic-integration",
29]
30risk_score = 21
31rule_id = "bdfebe11-e169-42e3-b344-c5d2015533d3"
32setup = """## Setup
33
34The rule requires the Living off the Land (LotL) Attack Detection integration assets to be installed, as well as Windows process events collected by integrations such as Elastic Defend or Winlogbeat.  
35
36### LotL Attack Detection Setup
37The LotL Attack Detection integration detects living-off-the-land activity in Windows process events.
38
39#### Prerequisite Requirements:
40- Fleet is required for LotL Attack Detection.
41- To configure Fleet Server refer to the [documentation](https://www.elastic.co/guide/en/fleet/current/fleet-server.html).
42- Windows process events collected by the [Elastic Defend](https://docs.elastic.co/en/integrations/endpoint) integration or Winlogbeat(https://www.elastic.co/guide/en/beats/winlogbeat/current/_winlogbeat_overview.html).
43- To install Elastic Defend, refer to the [documentation](https://www.elastic.co/guide/en/security/current/install-endpoint.html).
44- To set up and run Winlogbeat, follow [this](https://www.elastic.co/guide/en/beats/winlogbeat/current/winlogbeat-installation-configuration.html) guide.
45
46#### The following steps should be executed to install assets associated with the LotL Attack Detection integration:
47- Go to the Kibana homepage. Under Management, click Integrations.
48- In the query bar, search for Living off the Land Attack Detection and select the integration to see more details about it.
49- Follow the instructions under the **Installation** section.
50- For this rule to work, complete the instructions through **Add preconfigured anomaly detection jobs**.
51"""
52severity = "low"
53tags = [
54    "Use Case: Living off the Land Attack Detection",
55    "Rule Type: ML",
56    "Rule Type: Machine Learning",
57    "Tactic: Defense Evasion",
58]
59type = "machine_learning"
60[[rule.threat]]
61framework = "MITRE ATT&CK"
62[[rule.threat.technique]]
63id = "T1036"
64name = "Masquerading"
65reference = "https://attack.mitre.org/techniques/T1036/"
66
67
68[rule.threat.tactic]
69id = "TA0005"
70name = "Defense Evasion"
71reference = "https://attack.mitre.org/tactics/TA0005/"
...
toml

References

Related rules

to-top