Documentation Index
Fetch the complete documentation index at: https://bloodhound.specterops.io/llms.txt
Use this file to discover all available pages before exploring further.
Extension metadata identifying the extension, including version and namespace.
Defines custom node types and their visual representations for an extension.
Defines custom edge types and their traversability behavior for an extension.
Defines the environments for a platform and identifies which node kinds an extension treats as principals within each environment.BloodHound Enterprise uses these environment definitions to group analysis, findings, and metrics.
Defines the findings and remediation guidance BloodHound Enterprise uses when relationships of the specified kind represent potential Attack Paths in a target environment (based on Privilege Zone rules).
Namespacing
BloodHound uses namespaces to organize graph data. Each extension has a namespace key, which is used as a prefix in relevantname fields to indicate that the data belongs to that namespace. Namespacing allows multiple extensions to define similar graph data without conflicts, because the namespace prefix makes each name unique.
With the exception of schema.name, all name fields must follow these namespacing rules to avoid collisions with built-in graph elements and other extensions. This does not apply to display_name fields, which are used only for human-readable labels.
- Must be unique within the extension
- Must be prefixed with the extension’s namespace separated by an underscore (for example,
namespace_Name) - Must include more than just the namespace prefix
schema.name field does not use a namespace prefix, it must still be unique for each extension. BloodHound treats extensions with matching schema.name fields as the same extension and overwrites existing extension definition schemas when uploaded.
Findings and metrics
This is a SpecterOps-managed feature. If it is not enabled in your environment, contact your account team for assistance.
| Field | Where | Requirement |
|---|---|---|
environment_kind | Extension definition schema | Must match the environment node kind defined in the node_kinds.name field.If a relationship-based finding exists for the environment, relationship_findings.environment_kind must also match. |
source_kind | Data payload | Must be present on nodes for them to be included in findings and metrics. |
environmentid | Data payload | For nodes that belong to an environment, must be set to the graph.nodes.id of that environment node.That environment’s node kind must match the node_kinds.name with the corresponding environments.environment_kind definition. |
collected | Data payload | Must be set to true on nodes with an environment kind to indicate that data has actually been collected for that environment.For example, your payload might include multiple environment nodes, but only nodes for environments with successfully collected data should have collected: true. |
Users must also create Privilege Zone rules after installing an extension and prior to uploading a data payload to see findings in BloodHound Enterprise.
schema
Defines metadata about the extension itself.
Unique name that identifies an extension in BloodHound.
Human-readable label shown for this extension in BloodHound.
Extension schema version in semantic version format, for example
v1.0.0.Namespace key used as a prefix for all
name fields in the node_kinds, relationship_kinds, and relationship_findings arrays to indicate that the data belongs to that namespace.node_kinds
Defines all node types in your extension. Each node kind represents an entity type (for example: user, device, or environment).
Unique node kind identifier. Must follow namespacing rules. For each node in a data payload to be included in a structured graph, at least one value in its
kinds array must match a node_kinds.name defined in the extension definition schema.The node schema for an environment must be defined here to be used for findings and metrics in BloodHound Enterprise.Human-readable label shown for this node kind in BloodHound.
Optional description that explains what the node kind represents.
Determines whether to use the
icon and color definitions for nodes of this kind in the graph.Optional Font Awesome icon name (without the “fa-” prefix) to show for nodes of this kind in the graph.
Optional Hex color code (in
#RGB or #RRGGBB format, the # is required) to apply to nodes of this kind in the graph.relationship_kinds
Defines what kind of connections exist. Each relationship kind represents a specific type of connection that can exist between nodes.
Unique relationship kind identifier. Must follow namespacing rules. For each edge in a data payload to be included in a structured graph,
kind must match a relationship_kinds.name defined in the extension definition schema.Optional description of what the relationship means.
Controls whether edges of this relationship kind are used for pathfinding and Attack Path detection.When
is_traversable is set to true on a relationship kind, all edges of that kind inherit the same traversability behavior. Only are included in pathfinding and considered for findings and metrics.environments
Represents which node type within the extension is considered an environment for organizational and analytics purposes. Must match a node kind defined in the
node_kinds array.For findings and metrics in BloodHound Enterprise, the graph.nodes.properties.environmentid field for applicable nodes in the data payload must match this field.Source kind that associates this environment definition with a specific platform for environment organization and selection. See Data source for details.
Node kinds defined by this extension/schema that BloodHound should treat as . Must match a
node_kinds.name defined in this schema.BloodHound Enterprise incorporates these node kinds in findings and metrics.relationship_findings
Unique finding identifier. Must follow namespacing rules and be unique across all schema definition names, including node kinds, relationship kinds, and findings.
Human-readable label shown for this finding in BloodHound.
Environment kind where this finding should be evaluated. Must match an
environments.environment_kind and node_kinds.name defined in any installed extension definition schema.For intra-extension findings, this typically matches the environment kind defined by the same extension schema. For cross-platform findings (for example, hybrid relationships), the impacted environment kind may be different.Relationship kind that contributes to this finding when matching edges are present and the edge crosses a Privilege Zone boundary. Must match a
relationship_kinds.name defined in any installed extension definition schema.Remediation guidance to resolve the finding, including both short and long forms.
A concise summary of the recommended remediation action.
A detailed explanation of the finding and its cause, which can include Markdown formatting for better readability.
A concise summary of the steps to remediate the finding.
A detailed, step-by-step guide to remediate the finding, which can include Markdown formatting for better readability.