To work with a specific client, search for it using the search bar at the top of the Admin GUI.
Click the button to see all clients or choose a preset search from the dropdown.
Or search using freeform text (simple wildcards are supported) or a structured search expression .
The search bar allows for freeform text searches but you can also perform searches using defined search operators and terms. The search bar provides autocompletion to guide your choices.
The following search operators are available:
all
: show all clientslabel
: search clients by labelhost
: search for hostnamesip
: search based on last known IP addressmac
: search based on recorded MAC addressesrecent
: show clients your user has recently interacted withIn addition, if you have configured indexing of selected client metadata fields then those field names will also be available as search operators.
The following search terms are recognized:
none
: currently only supported with the label
operator and used to return
unlabelled clients.Search patterns can utilize the wildcard symbol *
anywhere in the pattern. The
wildcard can occur more than once in a pattern. If specified on it’s own *
is
equivalent to the search operator all
, which is also the same as searching
with an empty search expression.
More complex searches can be done in a notebook using VQL.
The GUI’s search function uses a client info index. This provides performant
searches even when the server has many thousands of clients. The client info
index can also be queried via VQL using the
clients()
plugin which has a search
argument that accepts the same search syntax as
the GUI’s search bar, for example
SELECT client_id FROM clients(search="label:none")
.
However VQL also allows you to search client info fields that aren’t indexed and
apply more refined filtering using VQL constructs such as WHERE
clauses.
The recency (“freshness”) of the client info data is determined by how often
client interrogation
is run. By default this data is updated daily but the frequency of collection
can be changed in the client configuration file using the setting
Client.client_info_update_time
.
The search index on the server is rebuilt periodically to avoid inconsistencies.
By default this occurs every 5 minutes. The frequency of this process can be
configured in the server configuration file using the setting
defaults.reindex_period_seconds
.
The results from the search are shown as a paged table.
The table contains seven columns:
Client selection checkboxes. You can select one or more (or all) clients from the search results and then perform bulk operations on them. Once any clients are selected then the Label Clients, Delete Clients, and Kill Clients buttons will become available in the toolbar above the client list.
The online status of the host is shown as a color icon.
Clicking on the online status column header toggles the search between all clients and only those that are currently online.
The Client ID of the host. All clients have a unique ID starting with C.
.
The client ID is a unique identifier, unlike hostnames or other endpoint identifiers which have no guarantee of uniqueness and which may change over time. The client ID is derived from the client’s cryptographic key and is stored on the endpoint in the client writeback file. Clicking on the client id will take you to the client’s information screen and switch all client views to the selected client. The client indicator at the top-center of the screen shows you which client you currently have selected.
The Hostname reported by the client.
The Fully Qualified Domain Name (FQDN) reported by the client.
The Operating System version (OS Version) reported by the client.
Any Labels applied to the host. Clicking on a label removes the label from this host. Labels exist on the server only and are used for organizing clients, targeting hunts and other client management functions.
You might be wondering what happens if you delete active clients?
When you select one or more clients (using the selection checkboxes) and then delete them, this action deletes their records from the client info index and deletes any existing collections data associated with them from the datastore.
If the client is still active, or temporarily offline and later becomes active, the client will continue as though nothing happened. It’s old data will be gone due to the delete action but the client doesn’t know or care about data that it previously sent to the server. The client still has it’s Client ID.
The server will re-enroll the client and instruct the client to perform a new interrogation flow so that it’s client info record can be updated.
Once you select and view a particular client, as described in the next section, it will be automatically added to your Most Recently Used (MRU) list. The Recent Hosts search preset will show you the clients on this list.
Clicking on any Client ID in the search results will take you to the client’s Overview page and switch all client views to the currently selected client.
The client indicator at the top-center of the screen shows you which client you are currently working with.
Velociraptor maintains some basic information about the host, such as its hostname, labels, last seen IP, and last seen time. This is shown in the Overview and VQL Drilldown pages. Velociraptor gathers this information from the endpoint upon first enrollment and periodically thereafter through a process that we refer to as Interrogation . You can manually refresh this information at any time by clicking the Interrogate button.
Hosts may have labels attached to them. A label is any name associated with a host. Labels are useful when we need to hunt or perform other operations on a well defined group of hosts. We can restrict a hunt to one or more labels to avoid collecting unnecessary data or to target specific operating systems. Labels are explained here in more detail.
Each client can have associated arbitrary metadata. You can use this metadata in VQL, in Notebooks or in server artifacts. Client metadata is explained here in more detail.
The VQL Drilldown page shows more information about the client, including telemetry of the client’s footprint on the endpoint and more information about the endpoint.
The Shell page allows you to run shell commands on the client. This is explained here in more detail.
You can quarantine a host using the Quarantine Host () button.
Quarantining a host will reconfigure the hosts’s network stack to only allow it to communicate with the Velociraptor server. This allows you to continue investigating the host remotely while preventing the host from making other network connections. Client Quarantine is explained here in more detail.
With a client selected we can browse it’s filesystem using the Virtual FileSystem (VFS) viewer. The VFS is explained here in more detail.
The Collected button on the Overview page will take you to the client’s Collections page where you can schedule new Artifact collections for that client, or view the status and results of previously run collections.