The following dependencies are required for this project:
- Git
- CMake at least 3.22
- Make
- C++ compiler (GCC 10 or Clang 13, coroutines support needed)
- Zip (for vcpkg)
- Curl (for vcpkg)
- Tar (for vcpkg)
- Ninja-build (for vcpkg)
- Pkg-config
-
Installing Dependencies on Debian
To install the necessary dependencies on a Debian-based system, run the following commands:
sudo apt-get update sudo apt-get install cmake make gcc git zip curl tar ninja-build pkg-config wget gnupg lsb-release software-properties-common libbz2-dev libsystemd-dev wget https://apt.llvm.org/llvm.sh chmod +x llvm.sh sudo ./llvm.sh 18 sudo apt-get update sudo apt-get install -y clang-tidy-18 autopoint libtool zlib1g-dev libgcrypt20-dev libpopt-dev libmagic-dev libsqlite3-dev liblua5.4-dev gettext libarchive-dev
-
Clone the Repository
First, clone the repository using the following command:
git clone https://github.com/wazuh/wazuh-agent.git
-
Initialize Submodules
The project uses submodules, so you need to initialize and update them. Run the following commands:
cd wazuh-agent git submodule update --init --recursive
-
Configure and Build the Project
cmake src -B build cmake --build build
If you want to include tests, configure the project with the following command:
cmake src -B build -DBUILD_TESTS=1 cmake --build build
-
Run the Agent
To run the agent in the foreground from the CLI
You can start and get status with:
./wazuh-agent ./wazuh-agent --status
To run the agent as a systemd service
Copy the file
src/agent/service/wazuh-agent.service
to/usr/lib/systemd/system/
. Replace the placeholder WAZUH_HOME to your wazuh-agent executable directory. Reload unit files.systemctl daemon-reload
Enable service.
systemctl enable wazuh-agent
You can start and stop the agent, and get status from systemctl:
systemctl start wazuh-agent systemctl stop wazuh-agent systemctl is-active wazuh-agent systemctl status wazuh-agent
-
Run tests
If built with CMake and
-DBUILD_TESTS=1
, you can run tests with:ctest --test-dir build --output-log build
-
Install brew, a package manager for macOS
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
-
Install dependencies
brew install automake autoconf libtool cmake pkg-config openssl
-
Clone the Repository
Clone the repository:
git clone https://github.com/wazuh/wazuh-agent.git
-
Initialize Submodules
The project uses submodules, so you need to initialize and update them. Run the following commands:
cd wazuh-agent git submodule update --init --recursive
-
Configure and Build the Project
cmake src -B build cmake --build build
If you want to include tests, configure the project with the following command:
cmake src -B build -DBUILD_TESTS=1 cmake --build build
-
Run the Agent
To run the agent in the foreground from the CLI
You can start and get status with:
./wazuh-agent ./wazuh-agent --status
To run the agent as a launchd service
Copy the property list file
src/agent/service/com.wazuh.agent.plist
to/Library/LaunchDaemons/
. Edit the file and replace the placeholder path with your wazuh-agent executable directory as well as the working directory.sudo chown root:wheel /Library/LaunchDaemons/com.wazuh.agent.plist sudo chmod 644 /Library/LaunchDaemons/com.wazuh.agent.plist
Load the service
sudo launchctl bootstrap system /Library/LaunchDaemons/com.wazuh.agent.plist
This command has superseeded
load
in the legacy syntax. The daemon will run after load as indicated in the property list file.Unload the service
sudo launchctl bootout system /Library/LaunchDaemons/com.wazuh.agent.plist
This command has superseeded
unload
in the legacy syntax.Verify the service is running
sudo launchctl print system/com.wazuh.agent
-
Run tests
If built with CMake and
-DBUILD_TESTS=1
, you can run tests with:ctest --test-dir build --output-log build
-
Package Installation
If you wish to install a package use the following command.
sudo installer -pkg /path/to/package/package_filename.pkg -target /
Then load and manage the service as indicated in point 6 above. Skip the property list file copying and editing as well as the permissions part - the installer takes care of that.
- Installing Dependencies
- Visual Studio Community 2022 (with MSVC 14)
- Chocolatey
Set-ExecutionPolicy Bypass -Scope Process -Force; [System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; iex ((New-Object System.Net.WebClient).DownloadString('https://community.chocolatey.org/install.ps1'))
- Make
choco install make
- Cmake 3.30.x
choco install cmake --installargs 'ADD_CMAKE_TO_PATH=System'
- OpenSSL
choco install openssl
- Git
-
Clone the Repository
First, clone the repository using the following command:
git clone https://github.com/wazuh/wazuh-agent.git
-
Initialize Submodules
The project uses submodules, so you need to initialize and update them. Run the following commands:
cd wazuh-agent git submodule update --init --recursive
-
Configure and Build the Project
cmake src -B build -G "Visual Studio 17 2022" -A x64 cmake --build build
If you want to include tests, configure the project with the following command:
cmake src -B build -DBUILD_TESTS=1 -G "Visual Studio 17 2022" -A x64 cmake --build build --config RelWithDebInfo
-
Run the Agent
Install windows service
.\RelWithDebInfo\wazuh-agent --install-service
You can start, stop or restart the service from Windows SCM.
Or from the CLI
.\RelWithDebInfo\wazuh-agent .\RelWithDebInfo\wazuh-agent --status
To remove the service
.\RelWithDebInfo\wazuh-agent --remove-service
-
Run tests
If built with CMake and
-DBUILD_TESTS=1
, you can run tests with:ctest -C RelWithDebInfo --test-dir build --output-log build
Option | Description | Default |
---|---|---|
BUILD_TESTS |
Enable tests compilation | OFF |
COVERAGE |
Enable coverage report | OFF |
ENABLE_CLANG_TIDY |
Check code with clang-tidy | ON |
ENABLE_INVENTORY |
Enable Inventory module | ON |
ENABLE_LOGCOLLECTOR |
Enable Logcollector module | ON |
- The project uses
vcpkg
as a submodule to manage dependencies. By initializing the submodules,vcpkg
will automatically fetch the necessary dependencies when running CMake.