mirror of
				https://github.com/wazuh/wazuh-docker.git
				synced 2025-11-03 21:43:15 +00:00 
			
		
		
		
	Compare commits
	
		
			184 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					cb63566719 | ||
| 
						 | 
					282440d00e | ||
| 
						 | 
					898d86ff0e | ||
| 
						 | 
					8f0af0c87f | ||
| 
						 | 
					8b84f7f299 | ||
| 
						 | 
					999d01f48a | ||
| 
						 | 
					bd758935e7 | ||
| 
						 | 
					0e284a2309 | ||
| 
						 | 
					b597e1cecc | ||
| 
						 | 
					247a6b0375 | ||
| 
						 | 
					879a10cc9f | ||
| 
						 | 
					0fef2182eb | ||
| 
						 | 
					7b00fb8f73 | ||
| 
						 | 
					cdbc5485b4 | ||
| 
						 | 
					6249cb8f30 | ||
| 
						 | 
					7fe9ba2e19 | ||
| 
						 | 
					996c593242 | ||
| 
						 | 
					1916f4166a | ||
| 
						 | 
					36bdb5fedb | ||
| 
						 | 
					15a856dc32 | ||
| 
						 | 
					1486b5942c | ||
| 
						 | 
					25319ee004 | ||
| 
						 | 
					f47ca7fbc0 | ||
| 
						 | 
					5ef94b819c | ||
| 
						 | 
					e77ceb6ad6 | ||
| 
						 | 
					127e74296a | ||
| 
						 | 
					0aa63db271 | ||
| 
						 | 
					583f75176d | ||
| 
						 | 
					11d2c84203 | ||
| 
						 | 
					2e52ebd7b7 | ||
| 
						 | 
					4223b44f3f | ||
| 
						 | 
					3fc48bec11 | ||
| 
						 | 
					56750a07f2 | ||
| 
						 | 
					b362e0774b | ||
| 
						 | 
					d11e421cdd | ||
| 
						 | 
					99c163f4e5 | ||
| 
						 | 
					acc3c22bed | ||
| 
						 | 
					6eb435a82f | ||
| 
						 | 
					ac760dbb14 | ||
| 
						 | 
					2adb0cc46d | ||
| 
						 | 
					ca6cc555f2 | ||
| 
						 | 
					eca65a8538 | ||
| 
						 | 
					a063b27592 | ||
| 
						 | 
					bc2a446c17 | ||
| 
						 | 
					80b7c047ec | ||
| 
						 | 
					4b0818bc2c | ||
| 
						 | 
					28c051a05e | ||
| 
						 | 
					1f0f98ddaa | ||
| 
						 | 
					bc35a25b3b | ||
| 
						 | 
					0399e7b16a | ||
| 
						 | 
					f38bc64415 | ||
| 
						 | 
					2ee7cfa515 | ||
| 
						 | 
					78cb2fc571 | ||
| 
						 | 
					6f49d17696 | ||
| 
						 | 
					f0c56d6da2 | ||
| 
						 | 
					e86fbd6791 | ||
| 
						 | 
					3e120aee77 | ||
| 
						 | 
					e10fd22fcc | ||
| 
						 | 
					4c3a6696f6 | ||
| 
						 | 
					5ed2095854 | ||
| 
						 | 
					f3474a392e | ||
| 
						 | 
					62fc011c2c | ||
| 
						 | 
					bdce114251 | ||
| 
						 | 
					0a440c0433 | ||
| 
						 | 
					311ffc72d8 | ||
| 
						 | 
					65fe95472b | ||
| 
						 | 
					21e1943cab | ||
| 
						 | 
					4a2d9b54d3 | ||
| 
						 | 
					3f320be95d | ||
| 
						 | 
					5712d37a7a | ||
| 
						 | 
					5d5cc9d30a | ||
| 
						 | 
					956d42e932 | ||
| 
						 | 
					1e70aad5f8 | ||
| 
						 | 
					09841ba9e4 | ||
| 
						 | 
					c014ea77f4 | ||
| 
						 | 
					12d8e8f122 | ||
| 
						 | 
					fe327f10a3 | ||
| 
						 | 
					5063213d39 | ||
| 
						 | 
					dca7f9382e | ||
| 
						 | 
					577e533958 | ||
| 
						 | 
					98930a6708 | ||
| 
						 | 
					f08a3cf64d | ||
| 
						 | 
					8cf7909bc0 | ||
| 
						 | 
					0c57402b94 | ||
| 
						 | 
					1e261c165e | ||
| 
						 | 
					b60e875962 | ||
| 
						 | 
					693b9d9c23 | ||
| 
						 | 
					a275a08cfe | ||
| 
						 | 
					2709a8e457 | ||
| 
						 | 
					0682effeca | ||
| 
						 | 
					c248592d39 | ||
| 
						 | 
					6049aec381 | ||
| 
						 | 
					ad6a08c2b0 | ||
| 
						 | 
					a583069698 | ||
| 
						 | 
					a67c407bfe | ||
| 
						 | 
					6138516ad9 | ||
| 
						 | 
					665f6fd84a | ||
| 
						 | 
					2487a5481e | ||
| 
						 | 
					8cb7da82df | ||
| 
						 | 
					91513bda93 | ||
| 
						 | 
					6b62f1c738 | ||
| 
						 | 
					7257ddc0aa | ||
| 
						 | 
					bdd919fc48 | ||
| 
						 | 
					3112eb2bd5 | ||
| 
						 | 
					e9ed0d1d31 | ||
| 
						 | 
					ed9b2f0d39 | ||
| 
						 | 
					24f12a72d7 | ||
| 
						 | 
					faddbe4af4 | ||
| 
						 | 
					f4596dc833 | ||
| 
						 | 
					78006fc5bd | ||
| 
						 | 
					956be62183 | ||
| 
						 | 
					60d6fb8b98 | ||
| 
						 | 
					2b10eff949 | ||
| 
						 | 
					3398c9f2b3 | ||
| 
						 | 
					0763499562 | ||
| 
						 | 
					88842eede8 | ||
| 
						 | 
					ef4f28a0c1 | ||
| 
						 | 
					79cdec2032 | ||
| 
						 | 
					ec68bd1049 | ||
| 
						 | 
					0650c53e47 | ||
| 
						 | 
					3dfb3505a2 | ||
| 
						 | 
					f8b2399347 | ||
| 
						 | 
					9d710e182d | ||
| 
						 | 
					d59ee1bd35 | ||
| 
						 | 
					b022f9f5c1 | ||
| 
						 | 
					390a71ebea | ||
| 
						 | 
					6afcc00ba7 | ||
| 
						 | 
					b13aef91d1 | ||
| 
						 | 
					b61953cc35 | ||
| 
						 | 
					4b98b24999 | ||
| 
						 | 
					1fea52d4d0 | ||
| 
						 | 
					97ba114f8e | ||
| 
						 | 
					12653111bd | ||
| 
						 | 
					e03cfde3bc | ||
| 
						 | 
					654d1dbf36 | ||
| 
						 | 
					219843dbb8 | ||
| 
						 | 
					92eef99c13 | ||
| 
						 | 
					f5b237458a | ||
| 
						 | 
					04c64e78bc | ||
| 
						 | 
					8d9d04adc5 | ||
| 
						 | 
					1e8db5cfbd | ||
| 
						 | 
					59e0ec54bd | ||
| 
						 | 
					8f3478361d | ||
| 
						 | 
					6a242a36ce | ||
| 
						 | 
					520291162f | ||
| 
						 | 
					63217770f7 | ||
| 
						 | 
					91a56eb429 | ||
| 
						 | 
					c99985f479 | ||
| 
						 | 
					a6d0a1ffeb | ||
| 
						 | 
					f746e96b74 | ||
| 
						 | 
					43ecb7f623 | ||
| 
						 | 
					0567dd1632 | ||
| 
						 | 
					6ef6883b8a | ||
| 
						 | 
					41b25fe60f | ||
| 
						 | 
					a89eddb135 | ||
| 
						 | 
					284b945cd8 | ||
| 
						 | 
					f1978f4b88 | ||
| 
						 | 
					b6ebf179db | ||
| 
						 | 
					086b24c490 | ||
| 
						 | 
					4e8569009e | ||
| 
						 | 
					32809c9c52 | ||
| 
						 | 
					64ab19be1a | ||
| 
						 | 
					27888e0b83 | ||
| 
						 | 
					5791218f83 | ||
| 
						 | 
					cc05d1a251 | ||
| 
						 | 
					81b0172b37 | ||
| 
						 | 
					4c82d16144 | ||
| 
						 | 
					e756c20053 | ||
| 
						 | 
					0ef3428788 | ||
| 
						 | 
					52ddc7607f | ||
| 
						 | 
					957de01c8f | ||
| 
						 | 
					45ca9a1b37 | ||
| 
						 | 
					8002f2d402 | ||
| 
						 | 
					dc167c2316 | ||
| 
						 | 
					6591e7e4a1 | ||
| 
						 | 
					a97c14e807 | ||
| 
						 | 
					49bc23682f | ||
| 
						 | 
					122acb404d | ||
| 
						 | 
					efac96b011 | ||
| 
						 | 
					ee9fdc383a | ||
| 
						 | 
					103c7e66df | ||
| 
						 | 
					8aef2921d9 | ||
| 
						 | 
					0d66cfbd5a | ||
| 
						 | 
					77c18adce5 | 
							
								
								
									
										6
									
								
								.env
									
									
									
									
									
								
							
							
						
						
									
										6
									
								
								.env
									
									
									
									
									
								
							@@ -1,6 +1,6 @@
 | 
			
		||||
WAZUH_VERSION=4.8.0
 | 
			
		||||
WAZUH_IMAGE_VERSION=4.8.0
 | 
			
		||||
WAZUH_VERSION=4.9.0
 | 
			
		||||
WAZUH_IMAGE_VERSION=4.9.0
 | 
			
		||||
WAZUH_TAG_REVISION=1
 | 
			
		||||
FILEBEAT_TEMPLATE_BRANCH=4.8.0
 | 
			
		||||
FILEBEAT_TEMPLATE_BRANCH=4.9.0
 | 
			
		||||
WAZUH_FILEBEAT_MODULE=wazuh-filebeat-0.4.tar.gz
 | 
			
		||||
WAZUH_UI_REVISION=1
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										2
									
								
								.github/.goss.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/.goss.yaml
									
									
									
									
										vendored
									
									
								
							@@ -56,7 +56,7 @@ package:
 | 
			
		||||
  wazuh-manager:
 | 
			
		||||
    installed: true
 | 
			
		||||
    versions:
 | 
			
		||||
    - 4.8.0-1
 | 
			
		||||
    - 4.9.0
 | 
			
		||||
port:
 | 
			
		||||
  tcp:1514:
 | 
			
		||||
    listening: true
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										19
									
								
								.github/workflows/push.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										19
									
								
								.github/workflows/push.yml
									
									
									
									
										vendored
									
									
								
							@@ -10,6 +10,11 @@ jobs:
 | 
			
		||||
    - name: Check out code
 | 
			
		||||
      uses: actions/checkout@v3
 | 
			
		||||
 | 
			
		||||
    - name: Install docker-compose
 | 
			
		||||
      run: |
 | 
			
		||||
        curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
 | 
			
		||||
        chmod +x /usr/local/bin/docker-compose
 | 
			
		||||
 | 
			
		||||
    - name: Build Wazuh images
 | 
			
		||||
      run: build-docker-images/build-images.sh
 | 
			
		||||
 | 
			
		||||
@@ -63,6 +68,11 @@ jobs:
 | 
			
		||||
    - name: Check out code
 | 
			
		||||
      uses: actions/checkout@v3
 | 
			
		||||
 | 
			
		||||
    - name: Install docker-compose
 | 
			
		||||
      run: |
 | 
			
		||||
        curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
 | 
			
		||||
        chmod +x /usr/local/bin/docker-compose
 | 
			
		||||
 | 
			
		||||
    - name: Create enviroment variables
 | 
			
		||||
      run: cat .env > $GITHUB_ENV
 | 
			
		||||
 | 
			
		||||
@@ -186,6 +196,11 @@ jobs:
 | 
			
		||||
    - name: Check out code
 | 
			
		||||
      uses: actions/checkout@v3
 | 
			
		||||
 | 
			
		||||
    - name: Install docker-compose
 | 
			
		||||
      run: |
 | 
			
		||||
        curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
 | 
			
		||||
        chmod +x /usr/local/bin/docker-compose
 | 
			
		||||
 | 
			
		||||
    - name: Create enviroment variables
 | 
			
		||||
      run: cat .env > $GITHUB_ENV
 | 
			
		||||
 | 
			
		||||
@@ -232,7 +247,7 @@ jobs:
 | 
			
		||||
         echo 'Waiting for Wazuh indexer start'
 | 
			
		||||
         free -m
 | 
			
		||||
         df -h
 | 
			
		||||
         sleep 10
 | 
			
		||||
         sleep 120
 | 
			
		||||
       done
 | 
			
		||||
       status_green="`curl -XGET "https://0.0.0.0:9200/_cluster/health" -u admin:SecretPassword -k -s | grep green | wc -l`"
 | 
			
		||||
       if [[ $status_green -eq 1 ]]; then
 | 
			
		||||
@@ -270,7 +285,7 @@ jobs:
 | 
			
		||||
         sleep 10
 | 
			
		||||
       done
 | 
			
		||||
       docs="`curl -XGET "https://0.0.0.0:9200/wazuh-alerts*/_count" -u admin:SecretPassword -k -s | jq -r ".count"`"
 | 
			
		||||
       if [[ $docs -gt 1 ]]; then
 | 
			
		||||
       if [[ $docs -gt 0 ]]; then
 | 
			
		||||
        echo "wazuh-alerts index documents: ${docs}"
 | 
			
		||||
       else
 | 
			
		||||
        echo "wazuh-alerts index documents: ${docs}"
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										15
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								CHANGELOG.md
									
									
									
									
									
								
							@@ -1,6 +1,21 @@
 | 
			
		||||
# Change Log
 | 
			
		||||
All notable changes to this project will be documented in this file.
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v4.9.0
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update Wazuh to version [4.9.0](https://github.com/wazuh/wazuh/blob/v4.9.0/CHANGELOG.md#v490)
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v4.8.2
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update Wazuh to version [4.8.2](https://github.com/wazuh/wazuh/blob/v4.8.2/CHANGELOG.md#v482)
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v4.8.1
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update Wazuh to version [4.8.1](https://github.com/wazuh/wazuh/blob/v4.8.1/CHANGELOG.md#v481)
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v4.8.0
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										71
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										71
									
								
								README.md
									
									
									
									
									
								
							@@ -8,19 +8,19 @@
 | 
			
		||||
In this repository you will find the containers to run:
 | 
			
		||||
 | 
			
		||||
* Wazuh manager: it runs the Wazuh manager, Wazuh API and Filebeat OSS
 | 
			
		||||
* Wazuh dashboard: provides a web user interface to browse through alerts data and allows you to visualize agents configuration and status.
 | 
			
		||||
* Wazuh dashboard: provides a web user interface to browse through alert data and allows you to visualize the agents configuration and status.
 | 
			
		||||
* Wazuh indexer: Wazuh indexer container (working as a single-node cluster or as a multi-node cluster). **Be aware to increase the `vm.max_map_count` setting, as it's detailed in the [Wazuh documentation](https://documentation.wazuh.com/current/docker/wazuh-container.html#increase-max-map-count-on-your-host-linux).**
 | 
			
		||||
 | 
			
		||||
The folder `build-docker-images` contains a README explaining how to build the Wazuh images and the necessary assets.
 | 
			
		||||
The folder `indexer-certs-creator` contains a README explaining how to create the certificates creator tool and the necessary assets.
 | 
			
		||||
The folder `single-node` contains a README explaining how to run a Wazuh environment with one Wazuh manager, one Wazuh indexer, and one Wazuh dashboard.
 | 
			
		||||
The folder `multi-node` contains a README explaining how to run a Wazuh environment with two Wazuh managers, three Wazuh indexer, and one Wazuh dashboard.
 | 
			
		||||
The folder `multi-node` contains a README explaining how to run a Wazuh environment with two Wazuh managers, three Wazuh indexers, and one Wazuh dashboard.
 | 
			
		||||
 | 
			
		||||
## Documentation
 | 
			
		||||
 | 
			
		||||
* [Wazuh full documentation](http://documentation.wazuh.com)
 | 
			
		||||
* [Wazuh documentation for Docker](https://documentation.wazuh.com/current/docker/index.html)
 | 
			
		||||
* [Docker hub](https://hub.docker.com/u/wazuh)
 | 
			
		||||
* [Docker Hub](https://hub.docker.com/u/wazuh)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
### Setup SSL certificate
 | 
			
		||||
@@ -38,7 +38,7 @@ Default values are included when available.
 | 
			
		||||
```
 | 
			
		||||
API_USERNAME="wazuh-wui"                            # Wazuh API username
 | 
			
		||||
API_PASSWORD="MyS3cr37P450r.*-"                     # Wazuh API password - Must comply with requirements
 | 
			
		||||
                                                    # (8+ length, uppercase, lowercase, specials chars)
 | 
			
		||||
                                                    # (8+ length, uppercase, lowercase, special chars)
 | 
			
		||||
 | 
			
		||||
INDEXER_URL=https://wazuh.indexer:9200              # Wazuh indexer URL
 | 
			
		||||
INDEXER_USERNAME=admin                              # Wazuh indexer Username
 | 
			
		||||
@@ -53,8 +53,8 @@ SSL_KEY=""                                          # Path of Filebeat SSL Key
 | 
			
		||||
```
 | 
			
		||||
PATTERN="wazuh-alerts-*"        # Default index pattern to use
 | 
			
		||||
 | 
			
		||||
CHECKS_PATTERN=true             # Defines which checks must to be consider by the healthcheck
 | 
			
		||||
CHECKS_TEMPLATE=true            # step once the Wazuh app starts. Values must to be true or false
 | 
			
		||||
CHECKS_PATTERN=true             # Defines which checks must be considered by the healthcheck
 | 
			
		||||
CHECKS_TEMPLATE=true            # step once the Wazuh app starts. Values must be true or false
 | 
			
		||||
CHECKS_API=true
 | 
			
		||||
CHECKS_SETUP=true
 | 
			
		||||
 | 
			
		||||
@@ -89,19 +89,23 @@ WAZUH_MONITORING_REPLICAS=0         ##
 | 
			
		||||
## Directory structure
 | 
			
		||||
 | 
			
		||||
    ├── build-docker-images
 | 
			
		||||
    │   ├── docker-compose.yml
 | 
			
		||||
    │   ├── build-images.sh
 | 
			
		||||
    │   ├── build-images.yml
 | 
			
		||||
    │   ├── README.md
 | 
			
		||||
    │   ├── wazuh-dashboard
 | 
			
		||||
    │   │   ├── config
 | 
			
		||||
    │   │   │   ├── config.sh
 | 
			
		||||
    │   │   │   ├── config.yml
 | 
			
		||||
    │   │   │   ├── dl_base.sh
 | 
			
		||||
    │   │   │   ├── entrypoint.sh
 | 
			
		||||
    │   │   │   ├── install_wazuh_app.sh
 | 
			
		||||
    │   │   │   ├── opensearch_dashboards.yml
 | 
			
		||||
    │   │   │   ├── wazuh_app_config.sh
 | 
			
		||||
    │   │   │   └── wazuh.yml
 | 
			
		||||
    │   │   └── Dockerfile
 | 
			
		||||
    │   ├── wazuh-indexer
 | 
			
		||||
    │   │   ├── config
 | 
			
		||||
    │   │   │   ├── action_groups.yml
 | 
			
		||||
    │   │   │   ├── action_groups.yml
 | 
			
		||||
    │   │   │   ├── config.sh
 | 
			
		||||
    │   │   │   ├── config.yml
 | 
			
		||||
    │   │   │   ├── entrypoint.sh
 | 
			
		||||
@@ -113,6 +117,7 @@ WAZUH_MONITORING_REPLICAS=0         ##
 | 
			
		||||
    │   │   └── Dockerfile
 | 
			
		||||
    │   └── wazuh-manager
 | 
			
		||||
    │       ├── config
 | 
			
		||||
    │       │   ├── check_repository.sh
 | 
			
		||||
    │       │   ├── create_user.py
 | 
			
		||||
    │       │   ├── etc
 | 
			
		||||
    │       │   │   ├── cont-init.d
 | 
			
		||||
@@ -125,19 +130,21 @@ WAZUH_MONITORING_REPLICAS=0         ##
 | 
			
		||||
    │       │   │       │   └── run
 | 
			
		||||
    │       │   │       └── ossec-logs
 | 
			
		||||
    │       │   │           └── run
 | 
			
		||||
    │       │   ├── filebeat_module.sh
 | 
			
		||||
    │       │   ├── filebeat.yml
 | 
			
		||||
    │       │   ├── permanent_data.env
 | 
			
		||||
    │       │   ├── permanent_data.sh
 | 
			
		||||
    │       │   └── wazuh.repo
 | 
			
		||||
    │       │   └── permanent_data.sh
 | 
			
		||||
    │       └── Dockerfile
 | 
			
		||||
    ├── CHANGELOG.md
 | 
			
		||||
    ├── indexer-certs-creator
 | 
			
		||||
    │   ├── config
 | 
			
		||||
    │   │   └── entrypoint.sh
 | 
			
		||||
    │   └── Dockerfile
 | 
			
		||||
    │   ├── Dockerfile
 | 
			
		||||
    │   └── README.md
 | 
			
		||||
    ├── LICENSE
 | 
			
		||||
    ├── multi-node
 | 
			
		||||
    │   ├── config
 | 
			
		||||
    │   │   ├── certs.yml
 | 
			
		||||
    │   │   ├── nginx
 | 
			
		||||
    │   │   │   └── nginx.conf
 | 
			
		||||
    │   │   ├── wazuh_cluster
 | 
			
		||||
@@ -146,40 +153,29 @@ WAZUH_MONITORING_REPLICAS=0         ##
 | 
			
		||||
    │   │   ├── wazuh_dashboard
 | 
			
		||||
    │   │   │   ├── opensearch_dashboards.yml
 | 
			
		||||
    │   │   │   └── wazuh.yml
 | 
			
		||||
    │   │   ├── wazuh_indexer
 | 
			
		||||
    │   │   │   ├── internal_users.yml
 | 
			
		||||
    │   │   │   ├── wazuh1.indexer.yml
 | 
			
		||||
    │   │   │   ├── wazuh2.indexer.yml
 | 
			
		||||
    │   │   │   └── wazuh3.indexer.yml
 | 
			
		||||
    │   │   └── wazuh_indexer_ssl_certs
 | 
			
		||||
    │   │       └── certs.yml
 | 
			
		||||
    │   │   └── wazuh_indexer
 | 
			
		||||
    │   │       ├── internal_users.yml
 | 
			
		||||
    │   │       ├── wazuh1.indexer.yml
 | 
			
		||||
    │   │       ├── wazuh2.indexer.yml
 | 
			
		||||
    │   │       └── wazuh3.indexer.yml
 | 
			
		||||
    │   ├── docker-compose.yml
 | 
			
		||||
    │   ├── generate-indexer-certs.yml
 | 
			
		||||
    │   ├── Migration-to-Wazuh-4.3.md
 | 
			
		||||
    │   ├── Migration-to-Wazuh-4.4.md
 | 
			
		||||
    │   ├── README.md
 | 
			
		||||
    │   └── volume-migrator.sh
 | 
			
		||||
    ├── README.md
 | 
			
		||||
    ├── SECURITY.md
 | 
			
		||||
    ├── single-node
 | 
			
		||||
    │   ├── config
 | 
			
		||||
    │   │   ├── certs.yml
 | 
			
		||||
    │   │   ├── wazuh_cluster
 | 
			
		||||
    │   │   │   └── wazuh_manager.conf
 | 
			
		||||
    │   │   ├── wazuh_dashboard
 | 
			
		||||
    │   │   │   ├── opensearch_dashboards.yml
 | 
			
		||||
    │   │   │   └── wazuh.yml
 | 
			
		||||
    │   │   ├── wazuh_indexer
 | 
			
		||||
    │   │   │   ├── internal_users.yml
 | 
			
		||||
    │   │   │   └── wazuh.indexer.yml
 | 
			
		||||
    │   │   └── wazuh_indexer_ssl_certs
 | 
			
		||||
    │   │       ├── admin-key.pem
 | 
			
		||||
    │   │       ├── admin.pem
 | 
			
		||||
    │   │       ├── certs.yml
 | 
			
		||||
    │   │       ├── root-ca.key
 | 
			
		||||
    │   │       ├── root-ca.pem
 | 
			
		||||
    │   │       ├── wazuh.dashboard-key.pem
 | 
			
		||||
    │   │       ├── wazuh.dashboard.pem
 | 
			
		||||
    │   │       ├── wazuh.indexer-key.pem
 | 
			
		||||
    │   │       ├── wazuh.indexer.pem
 | 
			
		||||
    │   │       ├── wazuh.manager-key.pem
 | 
			
		||||
    │   │       └── wazuh.manager.pem
 | 
			
		||||
    │   │   └── wazuh_indexer
 | 
			
		||||
    │   │       ├── internal_users.yml
 | 
			
		||||
    │   │       └── wazuh.indexer.yml
 | 
			
		||||
    │   ├── docker-compose.yml
 | 
			
		||||
    │   ├── generate-indexer-certs.yml
 | 
			
		||||
    │   └── README.md
 | 
			
		||||
@@ -190,12 +186,15 @@ WAZUH_MONITORING_REPLICAS=0         ##
 | 
			
		||||
## Branches
 | 
			
		||||
 | 
			
		||||
* `master` branch contains the latest code, be aware of possible bugs on this branch.
 | 
			
		||||
* `stable` branch on correspond to the last Wazuh stable version.
 | 
			
		||||
* `stable` branch corresponds to the last Wazuh stable version.
 | 
			
		||||
 | 
			
		||||
## Compatibility Matrix
 | 
			
		||||
 | 
			
		||||
| Wazuh version | ODFE    | XPACK  |
 | 
			
		||||
|---------------|---------|--------|
 | 
			
		||||
| v4.9.0        |         |        |
 | 
			
		||||
| v4.8.2        |         |        |
 | 
			
		||||
| v4.8.1        |         |        |
 | 
			
		||||
| v4.8.0        |         |        |
 | 
			
		||||
| v4.7.5        |         |        |
 | 
			
		||||
| v4.7.4        |         |        |
 | 
			
		||||
@@ -254,7 +253,7 @@ These Docker containers are based on:
 | 
			
		||||
*  "deviantony" dockerfiles which can be found at [https://github.com/deviantony/docker-elk](https://github.com/deviantony/docker-elk)
 | 
			
		||||
*  "xetus-oss" dockerfiles, which can be found at [https://github.com/xetus-oss/docker-ossec-server](https://github.com/xetus-oss/docker-ossec-server)
 | 
			
		||||
 | 
			
		||||
We thank you them and everyone else who has contributed to this project.
 | 
			
		||||
We thank them and everyone else who has contributed to this project.
 | 
			
		||||
 | 
			
		||||
## License and copyright
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										4
									
								
								VERSION
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								VERSION
									
									
									
									
									
								
							@@ -1,2 +1,2 @@
 | 
			
		||||
WAZUH-DOCKER_VERSION="4.8.0"
 | 
			
		||||
REVISION="40812"
 | 
			
		||||
WAZUH-DOCKER_VERSION="4.9.0"
 | 
			
		||||
REVISION="40907"
 | 
			
		||||
 
 | 
			
		||||
@@ -13,7 +13,7 @@ This script initializes the environment variables needed to build each of the im
 | 
			
		||||
The script allows you to build images from other versions of Wazuh, to do this you must use the -v or --version argument:
 | 
			
		||||
 | 
			
		||||
```
 | 
			
		||||
$ build-docker-images/build-images.sh -v 4.8.0
 | 
			
		||||
$ build-docker-images/build-images.sh -v 4.9.0
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
To get all the available script options use the -h or --help option:
 | 
			
		||||
@@ -26,7 +26,7 @@ Usage: build-docker-images/build-images.sh [OPTIONS]
 | 
			
		||||
    -d, --dev <ref>              [Optional] Set the development stage you want to build, example rc1 or beta1, not used by default.
 | 
			
		||||
    -f, --filebeat-module <ref>  [Optional] Set Filebeat module version. By default 0.4.
 | 
			
		||||
    -r, --revision <rev>         [Optional] Package revision. By default 1
 | 
			
		||||
    -v, --version <ver>          [Optional] Set the Wazuh version should be builded. By default, 4.8.0.
 | 
			
		||||
    -v, --version <ver>          [Optional] Set the Wazuh version should be builded. By default, 4.9.0.
 | 
			
		||||
    -h, --help                   Show this help.
 | 
			
		||||
 | 
			
		||||
```
 | 
			
		||||
@@ -1,4 +1,4 @@
 | 
			
		||||
WAZUH_IMAGE_VERSION=4.8.0
 | 
			
		||||
WAZUH_IMAGE_VERSION=4.9.0
 | 
			
		||||
WAZUH_VERSION=$(echo $WAZUH_IMAGE_VERSION | sed -e 's/\.//g')
 | 
			
		||||
WAZUH_TAG_REVISION=1
 | 
			
		||||
WAZUH_CURRENT_VERSION=$(curl --silent https://api.github.com/repos/wazuh/wazuh/releases/latest | grep '["]tag_name["]:' | sed -E 's/.*\"([^\"]+)\".*/\1/' | cut -c 2- | sed -e 's/\.//g')
 | 
			
		||||
@@ -12,7 +12,7 @@ IMAGE_VERSION=${WAZUH_IMAGE_VERSION}
 | 
			
		||||
# License (version 2) as published by the FSF - Free Software
 | 
			
		||||
# Foundation.
 | 
			
		||||
 | 
			
		||||
WAZUH_IMAGE_VERSION="4.8.0"
 | 
			
		||||
WAZUH_IMAGE_VERSION="4.9.0"
 | 
			
		||||
WAZUH_TAG_REVISION="1"
 | 
			
		||||
WAZUH_DEV_STAGE=""
 | 
			
		||||
FILEBEAT_MODULE_VERSION="0.4"
 | 
			
		||||
 
 | 
			
		||||
@@ -62,7 +62,7 @@ services:
 | 
			
		||||
      context: wazuh-dashboard/
 | 
			
		||||
      args:
 | 
			
		||||
        WAZUH_VERSION: ${WAZUH_VERSION}
 | 
			
		||||
        WAZUH_TAG_REVISION: ${WAZUH_TAG_REVISION}
 | 
			
		||||
        WAZUH_TAG_REVISION: 2
 | 
			
		||||
        WAZUH_UI_REVISION: ${WAZUH_UI_REVISION}
 | 
			
		||||
    image: wazuh/wazuh-dashboard:${WAZUH_IMAGE_VERSION}
 | 
			
		||||
    hostname: wazuh.dashboard
 | 
			
		||||
 
 | 
			
		||||
@@ -3,37 +3,29 @@ FROM amazonlinux:2023 AS builder
 | 
			
		||||
 | 
			
		||||
ARG WAZUH_VERSION
 | 
			
		||||
ARG WAZUH_TAG_REVISION
 | 
			
		||||
ARG INSTALL_DIR=/usr/share/wazuh-dashboard
 | 
			
		||||
ARG WAZUH_UI_REVISION
 | 
			
		||||
ARG INSTALL_DIR=/usr/share/wazuh-dashboard
 | 
			
		||||
 | 
			
		||||
# Update and install dependencies
 | 
			
		||||
RUN yum install curl-minimal libcap xz tar openssl -y
 | 
			
		||||
RUN yum install curl-minimal libcap openssl -y
 | 
			
		||||
 | 
			
		||||
# Create Install dir
 | 
			
		||||
RUN mkdir -p $INSTALL_DIR
 | 
			
		||||
COPY config/check_repository.sh /
 | 
			
		||||
RUN chmod 775 /check_repository.sh && \
 | 
			
		||||
    source /check_repository.sh
 | 
			
		||||
 | 
			
		||||
# Download and extract Wazuh dashboard base
 | 
			
		||||
COPY config/dl_base.sh .
 | 
			
		||||
RUN bash dl_base.sh
 | 
			
		||||
 | 
			
		||||
# Generate certificates
 | 
			
		||||
COPY config/config.sh .
 | 
			
		||||
COPY config/config.yml /
 | 
			
		||||
RUN bash config.sh
 | 
			
		||||
 | 
			
		||||
COPY config/install_wazuh_app.sh /
 | 
			
		||||
RUN chmod 775 /install_wazuh_app.sh
 | 
			
		||||
RUN bash /install_wazuh_app.sh
 | 
			
		||||
 | 
			
		||||
# Copy and set permissions to config files
 | 
			
		||||
COPY config/opensearch_dashboards.yml $INSTALL_DIR/config/
 | 
			
		||||
COPY config/wazuh.yml $INSTALL_DIR/data/wazuh/config/
 | 
			
		||||
RUN chmod 664 $INSTALL_DIR/config/opensearch_dashboards.yml
 | 
			
		||||
RUN yum install wazuh-dashboard-${WAZUH_VERSION}-${WAZUH_TAG_REVISION} -y && \
 | 
			
		||||
    yum clean all
 | 
			
		||||
 | 
			
		||||
# Create and set permissions to data directories
 | 
			
		||||
RUN mkdir -p $INSTALL_DIR/data/wazuh && chmod -R 775 $INSTALL_DIR/data/wazuh
 | 
			
		||||
RUN mkdir -p $INSTALL_DIR/data/wazuh/config && chmod -R 775 $INSTALL_DIR/data/wazuh/config
 | 
			
		||||
RUN mkdir -p $INSTALL_DIR/data/wazuh/logs && chmod -R 775 $INSTALL_DIR/data/wazuh/logs
 | 
			
		||||
COPY config/wazuh.yml $INSTALL_DIR/data/wazuh/config/
 | 
			
		||||
 | 
			
		||||
# Generate certificates
 | 
			
		||||
COPY config/config.sh .
 | 
			
		||||
COPY config/config.yml /
 | 
			
		||||
RUN bash config.sh
 | 
			
		||||
 | 
			
		||||
################################################################################
 | 
			
		||||
# Build stage 1 (the current Wazuh dashboard image):
 | 
			
		||||
 
 | 
			
		||||
@@ -0,0 +1,30 @@
 | 
			
		||||
## variables
 | 
			
		||||
APT_KEY=https://packages.wazuh.com/key/GPG-KEY-WAZUH
 | 
			
		||||
GPG_SIGN="gpgcheck=1\ngpgkey=${APT_KEY}]"
 | 
			
		||||
REPOSITORY="[wazuh]\n${GPG_SIGN}\nenabled=1\nname=EL-\$releasever - Wazuh\nbaseurl=https://packages.wazuh.com/4.x/yum/\nprotect=1"
 | 
			
		||||
WAZUH_CURRENT_VERSION=$(curl --silent https://api.github.com/repos/wazuh/wazuh/releases/latest | grep '["]tag_name["]:' | sed -E 's/.*\"([^\"]+)\".*/\1/' | cut -c 2-)
 | 
			
		||||
MAJOR_BUILD=$(echo $WAZUH_VERSION | cut -d. -f1)
 | 
			
		||||
MID_BUILD=$(echo $WAZUH_VERSION | cut -d. -f2)
 | 
			
		||||
MINOR_BUILD=$(echo $WAZUH_VERSION | cut -d. -f3)
 | 
			
		||||
MAJOR_CURRENT=$(echo $WAZUH_CURRENT_VERSION | cut -d. -f1)
 | 
			
		||||
MID_CURRENT=$(echo $WAZUH_CURRENT_VERSION | cut -d. -f2)
 | 
			
		||||
MINOR_CURRENT=$(echo $WAZUH_CURRENT_VERSION | cut -d. -f3)
 | 
			
		||||
 | 
			
		||||
## check version to use the correct repository
 | 
			
		||||
if [ "$MAJOR_BUILD" -gt "$MAJOR_CURRENT" ]; then
 | 
			
		||||
  APT_KEY=https://packages-dev.wazuh.com/key/GPG-KEY-WAZUH
 | 
			
		||||
  REPOSITORY="[wazuh]\n${GPG_SIGN}\nenabled=1\nname=EL-\$releasever - Wazuh\nbaseurl=https://packages-dev.wazuh.com/pre-release/yum/\nprotect=1"
 | 
			
		||||
elif [ "$MAJOR_BUILD" -eq "$MAJOR_CURRENT" ]; then
 | 
			
		||||
  if [ "$MID_BUILD" -gt "$MID_CURRENT" ]; then
 | 
			
		||||
    APT_KEY=https://packages-dev.wazuh.com/key/GPG-KEY-WAZUH
 | 
			
		||||
    REPOSITORY="[wazuh]\n${GPG_SIGN}\nenabled=1\nname=EL-\$releasever - Wazuh\nbaseurl=https://packages-dev.wazuh.com/pre-release/yum/\nprotect=1"
 | 
			
		||||
  elif [ "$MID_BUILD" -eq "$MID_CURRENT" ]; then
 | 
			
		||||
    if [ "$MINOR_BUILD" -gt "$MINOR_CURRENT" ]; then
 | 
			
		||||
      APT_KEY=https://packages-dev.wazuh.com/key/GPG-KEY-WAZUH
 | 
			
		||||
      REPOSITORY="[wazuh]\n${GPG_SIGN}\nenabled=1\nname=EL-\$releasever - Wazuh\nbaseurl=https://packages-dev.wazuh.com/pre-release/yum/\nprotect=1"
 | 
			
		||||
    fi
 | 
			
		||||
  fi
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
rpm --import "${APT_KEY}"
 | 
			
		||||
echo -e "${REPOSITORY}" | tee /etc/yum.repos.d/wazuh.repo
 | 
			
		||||
@@ -9,8 +9,8 @@ export CONFIG_DIR=${INSTALLATION_DIR}/config
 | 
			
		||||
 | 
			
		||||
## Variables
 | 
			
		||||
CERT_TOOL=wazuh-certs-tool.sh
 | 
			
		||||
PACKAGES_URL=https://packages.wazuh.com/4.8/
 | 
			
		||||
PACKAGES_DEV_URL=https://packages-dev.wazuh.com/4.8/
 | 
			
		||||
PACKAGES_URL=https://packages.wazuh.com/4.9/
 | 
			
		||||
PACKAGES_DEV_URL=https://packages-dev.wazuh.com/4.9/
 | 
			
		||||
 | 
			
		||||
## Check if the cert tool exists in S3 buckets
 | 
			
		||||
CERT_TOOL_PACKAGES=$(curl --silent -I $PACKAGES_URL$CERT_TOOL | grep -E "^HTTP" | awk  '{print $2}')
 | 
			
		||||
 
 | 
			
		||||
@@ -1,25 +0,0 @@
 | 
			
		||||
REPOSITORY="packages.wazuh.com/4.x"
 | 
			
		||||
WAZUH_CURRENT_VERSION=$(curl --silent https://api.github.com/repos/wazuh/wazuh/releases/latest | grep '["]tag_name["]:' | sed -E 's/.*\"([^\"]+)\".*/\1/' | cut -c 2-)
 | 
			
		||||
MAJOR_BUILD=$(echo $WAZUH_VERSION | cut -d. -f1)
 | 
			
		||||
MID_BUILD=$(echo $WAZUH_VERSION | cut -d. -f2)
 | 
			
		||||
MINOR_BUILD=$(echo $WAZUH_VERSION | cut -d. -f3)
 | 
			
		||||
MAJOR_CURRENT=$(echo $WAZUH_CURRENT_VERSION | cut -d. -f1)
 | 
			
		||||
MID_CURRENT=$(echo $WAZUH_CURRENT_VERSION | cut -d. -f2)
 | 
			
		||||
MINOR_CURRENT=$(echo $WAZUH_CURRENT_VERSION | cut -d. -f3)
 | 
			
		||||
 | 
			
		||||
## check version to use the correct repository
 | 
			
		||||
if [ "$MAJOR_BUILD" -gt "$MAJOR_CURRENT" ]; then
 | 
			
		||||
  REPOSITORY="packages-dev.wazuh.com/pre-release"
 | 
			
		||||
elif [ "$MAJOR_BUILD" -eq "$MAJOR_CURRENT" ]; then
 | 
			
		||||
  if [ "$MID_BUILD" -gt "$MID_CURRENT" ]; then
 | 
			
		||||
    REPOSITORY="packages-dev.wazuh.com/pre-release"
 | 
			
		||||
  elif [ "$MID_BUILD" -eq "$MID_CURRENT" ]; then
 | 
			
		||||
    if [ "$MINOR_BUILD" -gt "$MINOR_CURRENT" ]; then
 | 
			
		||||
      REPOSITORY="packages-dev.wazuh.com/pre-release"
 | 
			
		||||
    fi
 | 
			
		||||
  fi
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
curl -o wazuh-dashboard-base.tar.xz https://${REPOSITORY}/stack/dashboard/wazuh-dashboard-base-${WAZUH_VERSION}-${WAZUH_TAG_REVISION}-linux-x64.tar.xz
 | 
			
		||||
tar -xf wazuh-dashboard-base.tar.xz --directory  $INSTALL_DIR --strip-components=1
 | 
			
		||||
@@ -1,35 +0,0 @@
 | 
			
		||||
## variables
 | 
			
		||||
WAZUH_APP=https://packages.wazuh.com/4.x/ui/dashboard/wazuh-${WAZUH_VERSION}-${WAZUH_UI_REVISION}.zip
 | 
			
		||||
WAZUH_CHECK_UPDATES=https://packages.wazuh.com/4.x/ui/dashboard/wazuhCheckUpdates-${WAZUH_VERSION}-${WAZUH_UI_REVISION}.zip
 | 
			
		||||
WAZUH_CORE=https://packages.wazuh.com/4.x/ui/dashboard/wazuhCore-${WAZUH_VERSION}-${WAZUH_UI_REVISION}.zip
 | 
			
		||||
WAZUH_CURRENT_VERSION=$(curl --silent https://api.github.com/repos/wazuh/wazuh/releases/latest | grep '["]tag_name["]:' | sed -E 's/.*\"([^\"]+)\".*/\1/' | cut -c 2-)
 | 
			
		||||
MAJOR_BUILD=$(echo $WAZUH_VERSION | cut -d. -f1)
 | 
			
		||||
MID_BUILD=$(echo $WAZUH_VERSION | cut -d. -f2)
 | 
			
		||||
MINOR_BUILD=$(echo $WAZUH_VERSION | cut -d. -f3)
 | 
			
		||||
MAJOR_CURRENT=$(echo $WAZUH_CURRENT_VERSION | cut -d. -f1)
 | 
			
		||||
MID_CURRENT=$(echo $WAZUH_CURRENT_VERSION | cut -d. -f2)
 | 
			
		||||
MINOR_CURRENT=$(echo $WAZUH_CURRENT_VERSION | cut -d. -f3)
 | 
			
		||||
 | 
			
		||||
## check version to use the correct repository
 | 
			
		||||
if [ "$MAJOR_BUILD" -gt "$MAJOR_CURRENT" ]; then
 | 
			
		||||
  WAZUH_APP=https://packages-dev.wazuh.com/pre-release/ui/dashboard/wazuh-${WAZUH_VERSION}-${WAZUH_UI_REVISION}.zip
 | 
			
		||||
  WAZUH_CHECK_UPDATES=https://packages-dev.wazuh.com/pre-release/ui/dashboard/wazuhCheckUpdates-${WAZUH_VERSION}-${WAZUH_UI_REVISION}.zip
 | 
			
		||||
  WAZUH_CORE=https://packages-dev.wazuh.com/pre-release/ui/dashboard/wazuhCore-${WAZUH_VERSION}-${WAZUH_UI_REVISION}.zip
 | 
			
		||||
elif [ "$MAJOR_BUILD" -eq "$MAJOR_CURRENT" ]; then
 | 
			
		||||
  if [ "$MID_BUILD" -gt "$MID_CURRENT" ]; then
 | 
			
		||||
    WAZUH_APP=https://packages-dev.wazuh.com/pre-release/ui/dashboard/wazuh-${WAZUH_VERSION}-${WAZUH_UI_REVISION}.zip
 | 
			
		||||
    WAZUH_CHECK_UPDATES=https://packages-dev.wazuh.com/pre-release/ui/dashboard/wazuhCheckUpdates-${WAZUH_VERSION}-${WAZUH_UI_REVISION}.zip
 | 
			
		||||
    WAZUH_CORE=https://packages-dev.wazuh.com/pre-release/ui/dashboard/wazuhCore-${WAZUH_VERSION}-${WAZUH_UI_REVISION}.zip
 | 
			
		||||
  elif [ "$MID_BUILD" -eq "$MID_CURRENT" ]; then
 | 
			
		||||
    if [ "$MINOR_BUILD" -gt "$MINOR_CURRENT" ]; then
 | 
			
		||||
      WAZUH_APP=https://packages-dev.wazuh.com/pre-release/ui/dashboard/wazuh-${WAZUH_VERSION}-${WAZUH_UI_REVISION}.zip
 | 
			
		||||
      WAZUH_CHECK_UPDATES=https://packages-dev.wazuh.com/pre-release/ui/dashboard/wazuhCheckUpdates-${WAZUH_VERSION}-${WAZUH_UI_REVISION}.zip
 | 
			
		||||
      WAZUH_CORE=https://packages-dev.wazuh.com/pre-release/ui/dashboard/wazuhCore-${WAZUH_VERSION}-${WAZUH_UI_REVISION}.zip
 | 
			
		||||
    fi
 | 
			
		||||
  fi
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
# Install Wazuh App
 | 
			
		||||
$INSTALL_DIR/bin/opensearch-dashboards-plugin install $WAZUH_APP --allow-root
 | 
			
		||||
$INSTALL_DIR/bin/opensearch-dashboards-plugin install $WAZUH_CHECK_UPDATES --allow-root
 | 
			
		||||
$INSTALL_DIR/bin/opensearch-dashboards-plugin install $WAZUH_CORE --allow-root
 | 
			
		||||
@@ -1,13 +0,0 @@
 | 
			
		||||
server.host: 0.0.0.0
 | 
			
		||||
server.port: 5601
 | 
			
		||||
opensearch.hosts: https://wazuh.indexer:9200
 | 
			
		||||
opensearch.ssl.verificationMode: none
 | 
			
		||||
opensearch.requestHeadersWhitelist: [ authorization,securitytenant ]
 | 
			
		||||
opensearch_security.multitenancy.enabled: false
 | 
			
		||||
opensearch_security.readonly_mode.roles: ["kibana_read_only"]
 | 
			
		||||
server.ssl.enabled: true
 | 
			
		||||
server.ssl.key: "/usr/share/wazuh-dashboard/config/certs/dashboard-key.pem"
 | 
			
		||||
server.ssl.certificate: "/usr/share/wazuh-dashboard/config/certs/dashboard.pem"
 | 
			
		||||
opensearch.ssl.certificateAuthorities: ["/usr/share/wazuh-dashboard/config/certs/root-ca.pem"]
 | 
			
		||||
uiSettings.overrides.defaultRoute: /app/wz-home
 | 
			
		||||
 | 
			
		||||
@@ -6,6 +6,13 @@ ARG WAZUH_TAG_REVISION
 | 
			
		||||
 | 
			
		||||
RUN yum install curl-minimal openssl xz tar findutils shadow-utils -y
 | 
			
		||||
 | 
			
		||||
COPY config/check_repository.sh /
 | 
			
		||||
RUN chmod 775 /check_repository.sh && \
 | 
			
		||||
    source /check_repository.sh
 | 
			
		||||
 | 
			
		||||
RUN yum install wazuh-indexer-${WAZUH_VERSION}-${WAZUH_TAG_REVISION} -y && \
 | 
			
		||||
    yum clean all
 | 
			
		||||
 | 
			
		||||
COPY config/opensearch.yml /
 | 
			
		||||
 | 
			
		||||
COPY config/config.sh .
 | 
			
		||||
@@ -59,7 +66,8 @@ RUN chmod 700 /entrypoint.sh && chmod 700 /securityadmin.sh
 | 
			
		||||
 | 
			
		||||
RUN chown 1000:1000 /*.sh
 | 
			
		||||
 | 
			
		||||
COPY --from=builder --chown=1000:1000 /debian/wazuh-indexer/usr/share/wazuh-indexer /usr/share/wazuh-indexer
 | 
			
		||||
COPY --from=builder --chown=1000:1000 /usr/share/wazuh-indexer /usr/share/wazuh-indexer
 | 
			
		||||
COPY --from=builder --chown=1000:1000 /etc/wazuh-indexer /usr/share/wazuh-indexer
 | 
			
		||||
COPY --from=builder --chown=0:0 /debian/wazuh-indexer/usr/lib/systemd /usr/lib/systemd
 | 
			
		||||
COPY --from=builder --chown=0:0 /debian/wazuh-indexer/usr/lib/sysctl.d /usr/lib/sysctl.d
 | 
			
		||||
COPY --from=builder --chown=0:0 /debian/wazuh-indexer/usr/lib/tmpfiles.d /usr/lib/tmpfiles.d
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										30
									
								
								build-docker-images/wazuh-indexer/config/check_repository.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								build-docker-images/wazuh-indexer/config/check_repository.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,30 @@
 | 
			
		||||
## variables
 | 
			
		||||
APT_KEY=https://packages.wazuh.com/key/GPG-KEY-WAZUH
 | 
			
		||||
GPG_SIGN="gpgcheck=1\ngpgkey=${APT_KEY}]"
 | 
			
		||||
REPOSITORY="[wazuh]\n${GPG_SIGN}\nenabled=1\nname=EL-\$releasever - Wazuh\nbaseurl=https://packages.wazuh.com/4.x/yum/\nprotect=1"
 | 
			
		||||
WAZUH_CURRENT_VERSION=$(curl --silent https://api.github.com/repos/wazuh/wazuh/releases/latest | grep '["]tag_name["]:' | sed -E 's/.*\"([^\"]+)\".*/\1/' | cut -c 2-)
 | 
			
		||||
MAJOR_BUILD=$(echo $WAZUH_VERSION | cut -d. -f1)
 | 
			
		||||
MID_BUILD=$(echo $WAZUH_VERSION | cut -d. -f2)
 | 
			
		||||
MINOR_BUILD=$(echo $WAZUH_VERSION | cut -d. -f3)
 | 
			
		||||
MAJOR_CURRENT=$(echo $WAZUH_CURRENT_VERSION | cut -d. -f1)
 | 
			
		||||
MID_CURRENT=$(echo $WAZUH_CURRENT_VERSION | cut -d. -f2)
 | 
			
		||||
MINOR_CURRENT=$(echo $WAZUH_CURRENT_VERSION | cut -d. -f3)
 | 
			
		||||
 | 
			
		||||
## check version to use the correct repository
 | 
			
		||||
if [ "$MAJOR_BUILD" -gt "$MAJOR_CURRENT" ]; then
 | 
			
		||||
  APT_KEY=https://packages-dev.wazuh.com/key/GPG-KEY-WAZUH
 | 
			
		||||
  REPOSITORY="[wazuh]\n${GPG_SIGN}\nenabled=1\nname=EL-\$releasever - Wazuh\nbaseurl=https://packages-dev.wazuh.com/pre-release/yum/\nprotect=1"
 | 
			
		||||
elif [ "$MAJOR_BUILD" -eq "$MAJOR_CURRENT" ]; then
 | 
			
		||||
  if [ "$MID_BUILD" -gt "$MID_CURRENT" ]; then
 | 
			
		||||
    APT_KEY=https://packages-dev.wazuh.com/key/GPG-KEY-WAZUH
 | 
			
		||||
    REPOSITORY="[wazuh]\n${GPG_SIGN}\nenabled=1\nname=EL-\$releasever - Wazuh\nbaseurl=https://packages-dev.wazuh.com/pre-release/yum/\nprotect=1"
 | 
			
		||||
  elif [ "$MID_BUILD" -eq "$MID_CURRENT" ]; then
 | 
			
		||||
    if [ "$MINOR_BUILD" -gt "$MINOR_CURRENT" ]; then
 | 
			
		||||
      APT_KEY=https://packages-dev.wazuh.com/key/GPG-KEY-WAZUH
 | 
			
		||||
      REPOSITORY="[wazuh]\n${GPG_SIGN}\nenabled=1\nname=EL-\$releasever - Wazuh\nbaseurl=https://packages-dev.wazuh.com/pre-release/yum/\nprotect=1"
 | 
			
		||||
    fi
 | 
			
		||||
  fi
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
rpm --import "${APT_KEY}"
 | 
			
		||||
echo -e "${REPOSITORY}" | tee /etc/yum.repos.d/wazuh.repo
 | 
			
		||||
@@ -19,42 +19,11 @@ export INDEXER_FILE=wazuh-indexer-base.tar.xz
 | 
			
		||||
export BASE_FILE=wazuh-indexer-base-${VERSION}-linux-x64.tar.xz
 | 
			
		||||
export REPO_DIR=/unattended_installer
 | 
			
		||||
 | 
			
		||||
rm -rf ${INSTALLATION_DIR}/
 | 
			
		||||
 | 
			
		||||
## variables
 | 
			
		||||
REPOSITORY="packages.wazuh.com/4.x"
 | 
			
		||||
WAZUH_CURRENT_VERSION=$(curl --silent https://api.github.com/repos/wazuh/wazuh/releases/latest | grep '["]tag_name["]:' | sed -E 's/.*\"([^\"]+)\".*/\1/' | cut -c 2-)
 | 
			
		||||
MAJOR_BUILD=$(echo $WAZUH_VERSION | cut -d. -f1)
 | 
			
		||||
MID_BUILD=$(echo $WAZUH_VERSION | cut -d. -f2)
 | 
			
		||||
MINOR_BUILD=$(echo $WAZUH_VERSION | cut -d. -f3)
 | 
			
		||||
MAJOR_CURRENT=$(echo $WAZUH_CURRENT_VERSION | cut -d. -f1)
 | 
			
		||||
MID_CURRENT=$(echo $WAZUH_CURRENT_VERSION | cut -d. -f2)
 | 
			
		||||
MINOR_CURRENT=$(echo $WAZUH_CURRENT_VERSION | cut -d. -f3)
 | 
			
		||||
 | 
			
		||||
## check version to use the correct repository
 | 
			
		||||
if [ "$MAJOR_BUILD" -gt "$MAJOR_CURRENT" ]; then
 | 
			
		||||
  REPOSITORY="packages-dev.wazuh.com/pre-release"
 | 
			
		||||
elif [ "$MAJOR_BUILD" -eq "$MAJOR_CURRENT" ]; then
 | 
			
		||||
  if [ "$MID_BUILD" -gt "$MID_CURRENT" ]; then
 | 
			
		||||
    REPOSITORY="packages-dev.wazuh.com/pre-release"
 | 
			
		||||
  elif [ "$MID_BUILD" -eq "$MID_CURRENT" ]; then
 | 
			
		||||
    if [ "$MINOR_BUILD" -gt "$MINOR_CURRENT" ]; then
 | 
			
		||||
      REPOSITORY="packages-dev.wazuh.com/pre-release"
 | 
			
		||||
    fi
 | 
			
		||||
  fi
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
curl -o ${INDEXER_FILE} https://${REPOSITORY}/stack/indexer/${BASE_FILE}
 | 
			
		||||
tar -xf ${INDEXER_FILE}
 | 
			
		||||
 | 
			
		||||
## TOOLS
 | 
			
		||||
 | 
			
		||||
## Variables
 | 
			
		||||
CERT_TOOL=wazuh-certs-tool.sh
 | 
			
		||||
PASSWORD_TOOL=wazuh-passwords-tool.sh
 | 
			
		||||
PACKAGES_URL=https://packages.wazuh.com/4.8/
 | 
			
		||||
PACKAGES_DEV_URL=https://packages-dev.wazuh.com/4.8/
 | 
			
		||||
PACKAGES_URL=https://packages.wazuh.com/4.9/
 | 
			
		||||
PACKAGES_DEV_URL=https://packages-dev.wazuh.com/4.9/
 | 
			
		||||
 | 
			
		||||
## Check if the cert tool exists in S3 buckets
 | 
			
		||||
CERT_TOOL_PACKAGES=$(curl --silent -I $PACKAGES_URL$CERT_TOOL | grep -E "^HTTP" | awk  '{print $2}')
 | 
			
		||||
@@ -103,20 +72,6 @@ mkdir -p ${TARGET_DIR}/usr/lib/tmpfiles.d
 | 
			
		||||
mkdir -p ${TARGET_DIR}/usr/lib/sysctl.d
 | 
			
		||||
mkdir -p ${TARGET_DIR}/usr/lib/systemd/system
 | 
			
		||||
mkdir -p ${TARGET_DIR}${CONFIG_DIR}/certs
 | 
			
		||||
# Move configuration files for wazuh-indexer
 | 
			
		||||
mv -f ${BASE_DIR}/etc/init.d/${NAME} ${TARGET_DIR}/etc/init.d/${NAME}
 | 
			
		||||
mv -f ${BASE_DIR}/etc/wazuh-indexer/* ${TARGET_DIR}${CONFIG_DIR}
 | 
			
		||||
mv -f ${BASE_DIR}/etc/sysconfig/${NAME} ${TARGET_DIR}/etc/default/
 | 
			
		||||
mv -f ${BASE_DIR}/usr/lib/tmpfiles.d/* ${TARGET_DIR}/usr/lib/tmpfiles.d/
 | 
			
		||||
mv -f ${BASE_DIR}/usr/lib/sysctl.d/* ${TARGET_DIR}/usr/lib/sysctl.d/
 | 
			
		||||
mv -f ${BASE_DIR}/usr/lib/systemd/system/* ${TARGET_DIR}/usr/lib/systemd/system/
 | 
			
		||||
rm -rf ${BASE_DIR}/etc
 | 
			
		||||
rm -rf ${BASE_DIR}/usr
 | 
			
		||||
# Copy installation files to final location
 | 
			
		||||
cp -pr ${BASE_DIR}/* ${TARGET_DIR}${INSTALLATION_DIR}
 | 
			
		||||
# Copy the security tools
 | 
			
		||||
cp /$CERT_TOOL ${TARGET_DIR}${INSTALLATION_DIR}/plugins/opensearch-security/tools/
 | 
			
		||||
cp /$PASSWORD_TOOL ${TARGET_DIR}${INSTALLATION_DIR}/plugins/opensearch-security/tools/
 | 
			
		||||
# Copy Wazuh's config files for the security plugin
 | 
			
		||||
cp -pr /roles_mapping.yml ${TARGET_DIR}${INSTALLATION_DIR}/opensearch-security/
 | 
			
		||||
cp -pr /roles.yml ${TARGET_DIR}${INSTALLATION_DIR}/opensearch-security/
 | 
			
		||||
@@ -132,9 +87,9 @@ cp -pr /wazuh-certificates/admin.pem ${TARGET_DIR}${CONFIG_DIR}/certs/admin.pem
 | 
			
		||||
cp -pr /wazuh-certificates/admin-key.pem ${TARGET_DIR}${CONFIG_DIR}/certs/admin-key.pem
 | 
			
		||||
 | 
			
		||||
# Delete xms and xmx parameters in jvm.options
 | 
			
		||||
sed '/-Xms/d' -i ${TARGET_DIR}${CONFIG_DIR}/jvm.options
 | 
			
		||||
sed '/-Xmx/d' -i ${TARGET_DIR}${CONFIG_DIR}/jvm.options
 | 
			
		||||
sed -i 's/-Djava.security.policy=file:\/\/\/etc\/wazuh-indexer\/opensearch-performance-analyzer\/opensearch_security.policy/-Djava.security.policy=file:\/\/\/usr\/share\/wazuh-indexer\/opensearch-performance-analyzer\/opensearch_security.policy/g' ${TARGET_DIR}${CONFIG_DIR}/jvm.options
 | 
			
		||||
sed '/-Xms/d' -i /etc/wazuh-indexer/jvm.options
 | 
			
		||||
sed '/-Xmx/d' -i /etc/wazuh-indexer/jvm.options
 | 
			
		||||
sed -i 's/-Djava.security.policy=file:\/\/\/etc\/wazuh-indexer\/opensearch-performance-analyzer\/opensearch_security.policy/-Djava.security.policy=file:\/\/\/usr\/share\/wazuh-indexer\/opensearch-performance-analyzer\/opensearch_security.policy/g' /etc/wazuh-indexer/jvm.options
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
chmod -R 500 ${TARGET_DIR}${CONFIG_DIR}/certs
 | 
			
		||||
 
 | 
			
		||||
@@ -79,7 +79,9 @@ PERMANENT_DATA_EXCP[((i++))]="/var/ossec/wodles/aws/subscribers/sqs_message_proc
 | 
			
		||||
PERMANENT_DATA_EXCP[((i++))]="/var/ossec/wodles/aws/subscribers/sqs_queue.py"
 | 
			
		||||
PERMANENT_DATA_EXCP[((i++))]="/var/ossec/wodles/azure/azure-logs"
 | 
			
		||||
PERMANENT_DATA_EXCP[((i++))]="/var/ossec/wodles/azure/azure-logs.py"
 | 
			
		||||
PERMANENT_DATA_EXCP[((i++))]="/var/ossec/wodles/azure/orm.py"
 | 
			
		||||
PERMANENT_DATA_EXCP[((i++))]="/var/ossec/wodles/azure/db/orm.py"
 | 
			
		||||
PERMANENT_DATA_EXCP[((i++))]="/var/ossec/wodles/azure/db/utils.py"
 | 
			
		||||
PERMANENT_DATA_EXCP[((i++))]="/var/ossec/wodles/azure/db/__init__.py"
 | 
			
		||||
PERMANENT_DATA_EXCP[((i++))]="/var/ossec/wodles/docker/DockerListener"
 | 
			
		||||
PERMANENT_DATA_EXCP[((i++))]="/var/ossec/wodles/docker/DockerListener.py"
 | 
			
		||||
PERMANENT_DATA_EXCP[((i++))]="/var/ossec/wodles/gcloud/gcloud"
 | 
			
		||||
 
 | 
			
		||||
@@ -8,8 +8,8 @@
 | 
			
		||||
## Variables
 | 
			
		||||
CERT_TOOL=wazuh-certs-tool.sh
 | 
			
		||||
PASSWORD_TOOL=wazuh-passwords-tool.sh
 | 
			
		||||
PACKAGES_URL=https://packages.wazuh.com/4.8/
 | 
			
		||||
PACKAGES_DEV_URL=https://packages-dev.wazuh.com/4.8/
 | 
			
		||||
PACKAGES_URL=https://packages.wazuh.com/4.9/
 | 
			
		||||
PACKAGES_DEV_URL=https://packages-dev.wazuh.com/4.9/
 | 
			
		||||
 | 
			
		||||
## Check if the cert tool exists in S3 buckets
 | 
			
		||||
CERT_TOOL_PACKAGES=$(curl --silent -I $PACKAGES_URL$CERT_TOOL | grep -E "^HTTP" | awk  '{print $2}')
 | 
			
		||||
 
 | 
			
		||||
@@ -3,7 +3,7 @@ version: '3.7'
 | 
			
		||||
 | 
			
		||||
services:
 | 
			
		||||
  wazuh.master:
 | 
			
		||||
    image: wazuh/wazuh-manager:4.8.0
 | 
			
		||||
    image: wazuh/wazuh-manager:4.9.0
 | 
			
		||||
    hostname: wazuh.master
 | 
			
		||||
    restart: always
 | 
			
		||||
    ulimits:
 | 
			
		||||
@@ -45,7 +45,7 @@ services:
 | 
			
		||||
      - ./config/wazuh_cluster/wazuh_manager.conf:/wazuh-config-mount/etc/ossec.conf
 | 
			
		||||
 | 
			
		||||
  wazuh.worker:
 | 
			
		||||
    image: wazuh/wazuh-manager:4.8.0
 | 
			
		||||
    image: wazuh/wazuh-manager:4.9.0
 | 
			
		||||
    hostname: wazuh.worker
 | 
			
		||||
    restart: always
 | 
			
		||||
    ulimits:
 | 
			
		||||
@@ -81,7 +81,7 @@ services:
 | 
			
		||||
      - ./config/wazuh_cluster/wazuh_worker.conf:/wazuh-config-mount/etc/ossec.conf
 | 
			
		||||
 | 
			
		||||
  wazuh1.indexer:
 | 
			
		||||
    image: wazuh/wazuh-indexer:4.8.0
 | 
			
		||||
    image: wazuh/wazuh-indexer:4.9.0
 | 
			
		||||
    hostname: wazuh1.indexer
 | 
			
		||||
    restart: always
 | 
			
		||||
    ports:
 | 
			
		||||
@@ -107,7 +107,7 @@ services:
 | 
			
		||||
      - ./config/wazuh_indexer/internal_users.yml:/usr/share/wazuh-indexer/opensearch-security/internal_users.yml
 | 
			
		||||
 | 
			
		||||
  wazuh2.indexer:
 | 
			
		||||
    image: wazuh/wazuh-indexer:4.8.0
 | 
			
		||||
    image: wazuh/wazuh-indexer:4.9.0
 | 
			
		||||
    hostname: wazuh2.indexer
 | 
			
		||||
    restart: always
 | 
			
		||||
    environment:
 | 
			
		||||
@@ -129,7 +129,7 @@ services:
 | 
			
		||||
      - ./config/wazuh_indexer/internal_users.yml:/usr/share/wazuh-indexer/opensearch-security/internal_users.yml
 | 
			
		||||
 | 
			
		||||
  wazuh3.indexer:
 | 
			
		||||
    image: wazuh/wazuh-indexer:4.8.0
 | 
			
		||||
    image: wazuh/wazuh-indexer:4.9.0
 | 
			
		||||
    hostname: wazuh3.indexer
 | 
			
		||||
    restart: always
 | 
			
		||||
    environment:
 | 
			
		||||
@@ -151,7 +151,7 @@ services:
 | 
			
		||||
      - ./config/wazuh_indexer/internal_users.yml:/usr/share/wazuh-indexer/opensearch-security/internal_users.yml
 | 
			
		||||
 | 
			
		||||
  wazuh.dashboard:
 | 
			
		||||
    image: wazuh/wazuh-dashboard:4.8.0
 | 
			
		||||
    image: wazuh/wazuh-dashboard:4.9.0
 | 
			
		||||
    hostname: wazuh.dashboard
 | 
			
		||||
    restart: always
 | 
			
		||||
    ports:
 | 
			
		||||
 
 | 
			
		||||
@@ -3,7 +3,7 @@ version: '3.7'
 | 
			
		||||
 | 
			
		||||
services:
 | 
			
		||||
  wazuh.manager:
 | 
			
		||||
    image: wazuh/wazuh-manager:4.8.0
 | 
			
		||||
    image: wazuh/wazuh-manager:4.9.0
 | 
			
		||||
    hostname: wazuh.manager
 | 
			
		||||
    restart: always
 | 
			
		||||
    ulimits:
 | 
			
		||||
@@ -46,7 +46,7 @@ services:
 | 
			
		||||
      - ./config/wazuh_cluster/wazuh_manager.conf:/wazuh-config-mount/etc/ossec.conf
 | 
			
		||||
 | 
			
		||||
  wazuh.indexer:
 | 
			
		||||
    image: wazuh/wazuh-indexer:4.8.0
 | 
			
		||||
    image: wazuh/wazuh-indexer:4.9.0
 | 
			
		||||
    hostname: wazuh.indexer
 | 
			
		||||
    restart: always
 | 
			
		||||
    ports:
 | 
			
		||||
@@ -71,7 +71,7 @@ services:
 | 
			
		||||
      - ./config/wazuh_indexer/internal_users.yml:/usr/share/wazuh-indexer/opensearch-security/internal_users.yml
 | 
			
		||||
 | 
			
		||||
  wazuh.dashboard:
 | 
			
		||||
    image: wazuh/wazuh-dashboard:4.8.0
 | 
			
		||||
    image: wazuh/wazuh-dashboard:4.9.0
 | 
			
		||||
    hostname: wazuh.dashboard
 | 
			
		||||
    restart: always
 | 
			
		||||
    ports:
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user