# Host Risk Score Host Risk Score is an experimental feature that assigns risk scores to hosts in a given Kibana space. Risk scores are calculated for each host by utilizing transforms on the alerting indices. The transform runs hourly to update the score as new detection rule alerts are generated. The Host Risk Score [package](https://github.com/elastic/detection-rules/releases) contains all of the required artifacts for setup. The Host Risk Score feature provides drilldown Lens dashboards and additional Kibana features such as the **Host Risk Score Card** on the Overview page of the Elastic Security app, and the **Host Risk Keyword** on the Alert details flyout for an enhanced experience. ### Notes - **Host name collision**: Hosts are identified by the `host.name` field in alerts. There may be some edge cases where different hosts use the same name. [details](#host-name-collision-details) ## Setup Instructions 1. [Obtain artifacts](#obtain-artifacts) 2. [Upload scripts](#upload-scripts) 3. [Upload ingest pipeline](#upload-ingest-pipeline) 4. [Upload and start the `pivot` transform](#upload-start-pivot) 5. [Create the Host Risk Score index](#host-risk-index) 6. [Upload and start the `latest` transform](#upload-start-latest) 7. [Import dashboards](#import-dashboards) 8. [Enable Kibana features](#enable-kibana)

1. Obtain artifacts

The Host Risk Score functionality is space aware for privacy. Downloaded artifacts must be modified with the desired space before they can be used. - Download the latest release [bundle](https://github.com/elastic/detection-rules/releases) with the tag `ML-HostRiskScore-YYYMMDD-N`. - Unzip the contents of `ML-HostRiskScore-YYYMMDD-N.zip`. - Run `ml_hostriskscore_generate_scripts.py` script in the unzipped directory with your Kibana space as the argument.
Example of modifying artifacts for the default space
python ml_hostriskscore_generate_scripts.py --space default
- Find a new folder named after your space in the unzipped directory. **You will be using the scripts within this directory for the next steps.**

2. Upload scripts

- Navigate to `Management / Dev Tools` in Kibana. - Upload the contents of `ml_hostriskscore_levels_script.json`, `ml_hostriskscore_map_script.json` and `ml_hostriskscore_reduce_script.json` using the Script API with the following syntax. - Ensure that your space name (such as `default`) replaces `` in the script names below.
uploading scripts

PUT _scripts/ml_hostriskscore_levels_script_<your-space-name>
{contents of ml_hostriskscore_levels_script.json file}

PUT _scripts/ml_hostriskscore_map_script_<your-space-name>
{contents of ml_hostriskscore_map_script.json file}

PUT _scripts/ml_hostriskscore_reduce_script_<your-space-name>
{contents of ml_hostriskscore_reduce_script.json file}

3. Upload ingest pipeline

- Upload the contents of `ml_hostriskscore_ingest_pipeline.json` using the Ingest API with the following syntax. - Ensure that your space name (such as `default`) replaces `` below.
uploading ingest pipeline
PUT _ingest/pipeline/ml_hostriskscore_ingest_pipeline_<your-space-name>
{contents of ml_hostriskscore_ingest_pipeline.json file}

4. Upload and start the pivot transform

This transform calculates the risk level every hour for each host in the Kibana space specified. - Upload the contents of `ml_hostriskscore_pivot_transform.json` using the Transform API with the following syntax. - Ensure that your space name (such as `default`) replaces `` below.
uploading pivot transform
PUT _transform/ml_hostriskscore_pivot_transform_<your-space-name>
{contents of ml_hostriskscore_pivot_transform.json file}
- Navigate to `Transforms` under `Management / Stack Management` in Kibana. Find the transform with the ID `ml_hostriskscore_pivot_transform_`. Open the `Actions` menu on the right side of the row, then click `Start`. - Confirm the transform is working as expected by navigating to `Management / Dev Tools` and ensuring the target index exists.
sample test query
GET ml_host_risk_score_<your-space-name>/_search

5. Create the Host Risk Score index

- Navigate to `Management / Dev Tools` in Kibana. - Create the Host Risk Score index (`ml_host_risk_score_latest_`) with the following mappings. - Ensure that your space name (such as `default`) replaces `` below.
creating the Host Risk Score index
PUT ml_host_risk_score_latest_<your-space-name>
{
  "mappings":{
    "properties":{
      "host.name":{
        "type":"keyword"
      }
    }
  }
}

6. Upload and start the latest transform

This transform recurringly calculates risk levels for all hosts in the Kibana space specified. - Upload the contents of `ml_hostriskscore_latest_transform.json` using the Transform API with the following syntax. - Ensure that your space name (such as `default`) replaces `` below.
uploading latest transform
PUT _transform/ml_hostriskscore_latest_transform_<your-space-name>
{contents of ml_hostriskscore_latest_transform.json file}
- Navigate to `Transforms` under `Management / Stack Management` in Kibana. Find the transform with the ID `ml_hostriskscore_latest_transform_`. Open the `Actions` menu on the right side of the row, and click `Start`. - Confirm the transform is working as expected by navigating to `Management / Dev Tools` and ensuring the target index exists. You should see documents starting to appear in the index if there is ongoing alerting activity associated with hosts.
sample test query
GET ml_host_risk_score_latest_<your-space-name>/_search

7. Import dashboards

- Navigate to `Management / Stack Management / Kibana / Saved Objects` in Kibana. - Click on `Import` and import the `ml_hostriskscore_dashboards.ndjson` file. - Navigate to `Analytics / Dashboard`. - Confirm you can see a dashboard named `Current Risk Scores for Hosts`, which displays the current list (Top 20) of suspicious hosts in your environment. - Confirm you can see a dashboard named `Drilldown of Host Risk Score`, which allows you to further drill down into details of the risk associated with a particular host of interest.

8. Enable Kibana features

There are two features in Kibana related to Host Risk Scoring. _Host Risk Score card on the Overview page_ ![Host Risk Score card](./images/0a_host_risk_score_card.png) _Host Risk Keyword on Alert Details Flyout_ ![Host Risk Keyword](./images/0b_alert_summary.png) To enable the _Host Risk Score card on the Overview page_, and the _Host Risk Keyword on Alert Details Flyout_, you will need to add the following configuration to `kibana.yml`. ``` xpack.securitySolution.enableExperimental: ['riskyHostsEnabled'] ``` #### Instructions to modify `kibana.yml` on Elastic Cloud 1. Navigate to your deployment on the cloud ![Navigate to deployment](./images/1_create_deployment.png) 2. Click on Kibana on the sidebar and click on Edit configuration on your Kibana instance ![Edit Kibana config](./images/2_edit_configuration.png) 3. Click on Edit user settings ![Edit user settings](./images/3_edit_user_settings.png) 4. Modify Kibana configuration by adding `xpack.securitySolution.enableExperimental: ['riskyHostsEnabled']` ![Modify Kibana configuration](./images/4_add_flag.png) 5. Save updated Kibana settings ![Save updated Kibana settings](./images/5_save_settings.png) 6. Confirm activity finished ![Confirm activity finished](./images/6_confirm_activity_finished.png) 7. View Host Risk Score Card on the Overview page ![Host Risk Score card](./images/0a_host_risk_score_card.png)
##### Host name collision details Physical Windows clients - desktops and laptops - in an Active Directory forest are unlikely to have name collisions, as their computer accounts and distinguished names should be unique. Non-domain member servers, desktops and laptops, in a Windows workgroup, may occasionally have name collisions. Macs are often not managed by a directory service and may have name collisions. Virtual servers, that are created from templates or cloning processes may have hostname collisions.