2023-11-22 13:24:03 +00:00
---
2023-12-10 10:54:12 +00:00
title: wazuh
2023-11-22 13:24:03 +00:00
---
< span class = "badge badge--secondary" > Support level: Community< / span >
## What is wazuh
2023-11-24 20:35:46 +00:00
> wazuh is an open source Security Information and Event Management System that also has (extended) Endpoint Detection & Response (XDR) capabilities, as well as components of a Network Intrusion & Detection System (NIDS).
2023-11-22 13:24:03 +00:00
>
> -- https://wazuh.com
:::note
We assume that you already have wazuh and authentik installed/setup and now want to integrate authentik as your IDP solution to have SSO within wazuh.
:::
## Preparation
The following placeholders will be used:
- `wazuh.company` is the FQDN of the wazuh server instance.
- `authentik.company` is the FQDN of the authentik install.
2023-11-24 20:35:46 +00:00
While wazuh allows both LDAP and SAML integration, in this post we will only walk through the SAML integration.
2023-11-22 13:24:03 +00:00
2023-11-24 17:23:36 +00:00
### Step 1 - certificates
2023-11-22 13:24:03 +00:00
The first step would be to add a certificate for wazuh.
2023-12-10 10:54:21 +00:00
You can generate a new one under **System** -> **Certificates** -> **Generate** in the Admin interface of authentik.
2023-11-22 13:24:03 +00:00
Add a name, set the validity period to 365 days and click `Generate`
![](./certificate.png)
If all goes well authentik will display a message like the one below
![](./certificate1.png)
2023-11-24 17:23:36 +00:00
### Step 2 - saml provider
2023-11-22 13:24:03 +00:00
Now add a SAML provider - you can find the options under `Applications` -> `Providers`
![](./provider.png)
Select SAML Provider and click Next
![](./provider1.png)
Add a descriptive name, select the appropriate Authentication/Authorization flow, adjust the ACS URL to contain the IP/hostname of your wazuh installation and add `/_opendistro/_security/saml/acs` to the end.
`https://<WAZUH_IP_OR_HOSTNAME>/_opendistro/_security/saml/acs`
2023-12-10 10:54:30 +00:00
Also make sure to give it an appropriate `EntityID` name (`issuer`), you will need that later and a valid option is e.g. `wazuh-saml`
2023-11-22 13:24:03 +00:00
Select `Post` as the `Service Provider Binding` and move on to the advanced protocol settings.
![](./provider2.png)
2023-11-24 20:35:46 +00:00
The last step is to select the previously created `Signing Certificate` from the dropdown list and leave the rest of the configurations as default for now.
2023-11-22 13:24:03 +00:00
![](./provider3.png)
![](./provider4.png)
![](./provider5.png)
2023-11-24 17:23:36 +00:00
### Step 3 - property mapping
2023-11-22 13:24:03 +00:00
2023-11-24 20:35:46 +00:00
Time to create a Property Mapping - this is a custom function that takes group/user data from authentik and provides it to wazuh in a structured way.
2023-11-22 13:24:03 +00:00
We will map a group membership - `wazuh-admins` - as a backend role for RBAC in wazuh using Property Mapping - `Customization` -> `Property Mappings`
`Name: wazuh property mapping`
`SAML Attribute Role: Roles`
![](./property-mapping.png)
![](./property-mapping2.png)
```python
if ak_is_group_member(request.user, name="wazuh-admins"):
yield "wazuh-admin"
```
Make sure to adjust the provider to include the newly created property mapping in the `Advanced protocol settings` .
![](./property-mapping3.png)
2023-11-24 17:23:36 +00:00
### Step 4 - saml application
2023-11-22 13:24:03 +00:00
2023-11-24 17:23:36 +00:00
Now create an application to use the newly created provider. `Applications` -> `Applications` -> `Create`
2023-11-22 13:24:03 +00:00
2023-11-24 17:23:36 +00:00
`Name: wazuh-saml`
`Slug: wazuh-saml`
2023-11-22 13:24:03 +00:00
`Provider: SAML`
`Policy Engine: any`
![](./application.png)
2023-11-24 20:35:46 +00:00
You can change the UI / upload a logo so that in the applications overview you have a nice layout and can easily identify the new wazuh app.
2023-11-24 17:23:36 +00:00
![](./applications_overview.png)
### Step 5 - metadata + wazuh opensearch-security configuration
2023-11-24 20:35:46 +00:00
2023-11-24 17:23:36 +00:00
Now download the metadata file `saml_authentik_meta.xml` from the `Applications` -> `Provider` -> `Related Objects` -> `Download`
and copy/save it on the wazuh server - ideally under `/etc/wazuh-indexer/opensearch-security/idp-metadata.xml`
![Alt text ](./metadata.png )
Next up change the `/etc/wazuh-indexer/opensearch-security/config.yml` and make sure it looks like the one below
2023-11-24 20:35:46 +00:00
- you need to adjust the `metadata_file` if your name differs from the one shown above/below
- `entity_id` needs to change twice, once in the `idp` section and once in the `sp` section - you can look it up in the metadata xml file - search for `entityID`
![Alt text ](entityid.png )
- adapt the `kibana_url` to match your wazuh dashboard url - e.g. `https://wazuh.myhomelab.com/`
- copy/paste the `exchange_key` , you can get it from the metadata file (find the key between the `<ds:X509Certificate></ds:X509Certificate>` tags, it usually starts with MII...) - DO NOT FORGET TO PUT QUOTES AROUND THE CERTIFICATE
- make sure to adjust the ownership and access rights via the following commands:
2023-11-24 17:23:36 +00:00
```bash
sudo chown wazuh-indexer:wazuh-indexer /etc/wazuh-indexer/opensearch-security/idp-metadata.xml
sudo chmod 640 /etc/wazuh-indexer/opensearch-security/idp-metadata.xml
```
```yml
authc:
basic_internal_auth_domain:
description: "Authenticate via HTTP Basic + SAML against internal users database"
http_enabled: true
transport_enabled: true b
order: 0
http_authenticator:
2023-11-24 20:35:46 +00:00
type: basic
2023-11-24 17:23:36 +00:00
challenge: false
authentication_backend:
2023-11-24 20:35:46 +00:00
type: intern
2023-11-24 17:23:36 +00:00
saml_auth_domain:
http_enabled: true
transport_enabled: false
order: 1
http_authenticator:
2023-11-24 20:35:46 +00:00
type: saml
2023-11-24 17:23:36 +00:00
challenge: true
2023-11-24 20:35:46 +00:00
config:
2023-11-24 17:23:36 +00:00
idp:
metadata_file: "/etc/wazuh-indexer/opensearch-security/idp-metadata.xml"
2023-11-24 20:35:46 +00:00
entity_id: "wazuh-saml"
2023-11-24 17:23:36 +00:00
sp:
entity_id: "wazuh-saml"
kibana_url: "https://< YOUR_WAZUH_IP_OR_HOSTNAME > "
roles_key: Roles
exchange_key: "MIIGIODCCA+ygAwIBAgITREIpdNn++usuy4Gq5g0W2/SQs..."
authentication_backend:
type: noop
```
### Step 6 - securityadmin.sh
After you save the `config.yml` you need to restart the wazuh manager and tell it to load the modified file - this can be done automagically using the `securityadmin.sh` wazuh provides with the following command:
```bash
export JAVA_HOME=/usr/share/wazuh-indexer/jdk/ & & bash /usr/share/wazuh-indexer/plugins/opensearch-security/tools/securityadmin.sh -f /etc/wazuh-indexer/opensearch-security/config.yml -icl -key /etc/wazuh-indexer/certs/admin-key.pem -cert /etc/wazuh-indexer/certs/admin.pem -cacert /etc/wazuh-indexer/certs/root-ca.pem -h localhost -nhnv
```
If all goes well this shows `Done with success` in the end
### Step 7 - roles_mapping.yml
In order to map the backend roles from authentik to wazuh specific roles you need to adjust the `/etc/wazuh-indexer/opensearch-security/roles_mapping.yml`
Open the file and scroll to the following section:
![Alt text ](roles_mapping.png )
under `backend_roles` add `wazuh-admin` and check that reserved is `false` + the rest looks like below:
```yml
all_access:
2023-11-24 20:35:46 +00:00
reserved: false
hidden: false
backend_roles:
- "wazuh-admin"
- "admin"
hosts: []
users: []
and_backend_roles: []
description: "Maps admin to all_access"
2023-11-24 17:23:36 +00:00
```
save the file and use the securityadmin.sh with the following command to load the adjusted `roles_mapping.yml` :
2023-11-24 20:35:46 +00:00
2023-11-24 17:23:36 +00:00
```bash
export JAVA_HOME=/usr/share/wazuh-indexer/jdk/ & & bash /usr/share/wazuh-indexer/plugins/opensearch-security/tools/securityadmin.sh -f /etc/wazuh-indexer/opensearch-security/roles_mapping.yml -icl -key /etc/wazuh-indexer/certs/admin-key.pem -cert /etc/wazuh-indexer/certs/admin.pem -cacert /etc/wazuh-indexer/certs/root-ca.pem -h localhost -nhnv
```
If all goes well this shows `Done with success` in the end
### Step 8 - wazuh.yml
2023-11-24 20:35:46 +00:00
2023-11-24 17:23:36 +00:00
Check `/usr/share/wazuh-dashboard/data/wazuh/config/wazuh.yml` and make sure that `run_as` is set to `false` .
![](wazuhyml.png)
### Step 9 - security role mapping
2023-11-24 20:35:46 +00:00
2023-12-10 10:54:36 +00:00
Open the wazuh dashboard, click on the downward pointing triangle next to the wazuh logo, and then click on **Security** and **Roles mapping** .
2023-11-24 17:23:36 +00:00
![](roles_mapping1.png)
2023-12-10 10:53:37 +00:00
We will now add a new role mapping. Give it any descriptive name and then add the respective Roles. In this case `administrator` is the name, and add a new custom rule at the bottom that matches (`FIND`) the `user_name` to `wazuh-admin` .
2023-11-24 17:23:36 +00:00
![](saml-admin.png)
### Step 10 - final step - opensearch_dashboards.yml
2023-12-10 10:53:55 +00:00
The last step is to modify `/etc/wazuh-dashboard/opensearch_dashboards.yml` and add three lines to the bottom of the file:
2023-11-24 17:23:36 +00:00
```yml
opensearch_security.auth.type: "saml"
2023-11-24 20:35:46 +00:00
server.xsrf.allowlist:
[
"/_opendistro/_security/saml/acs",
"/_opendistro/_security/saml/logout",
"/_opendistro/_security/saml/acs/idpinitiated",
]
2023-11-24 17:23:36 +00:00
opensearch_security.session.keepalive: false
```
![](dashboardsyml.png)
2023-11-24 20:35:46 +00:00
If all went well you should now only have to restart the wazuh dashboard
2023-11-24 17:23:36 +00:00
`systemctl restart wazuh-dashboard`
2023-12-10 10:54:01 +00:00
And then you should be greeted by the authentik login screen when you try to connect to the dashboard.
2023-11-24 20:35:46 +00:00
![](login.png)