mirror of
				https://github.com/wazuh/wazuh-docker.git
				synced 2025-11-04 05:53:16 +00:00 
			
		
		
		
	Compare commits
	
		
			4 Commits
		
	
	
		
			devel
			...
			3.9.3_7.2.
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					95c473e7d4 | ||
| 
						 | 
					4a0ff2895f | ||
| 
						 | 
					611e113d52 | ||
| 
						 | 
					3cd812ad8e | 
							
								
								
									
										121
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										121
									
								
								CHANGELOG.md
									
									
									
									
									
								
							@@ -1,127 +1,10 @@
 | 
			
		||||
# Change Log
 | 
			
		||||
All notable changes to this project will be documented in this file.
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.13.1_7.8.0
 | 
			
		||||
## Wazuh Docker v3.9.3_7.2.0-oss
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update to Wazuh version 3.13.1_7.8.0
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.13.0_7.7.1
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update to Wazuh version 3.13.3_7.7.1
 | 
			
		||||
 | 
			
		||||
### Fixed
 | 
			
		||||
 | 
			
		||||
- Save agentless state ([@xr09](https://github.com/xr09)) [#350](https://github.com/wazuh/wazuh-docker/pull/350)
 | 
			
		||||
- Use HTTP credentials for service check when required ([@xr09](https://github.com/xr09)) [#356](https://github.com/wazuh/wazuh-docker/pull/356)
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.12.3_7.6.2
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update to Wazuh version 3.12.3_7.6.2
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.12.2_7.6.2
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update to Wazuh version 3.12.2_7.6.2
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.12.1_7.6.2
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update to Wazuh version 3.12.1_7.6.2
 | 
			
		||||
 | 
			
		||||
### Fixed
 | 
			
		||||
 | 
			
		||||
- Agent timestamp not being properly saved ([@xr09](https://github.com/xr09)) [#323](https://github.com/wazuh/wazuh-docker/pull/323)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.12.0_7.6.1
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update to Wazuh version 3.12.0_7.6.1
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.11.4_7.6.1
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update to Wazuh version 3.11.4_7.6.1
 | 
			
		||||
 | 
			
		||||
- Enable HTTP v2 on nginx ([@xr09](https://github.com/xr09)) [#308](https://github.com/wazuh/wazuh-docker/pull/308)
 | 
			
		||||
 | 
			
		||||
### Fixed
 | 
			
		||||
 | 
			
		||||
- Updated NGINX config syntax ([@xr09](https://github.com/xr09)) [#303](https://github.com/wazuh/wazuh-docker/pull/303)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.11.3_7.5.2
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update to Wazuh version 3.11.3_7.5.2
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.11.2_7.5.1
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Bumped Node.js to version 10 ([@xr09](https://github.com/xr09)) [#8615cd4](https://github.com/wazuh/wazuh-docker/commit/8615cd4d2152601e55becc7c3675360938e74b6a)
 | 
			
		||||
 | 
			
		||||
### Fixed
 | 
			
		||||
 | 
			
		||||
- Fix S3 Plugin ([@AnthonySendra](https://github.com/AnthonySendra)) [#293](https://github.com/wazuh/wazuh-docker/pull/293)
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.11.1_7.5.1
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update to Wazuh version 3.11.1_7.5.1
 | 
			
		||||
- Filebeat configuration file updated to latest version ([@manuasir](https://github.com/manuasir)) [#271](https://github.com/wazuh/wazuh-docker/pull/271)
 | 
			
		||||
- Allow using the hostname as node_name for managers ([@JPLachance](https://github.com/JPLachance)) [#261](https://github.com/wazuh/wazuh-docker/pull/261)
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.11.0_7.5.1
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update to Wazuh version 3.11.0_7.5.1
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.10.2_7.5.0
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update to Wazuh version 3.10.2_7.5.0
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.10.2_7.3.2
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update to Wazuh version 3.10.2_7.3.2
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.10.0_7.3.2
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update to Wazuh version 3.10.0_7.3.2
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.9.5_7.2.1
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update to Wazuh version 3.9.5_7.2.1
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.9.4_7.2.0
 | 
			
		||||
 | 
			
		||||
### Added
 | 
			
		||||
 | 
			
		||||
- Update to Wazuh version 3.9.4_7.2.0
 | 
			
		||||
- Implemented Wazuh Filebeat Module ([jm404](https://www.github.com/jm404)) [#2a77c6a](https://github.com/wazuh/wazuh-docker/commit/2a77c6a6e6bf78f2492adeedbade7a507d9974b2)
 | 
			
		||||
- Support for OSS Elastic Docker images.
 | 
			
		||||
 | 
			
		||||
## Wazuh Docker v3.9.3_7.2.0
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							@@ -1,5 +1,5 @@
 | 
			
		||||
 | 
			
		||||
 Portions Copyright (C) 2020 Wazuh, Inc.
 | 
			
		||||
 Portions Copyright (C) 2019 Wazuh, Inc.
 | 
			
		||||
 Based on work Copyright (C) 2003 - 2013 Trend Micro, Inc.
 | 
			
		||||
 | 
			
		||||
 This program is a free software; you can redistribute it and/or modify
 | 
			
		||||
 
 | 
			
		||||
@@ -57,7 +57,7 @@ In addition, a docker-compose file is provided to launch the containers mentione
 | 
			
		||||
 | 
			
		||||
* `stable` branch on correspond to the latest Wazuh-Docker stable version.
 | 
			
		||||
* `master` branch contains the latest code, be aware of possible bugs on this branch.
 | 
			
		||||
* `Wazuh.Version_ElasticStack.Version` (for example 3.13.1_7.8.0) branch. This branch contains the current release referenced in Docker Hub. The container images are installed under the current version of this branch.
 | 
			
		||||
* `Wazuh.Version_ElasticStack.Version` (for example 3.9.3_7.2.0) branch. This branch contains the current release referenced in Docker Hub. The container images are installed under the current version of this branch.
 | 
			
		||||
 | 
			
		||||
## Credits and Thank you
 | 
			
		||||
 | 
			
		||||
@@ -70,7 +70,7 @@ We thank you them and everyone else who has contributed to this project.
 | 
			
		||||
 | 
			
		||||
## License and copyright
 | 
			
		||||
 | 
			
		||||
Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
 | 
			
		||||
## Web references
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										4
									
								
								VERSION
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								VERSION
									
									
									
									
									
								
							@@ -1,2 +1,2 @@
 | 
			
		||||
WAZUH-DOCKER_VERSION="3.13.1_7.8.0"
 | 
			
		||||
REVISION="31310"
 | 
			
		||||
WAZUH-DOCKER_VERSION="3.9.3_7.2.0"
 | 
			
		||||
REVISION="3930"
 | 
			
		||||
@@ -1,9 +1,9 @@
 | 
			
		||||
# Wazuh App Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh App Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
version: '2'
 | 
			
		||||
 | 
			
		||||
services:
 | 
			
		||||
  wazuh:
 | 
			
		||||
    image: wazuh/wazuh:3.13.1_7.8.0
 | 
			
		||||
    image: wazuh/wazuh:3.9.3_7.2.0-oss
 | 
			
		||||
    hostname: wazuh-manager
 | 
			
		||||
    restart: always
 | 
			
		||||
    ports:
 | 
			
		||||
@@ -13,7 +13,7 @@ services:
 | 
			
		||||
      - "55000:55000"
 | 
			
		||||
 | 
			
		||||
  elasticsearch:
 | 
			
		||||
    image: wazuh/wazuh-elasticsearch:3.13.1_7.8.0
 | 
			
		||||
    image: wazuh/wazuh-elasticsearch:3.9.3_7.2.0-oss
 | 
			
		||||
    hostname: elasticsearch
 | 
			
		||||
    restart: always
 | 
			
		||||
    ports:
 | 
			
		||||
@@ -30,7 +30,7 @@ services:
 | 
			
		||||
    mem_limit: 2g
 | 
			
		||||
 | 
			
		||||
  kibana:
 | 
			
		||||
    image: wazuh/wazuh-kibana:3.13.1_7.8.0
 | 
			
		||||
    image: wazuh/wazuh-kibana:3.9.3_7.2.0-oss
 | 
			
		||||
    hostname: kibana
 | 
			
		||||
    restart: always
 | 
			
		||||
    depends_on:
 | 
			
		||||
@@ -38,9 +38,8 @@ services:
 | 
			
		||||
    links:
 | 
			
		||||
      - elasticsearch:elasticsearch
 | 
			
		||||
      - wazuh:wazuh
 | 
			
		||||
 | 
			
		||||
  nginx:
 | 
			
		||||
    image: wazuh/wazuh-nginx:3.13.1_7.8.0
 | 
			
		||||
    image: wazuh/wazuh-nginx:3.9.3_7.2.0
 | 
			
		||||
    hostname: nginx
 | 
			
		||||
    restart: always
 | 
			
		||||
    environment:
 | 
			
		||||
 
 | 
			
		||||
@@ -1,7 +1,6 @@
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
ARG ELASTIC_VERSION=7.8.0
 | 
			
		||||
FROM docker.elastic.co/elasticsearch/elasticsearch:${ELASTIC_VERSION}
 | 
			
		||||
ARG ELASTIC_VERSION
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
ARG ELASTIC_VERSION=7.2.0
 | 
			
		||||
FROM docker.elastic.co/elasticsearch/elasticsearch-oss:${ELASTIC_VERSION}
 | 
			
		||||
ARG S3_PLUGIN_URL="https://artifacts.elastic.co/downloads/elasticsearch-plugins/repository-s3/repository-s3-${ELASTIC_VERSION}.zip"
 | 
			
		||||
 | 
			
		||||
ENV ELASTICSEARCH_URL="http://elasticsearch:9200"
 | 
			
		||||
@@ -12,18 +11,16 @@ ENV ALERTS_SHARDS="1" \
 | 
			
		||||
ENV API_USER="foo" \
 | 
			
		||||
    API_PASS="bar"
 | 
			
		||||
 | 
			
		||||
ENV XPACK_ML="true"
 | 
			
		||||
 | 
			
		||||
ENV ENABLE_CONFIGURE_S3="false"
 | 
			
		||||
 | 
			
		||||
ARG TEMPLATE_VERSION=v3.13.1
 | 
			
		||||
ARG TEMPLATE_VERSION=v3.9.3
 | 
			
		||||
 | 
			
		||||
# Elasticearch cluster configuration environment variables
 | 
			
		||||
# If ELASTIC_CLUSTER is set to "true" the following variables will be added to the Elasticsearch configuration
 | 
			
		||||
# CLUSTER_INITIAL_MASTER_NODES set to own node by default.
 | 
			
		||||
ENV ELASTIC_CLUSTER="false" \
 | 
			
		||||
    CLUSTER_NAME="wazuh" \
 | 
			
		||||
    CLUSTER_NETWORK_HOST="0.0.0.0" \
 | 
			
		||||
    CLUSTER_NODE_MASTER="false" \
 | 
			
		||||
    CLUSTER_NODE_DATA="true" \
 | 
			
		||||
    CLUSTER_NODE_INGEST="true" \
 | 
			
		||||
@@ -44,7 +41,7 @@ COPY --chown=elasticsearch:elasticsearch ./config/load_settings.sh ./
 | 
			
		||||
 | 
			
		||||
RUN chmod +x ./load_settings.sh
 | 
			
		||||
 | 
			
		||||
RUN bin/elasticsearch-plugin install --batch $S3_PLUGIN_URL
 | 
			
		||||
RUN ${bin/elasticsearch-plugin install --batch S3_PLUGIN_URL}
 | 
			
		||||
 | 
			
		||||
COPY config/configure_s3.sh ./config/configure_s3.sh
 | 
			
		||||
RUN chmod 755 ./config/configure_s3.sh
 | 
			
		||||
 
 | 
			
		||||
@@ -1,5 +1,5 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
 | 
			
		||||
elastic_config_file="/usr/share/elasticsearch/config/elasticsearch.yml"
 | 
			
		||||
 | 
			
		||||
@@ -24,7 +24,7 @@ if [[ $CLUSTER_NODE_MASTER == "true" ]]; then
 | 
			
		||||
# cluster.initial_master_nodes for bootstrap the cluster
 | 
			
		||||
cat > $elastic_config_file << EOF
 | 
			
		||||
# cluster node
 | 
			
		||||
network.host: $CLUSTER_NETWORK_HOST
 | 
			
		||||
network.host: 0.0.0.0
 | 
			
		||||
node.name: $CLUSTER_MASTER_NODE_NAME
 | 
			
		||||
node.master: $CLUSTER_NODE_MASTER
 | 
			
		||||
cluster.initial_master_nodes: 
 | 
			
		||||
@@ -39,7 +39,7 @@ remove_cluster_config $elastic_config_file
 | 
			
		||||
 | 
			
		||||
cat > $elastic_config_file << EOF
 | 
			
		||||
# cluster node
 | 
			
		||||
network.host: $CLUSTER_NETWORK_HOST
 | 
			
		||||
network.host: 0.0.0.0
 | 
			
		||||
node.name: $CLUSTER_NODE_NAME
 | 
			
		||||
node.master: false
 | 
			
		||||
discovery.seed_hosts: 
 | 
			
		||||
 
 | 
			
		||||
@@ -1,5 +1,5 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
 | 
			
		||||
set -e
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -1,5 +1,5 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
 | 
			
		||||
# For more information https://github.com/elastic/elasticsearch-docker/blob/6.8.0/build/elasticsearch/bin/docker-entrypoint.sh
 | 
			
		||||
 | 
			
		||||
@@ -19,28 +19,6 @@ run_as_other_user_if_needed() {
 | 
			
		||||
  fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#Disabling xpack features
 | 
			
		||||
 | 
			
		||||
elasticsearch_config_file="/usr/share/elasticsearch/config/elasticsearch.yml"
 | 
			
		||||
if grep -Fq  "#xpack features" "$elasticsearch_config_file";
 | 
			
		||||
then
 | 
			
		||||
  declare -A CONFIG_MAP=(
 | 
			
		||||
  [xpack.ml.enabled]=$XPACK_ML
 | 
			
		||||
  )
 | 
			
		||||
  for i in "${!CONFIG_MAP[@]}"
 | 
			
		||||
  do
 | 
			
		||||
    if [ "${CONFIG_MAP[$i]}" != "" ]; then
 | 
			
		||||
      sed -i 's/.'"$i"'.*/'"$i"': '"${CONFIG_MAP[$i]}"'/' $elasticsearch_config_file
 | 
			
		||||
    fi
 | 
			
		||||
  done
 | 
			
		||||
else
 | 
			
		||||
  echo "
 | 
			
		||||
#xpack features
 | 
			
		||||
xpack.ml.enabled: $XPACK_ML
 | 
			
		||||
 " >> $elasticsearch_config_file
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
# Run load settings script.
 | 
			
		||||
 | 
			
		||||
./config_cluster.sh
 | 
			
		||||
 
 | 
			
		||||
@@ -1,18 +1,18 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
 | 
			
		||||
set -e
 | 
			
		||||
 | 
			
		||||
el_url=${ELASTICSEARCH_URL}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
if [[ ${ENABLED_XPACK} != "true" || "x${ELASTICSEARCH_USERNAME}" = "x" || "x${ELASTICSEARCH_PASSWORD}" = "x" ]]; then
 | 
			
		||||
  auth=""
 | 
			
		||||
if [ "x${WAZUH_API_URL}" = "x" ]; then
 | 
			
		||||
  wazuh_url="https://wazuh"
 | 
			
		||||
else
 | 
			
		||||
  auth="--user ${ELASTICSEARCH_USERNAME}:${ELASTICSEARCH_PASSWORD}"
 | 
			
		||||
  wazuh_url="${WAZUH_API_URL}"
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
until curl ${auth} -XGET $el_url; do
 | 
			
		||||
 | 
			
		||||
until curl -XGET $el_url; do
 | 
			
		||||
  >&2 echo "Elastic is unavailable - sleeping"
 | 
			
		||||
  sleep 5
 | 
			
		||||
done
 | 
			
		||||
@@ -38,15 +38,44 @@ if [ $ENABLE_CONFIGURE_S3 ]; then
 | 
			
		||||
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
if [ ${ENABLED_XPACK} = "true" ]; then
 | 
			
		||||
curl -XPUT "$el_url/_cluster/settings" ${auth} -H 'Content-Type: application/json' -d'
 | 
			
		||||
{
 | 
			
		||||
  "persistent": {
 | 
			
		||||
    "xpack.monitoring.collection.enabled": true
 | 
			
		||||
#Insert default templates
 | 
			
		||||
 | 
			
		||||
API_PASS_Q=`echo "$API_PASS" | tr -d '"'`
 | 
			
		||||
API_USER_Q=`echo "$API_USER" | tr -d '"'`
 | 
			
		||||
API_PASSWORD=`echo -n $API_PASS_Q | base64`
 | 
			
		||||
 | 
			
		||||
echo "Setting API credentials into Wazuh APP"
 | 
			
		||||
CONFIG_CODE=$(curl -s -o /dev/null -w "%{http_code}" -XGET $el_url/.wazuh/_doc/1513629884013)
 | 
			
		||||
 | 
			
		||||
if [ "x$CONFIG_CODE" != "x200" ]; then
 | 
			
		||||
  curl -s -XPOST $el_url/.wazuh/_doc/1513629884013 -H 'Content-Type: application/json' -d'
 | 
			
		||||
  {
 | 
			
		||||
    "api_user": "'"$API_USER_Q"'",
 | 
			
		||||
    "api_password": "'"$API_PASSWORD"'",
 | 
			
		||||
    "url": "'"$wazuh_url"'",
 | 
			
		||||
    "api_port": "55000",
 | 
			
		||||
    "insecure": "true",
 | 
			
		||||
    "component": "API",
 | 
			
		||||
    "cluster_info": {
 | 
			
		||||
      "manager": "wazuh-manager",
 | 
			
		||||
      "cluster": "Disabled",
 | 
			
		||||
      "status": "disabled"
 | 
			
		||||
    },
 | 
			
		||||
    "extensions": {
 | 
			
		||||
      "oscap": true,
 | 
			
		||||
      "audit": true,
 | 
			
		||||
      "pci": true,
 | 
			
		||||
      "aws": true,
 | 
			
		||||
      "virustotal": true,
 | 
			
		||||
      "gdpr": true,
 | 
			
		||||
      "ciscat": true
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
'
 | 
			
		||||
  }
 | 
			
		||||
  ' > /dev/null
 | 
			
		||||
else
 | 
			
		||||
  echo "Wazuh APP already configured"
 | 
			
		||||
fi
 | 
			
		||||
sleep 5
 | 
			
		||||
 | 
			
		||||
# Set cluster delayed timeout when node falls
 | 
			
		||||
curl -X PUT "$el_url/_all/_settings" -H 'Content-Type: application/json' -d'
 | 
			
		||||
 
 | 
			
		||||
@@ -1,18 +1,21 @@
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
FROM docker.elastic.co/kibana/kibana:7.8.0
 | 
			
		||||
USER kibana
 | 
			
		||||
ARG ELASTIC_VERSION=7.8.0
 | 
			
		||||
ARG WAZUH_VERSION=3.13.1
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
FROM docker.elastic.co/kibana/kibana-oss:7.2.0
 | 
			
		||||
ARG ELASTIC_VERSION=7.2.0
 | 
			
		||||
ARG WAZUH_VERSION=3.9.3
 | 
			
		||||
ARG WAZUH_APP_VERSION="${WAZUH_VERSION}_${ELASTIC_VERSION}"
 | 
			
		||||
 | 
			
		||||
WORKDIR /usr/share/kibana
 | 
			
		||||
RUN ./bin/kibana-plugin install https://packages.wazuh.com/wazuhapp/wazuhapp-${WAZUH_APP_VERSION}.zip
 | 
			
		||||
 | 
			
		||||
WORKDIR /
 | 
			
		||||
USER root
 | 
			
		||||
 | 
			
		||||
ADD  https://packages.wazuh.com/wazuhapp/wazuhapp-${WAZUH_APP_VERSION}.zip /tmp
 | 
			
		||||
 | 
			
		||||
RUN /usr/share/kibana/bin/kibana-plugin install --allow-root file:///tmp/wazuhapp-${WAZUH_APP_VERSION}.zip 
 | 
			
		||||
RUN rm -rf /tmp/wazuhapp-${WAZUH_APP_VERSION}.zip
 | 
			
		||||
 | 
			
		||||
COPY config/entrypoint.sh ./entrypoint.sh
 | 
			
		||||
RUN chmod 755 ./entrypoint.sh
 | 
			
		||||
 | 
			
		||||
USER kibana
 | 
			
		||||
 | 
			
		||||
ENV PATTERN="" \
 | 
			
		||||
    CHECKS_PATTERN="" \
 | 
			
		||||
    CHECKS_TEMPLATE="" \
 | 
			
		||||
@@ -33,21 +36,12 @@ ENV PATTERN="" \
 | 
			
		||||
    WAZUH_VERSION_REPLICAS="" \
 | 
			
		||||
    IP_SELECTOR="" \
 | 
			
		||||
    IP_IGNORE="" \
 | 
			
		||||
    XPACK_RBAC_ENABLED="" \
 | 
			
		||||
    WAZUH_MONITORING_ENABLED="" \
 | 
			
		||||
    WAZUH_MONITORING_FREQUENCY="" \
 | 
			
		||||
    WAZUH_MONITORING_SHARDS="" \
 | 
			
		||||
    WAZUH_MONITORING_REPLICAS="" \
 | 
			
		||||
    ADMIN_PRIVILEGES=""
 | 
			
		||||
 | 
			
		||||
ARG XPACK_CANVAS="true"
 | 
			
		||||
ARG XPACK_LOGS="true"
 | 
			
		||||
ARG XPACK_INFRA="true"
 | 
			
		||||
ARG XPACK_ML="true"
 | 
			
		||||
ARG XPACK_DEVTOOLS="true"
 | 
			
		||||
ARG XPACK_MONITORING="true"
 | 
			
		||||
ARG XPACK_APM="true"
 | 
			
		||||
 | 
			
		||||
ARG CHANGE_WELCOME="false"
 | 
			
		||||
 | 
			
		||||
COPY --chown=kibana:kibana ./config/wazuh_app_config.sh ./
 | 
			
		||||
@@ -58,18 +52,12 @@ COPY --chown=kibana:kibana ./config/kibana_settings.sh ./
 | 
			
		||||
 | 
			
		||||
RUN chmod +x ./kibana_settings.sh
 | 
			
		||||
 | 
			
		||||
COPY --chown=kibana:kibana ./config/xpack_config.sh ./
 | 
			
		||||
 | 
			
		||||
RUN chmod +x ./xpack_config.sh
 | 
			
		||||
 | 
			
		||||
RUN ./xpack_config.sh
 | 
			
		||||
 | 
			
		||||
COPY --chown=kibana:kibana ./config/welcome_wazuh.sh ./
 | 
			
		||||
 | 
			
		||||
RUN chmod +x ./welcome_wazuh.sh
 | 
			
		||||
 | 
			
		||||
RUN ./welcome_wazuh.sh
 | 
			
		||||
USER kibana
 | 
			
		||||
RUN NODE_OPTIONS="--max-old-space-size=2048" /usr/local/bin/kibana-docker --optimize
 | 
			
		||||
 | 
			
		||||
RUN /usr/local/bin/kibana-docker --optimize
 | 
			
		||||
 | 
			
		||||
ENTRYPOINT ./entrypoint.sh
 | 
			
		||||
 
 | 
			
		||||
@@ -1,5 +1,5 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
 | 
			
		||||
set -e
 | 
			
		||||
 | 
			
		||||
@@ -13,13 +13,7 @@ else
 | 
			
		||||
  el_url="${ELASTICSEARCH_URL}"
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
if [[ ${ENABLED_XPACK} != "true" || "x${ELASTICSEARCH_USERNAME}" = "x" || "x${ELASTICSEARCH_PASSWORD}" = "x" ]]; then
 | 
			
		||||
  auth=""
 | 
			
		||||
else
 | 
			
		||||
  auth="--user ${ELASTICSEARCH_USERNAME}:${ELASTICSEARCH_PASSWORD}"
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
until curl -XGET $el_url ${auth}; do
 | 
			
		||||
until curl -XGET $el_url; do
 | 
			
		||||
  >&2 echo "Elastic is unavailable - sleeping"
 | 
			
		||||
  sleep 5
 | 
			
		||||
done
 | 
			
		||||
 
 | 
			
		||||
@@ -1,5 +1,5 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
 | 
			
		||||
WAZUH_MAJOR=3
 | 
			
		||||
 | 
			
		||||
@@ -30,26 +30,13 @@ if [ "$KIBANA_INDEX" != "" ]; then
 | 
			
		||||
    echo "kibana.index: $KIBANA_INDEX" >> /usr/share/kibana/config/kibana.yml
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
# If XPACK_SECURITY_ENABLED was set, then change the xpack.security.enabled option from true (default) to false.
 | 
			
		||||
if [ "$XPACK_SECURITY_ENABLED" != "" ]; then
 | 
			
		||||
  if grep -q 'xpack.security.enabled' /usr/share/kibana/config/kibana.yml; then
 | 
			
		||||
    sed -i '/xpack.security.enabled/d' /usr/share/kibana/config/kibana.yml
 | 
			
		||||
  fi
 | 
			
		||||
    echo "xpack.security.enabled: $XPACK_SECURITY_ENABLED" >> /usr/share/kibana/config/kibana.yml
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
if [ "$KIBANA_IP" != "" ]; then
 | 
			
		||||
  kibana_ip="$KIBANA_IP"
 | 
			
		||||
else
 | 
			
		||||
  kibana_ip="kibana"
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
# Add auth headers if required
 | 
			
		||||
if [ "$ELASTICSEARCH_USERNAME" != "" ] && [ "$ELASTICSEARCH_PASSWORD" != "" ]; then
 | 
			
		||||
    curl_auth="-u $ELASTICSEARCH_USERNAME:$ELASTICSEARCH_PASSWORD"
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
while [[ "$(curl $curl_auth -XGET -I  -s -o /dev/null -w ''%{http_code}'' $kibana_ip:5601/status)" != "200" ]]; do
 | 
			
		||||
while [[ "$(curl -XGET -I  -s -o /dev/null -w ''%{http_code}'' $kibana_ip:5601/status)" != "200" ]]; do
 | 
			
		||||
  echo "Waiting for Kibana API. Sleeping 5 seconds"
 | 
			
		||||
  sleep 5
 | 
			
		||||
done
 | 
			
		||||
 
 | 
			
		||||
@@ -1,14 +1,7 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
 | 
			
		||||
wazuh_url="${WAZUH_API_URL:-https://wazuh}"
 | 
			
		||||
wazuh_port="${API_PORT:-55000}"
 | 
			
		||||
api_user="${API_USER:-foo}"
 | 
			
		||||
api_password="${API_PASS:-bar}"
 | 
			
		||||
 | 
			
		||||
kibana_config_file="/usr/share/kibana/optimize/wazuh/config/wazuh.yml"
 | 
			
		||||
mkdir -p /usr/share/kibana/optimize/wazuh/config/
 | 
			
		||||
touch $kibana_config_file
 | 
			
		||||
kibana_config_file="/usr/share/kibana/plugins/wazuh/config.yml"
 | 
			
		||||
 | 
			
		||||
declare -A CONFIG_MAP=(
 | 
			
		||||
  [pattern]=$PATTERN
 | 
			
		||||
@@ -31,7 +24,6 @@ declare -A CONFIG_MAP=(
 | 
			
		||||
  [wazuh-version.replicas]=$WAZUH_VERSION_REPLICAS
 | 
			
		||||
  [ip.selector]=$IP_SELECTOR
 | 
			
		||||
  [ip.ignore]=$IP_IGNORE
 | 
			
		||||
  [xpack.rbac.enabled]=$XPACK_RBAC_ENABLED
 | 
			
		||||
  [wazuh.monitoring.enabled]=$WAZUH_MONITORING_ENABLED
 | 
			
		||||
  [wazuh.monitoring.frequency]=$WAZUH_MONITORING_FREQUENCY
 | 
			
		||||
  [wazuh.monitoring.shards]=$WAZUH_MONITORING_SHARDS
 | 
			
		||||
@@ -45,24 +37,3 @@ do
 | 
			
		||||
        sed -i 's/.*#'"$i"'.*/'"$i"': '"${CONFIG_MAP[$i]}"'/' $kibana_config_file
 | 
			
		||||
    fi
 | 
			
		||||
done
 | 
			
		||||
 | 
			
		||||
# remove default API entry (new in 3.11.0_7.5.1)
 | 
			
		||||
sed -ie '/- default:/,+4d' $kibana_config_file
 | 
			
		||||
 | 
			
		||||
CONFIG_CODE=$(curl -s -o /dev/null -w "%{http_code}" -XGET $el_url/.wazuh/_doc/1513629884013 ${auth})
 | 
			
		||||
 | 
			
		||||
grep -q 1513629884013 $kibana_config_file
 | 
			
		||||
_config_exists=$?
 | 
			
		||||
 | 
			
		||||
if [[ "x$CONFIG_CODE" != "x200" && $_config_exists -ne 0 ]]; then
 | 
			
		||||
cat << EOF > $kibana_config_file
 | 
			
		||||
hosts:
 | 
			
		||||
  - 1513629884013:
 | 
			
		||||
      url: $wazuh_url
 | 
			
		||||
      port: $wazuh_port
 | 
			
		||||
      user: $api_user
 | 
			
		||||
      password: $api_password
 | 
			
		||||
EOF
 | 
			
		||||
else
 | 
			
		||||
  echo "Wazuh APP already configured"
 | 
			
		||||
fi
 | 
			
		||||
 
 | 
			
		||||
@@ -1,5 +1,5 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
 | 
			
		||||
if [[ $CHANGE_WELCOME == "true" ]]
 | 
			
		||||
then
 | 
			
		||||
@@ -21,3 +21,4 @@ then
 | 
			
		||||
    sed -i 's#visible: true#visible: false#g' $kibana_path/node_modules/x-pack/plugins/rollup/public/crud_app/index.js
 | 
			
		||||
    sed -i 's#visible: true#visible: false#g' $kibana_path/node_modules/x-pack/plugins/license_management/public/management_section.js
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -1,35 +0,0 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
 | 
			
		||||
kibana_config_file="/usr/share/kibana/config/kibana.yml"
 | 
			
		||||
if grep -Fq  "#xpack features" "$kibana_config_file";
 | 
			
		||||
then
 | 
			
		||||
  declare -A CONFIG_MAP=(
 | 
			
		||||
    [xpack.apm.ui.enabled]=$XPACK_APM
 | 
			
		||||
    [xpack.grokdebugger.enabled]=$XPACK_DEVTOOLS
 | 
			
		||||
    [xpack.searchprofiler.enabled]=$XPACK_DEVTOOLS
 | 
			
		||||
    [xpack.ml.enabled]=$XPACK_ML
 | 
			
		||||
    [xpack.canvas.enabled]=$XPACK_CANVAS
 | 
			
		||||
    [xpack.infra.enabled]=$XPACK_INFRA
 | 
			
		||||
    [monitoring.enabled]=$XPACK_MONITORING
 | 
			
		||||
    [console.enabled]=$XPACK_DEVTOOLS
 | 
			
		||||
  )
 | 
			
		||||
  for i in "${!CONFIG_MAP[@]}"
 | 
			
		||||
  do
 | 
			
		||||
    if [ "${CONFIG_MAP[$i]}" != "" ]; then
 | 
			
		||||
      sed -i 's/.'"$i"'.*/'"$i"': '"${CONFIG_MAP[$i]}"'/' $kibana_config_file
 | 
			
		||||
    fi
 | 
			
		||||
  done
 | 
			
		||||
else
 | 
			
		||||
  echo "
 | 
			
		||||
#xpack features
 | 
			
		||||
xpack.apm.ui.enabled: $XPACK_APM
 | 
			
		||||
xpack.grokdebugger.enabled: $XPACK_DEVTOOLS
 | 
			
		||||
xpack.searchprofiler.enabled: $XPACK_DEVTOOLS
 | 
			
		||||
xpack.ml.enabled: $XPACK_ML
 | 
			
		||||
xpack.canvas.enabled: $XPACK_CANVAS
 | 
			
		||||
xpack.infra.enabled: $XPACK_INFRA
 | 
			
		||||
xpack.monitoring.enabled: $XPACK_MONITORING
 | 
			
		||||
console.enabled: $XPACK_DEVTOOLS
 | 
			
		||||
" >> $kibana_config_file
 | 
			
		||||
fi
 | 
			
		||||
@@ -1,4 +1,4 @@
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
FROM nginx:latest
 | 
			
		||||
 | 
			
		||||
ENV DEBIAN_FRONTEND noninteractive
 | 
			
		||||
@@ -16,4 +16,4 @@ VOLUME ["/etc/nginx/conf.d"]
 | 
			
		||||
ENV NGINX_NAME="foo" \
 | 
			
		||||
    NGINX_PWD="bar"
 | 
			
		||||
 | 
			
		||||
ENTRYPOINT [ "/entrypoint.sh" ]
 | 
			
		||||
ENTRYPOINT /entrypoint.sh
 | 
			
		||||
 
 | 
			
		||||
@@ -1,5 +1,5 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
 | 
			
		||||
set -e
 | 
			
		||||
 | 
			
		||||
@@ -30,14 +30,14 @@ if [ ! -f /etc/nginx/conf.d/kibana.htpasswd ]; then
 | 
			
		||||
    do
 | 
			
		||||
      IFS=':' read -r -a credentials <<< "${users[index]}"
 | 
			
		||||
      if [ $index -eq 0 ]; then
 | 
			
		||||
        htpasswd -b -c /etc/nginx/conf.d/kibana.htpasswd ${credentials[0]} ${credentials[1]} >/dev/null
 | 
			
		||||
        echo ${credentials[1]}|htpasswd -i -c /etc/nginx/conf.d/kibana.htpasswd ${credentials[0]} >/dev/null
 | 
			
		||||
      else
 | 
			
		||||
        htpasswd -b /etc/nginx/conf.d/kibana.htpasswd  ${credentials[0]} ${credentials[1]} >/dev/null
 | 
			
		||||
        echo ${credentials[1]}|htpasswd -i /etc/nginx/conf.d/kibana.htpasswd  ${credentials[0]} >/dev/null
 | 
			
		||||
      fi
 | 
			
		||||
    done
 | 
			
		||||
  else
 | 
			
		||||
    # NGINX_PWD and NGINX_NAME are declared in nginx/Dockerfile 
 | 
			
		||||
    htpasswd -b -c /etc/nginx/conf.d/kibana.htpasswd $NGINX_NAME $NGINX_PWD >/dev/null
 | 
			
		||||
    echo $NGINX_PWD|htpasswd -i -c /etc/nginx/conf.d/kibana.htpasswd $NGINX_NAME >/dev/null
 | 
			
		||||
  fi
 | 
			
		||||
else
 | 
			
		||||
  echo "Kibana credentials already configured"
 | 
			
		||||
@@ -52,19 +52,17 @@ if [ "x${KIBANA_HOST}" = "x" ]; then
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
echo "Configuring NGINX"
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
if [ "${NGINX_PORT}" = "443" ]; then
 | 
			
		||||
cat > /etc/nginx/conf.d/default.conf <<EOF
 | 
			
		||||
server {
 | 
			
		||||
    listen 80;
 | 
			
		||||
    listen [::]:80;
 | 
			
		||||
    return 301 https://\$host\$request_uri;
 | 
			
		||||
    return 301 https://\$host:${NGINX_PORT}\$request_uri;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
server {
 | 
			
		||||
    listen ${NGINX_PORT} default_server ssl http2;
 | 
			
		||||
    listen [::]:${NGINX_PORT} ssl http2;
 | 
			
		||||
    listen ${NGINX_PORT} default_server;
 | 
			
		||||
    listen [::]:${NGINX_PORT};
 | 
			
		||||
    ssl on;
 | 
			
		||||
    ssl_certificate /etc/nginx/conf.d/ssl/certs/kibana-access.pem;
 | 
			
		||||
    ssl_certificate_key /etc/nginx/conf.d/ssl/private/kibana-access.key;
 | 
			
		||||
    location / {
 | 
			
		||||
@@ -77,21 +75,5 @@ server {
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
EOF
 | 
			
		||||
else
 | 
			
		||||
cat > /etc/nginx/conf.d/default.conf <<EOF
 | 
			
		||||
server {
 | 
			
		||||
    listen ${NGINX_PORT};
 | 
			
		||||
    listen [::]:${NGINX_PORT};
 | 
			
		||||
    location / {
 | 
			
		||||
        auth_basic "Restricted";
 | 
			
		||||
        auth_basic_user_file /etc/nginx/conf.d/kibana.htpasswd;
 | 
			
		||||
        proxy_pass http://${KIBANA_HOST}/;
 | 
			
		||||
        proxy_buffer_size          128k;
 | 
			
		||||
        proxy_buffers              4 256k;
 | 
			
		||||
        proxy_busy_buffers_size    256k;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
EOF
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
exec nginx -g 'daemon off;'
 | 
			
		||||
nginx -g 'daemon off;'
 | 
			
		||||
 
 | 
			
		||||
@@ -1,19 +1,19 @@
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
FROM phusion/baseimage:0.10.2
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
FROM phusion/baseimage:latest
 | 
			
		||||
 | 
			
		||||
ARG FILEBEAT_VERSION=7.8.0
 | 
			
		||||
ARG FILEBEAT_VERSION=7.2.0
 | 
			
		||||
 | 
			
		||||
ARG WAZUH_VERSION=3.13.1-1
 | 
			
		||||
ARG WAZUH_VERSION=3.9.3-1
 | 
			
		||||
 | 
			
		||||
ENV API_USER="foo" \
 | 
			
		||||
   API_PASS="bar"
 | 
			
		||||
 | 
			
		||||
ARG TEMPLATE_VERSION="v3.13.1"
 | 
			
		||||
ARG TEMPLATE_VERSION="v3.9.3"
 | 
			
		||||
 | 
			
		||||
# Set repositories.
 | 
			
		||||
RUN set -x && echo "deb https://packages.wazuh.com/3.x/apt/ stable main" | tee /etc/apt/sources.list.d/wazuh.list && \
 | 
			
		||||
   curl -s https://packages.wazuh.com/key/GPG-KEY-WAZUH | apt-key add - && \
 | 
			
		||||
   curl --silent --location https://deb.nodesource.com/setup_10.x | bash - && \
 | 
			
		||||
   curl --silent --location https://deb.nodesource.com/setup_8.x | bash - && \
 | 
			
		||||
   echo "postfix postfix/mailname string wazuh-manager" | debconf-set-selections && \
 | 
			
		||||
   echo "postfix postfix/main_mailer_type string 'Internet Site'" | debconf-set-selections && \
 | 
			
		||||
   groupadd -g 1000 ossec && useradd -u 1000 -g 1000 -d /var/ossec ossec
 | 
			
		||||
@@ -38,8 +38,8 @@ COPY config/01-config_filebeat.sh /entrypoint-scripts/01-config_filebeat.sh
 | 
			
		||||
RUN chmod 755 /init.bash && \
 | 
			
		||||
   sync && /init.bash && \
 | 
			
		||||
   sync && rm /init.bash && \
 | 
			
		||||
   curl -L -O https://artifacts.elastic.co/downloads/beats/filebeat/filebeat-${FILEBEAT_VERSION}-amd64.deb &&\
 | 
			
		||||
   dpkg -i filebeat-${FILEBEAT_VERSION}-amd64.deb && rm -f filebeat-${FILEBEAT_VERSION}-amd64.deb && \
 | 
			
		||||
   curl -L -O https://artifacts.elastic.co/downloads/beats/filebeat/filebeat-oss-${FILEBEAT_VERSION}-amd64.deb &&\
 | 
			
		||||
   dpkg -i filebeat-oss-${FILEBEAT_VERSION}-amd64.deb && rm -f filebeat-oss-${FILEBEAT_VERSION}-amd64.deb && \
 | 
			
		||||
   chmod 755 /entrypoint.sh && \
 | 
			
		||||
   chmod 755 /entrypoint-scripts/00-wazuh.sh && \
 | 
			
		||||
   chmod 755 /entrypoint-scripts/01-config_filebeat.sh
 | 
			
		||||
@@ -76,8 +76,5 @@ RUN chmod +x /etc/service/wazuh-api/run && \
 | 
			
		||||
ADD https://raw.githubusercontent.com/wazuh/wazuh/$TEMPLATE_VERSION/extensions/elasticsearch/7.x/wazuh-template.json /etc/filebeat
 | 
			
		||||
RUN chmod go-w /etc/filebeat/wazuh-template.json 
 | 
			
		||||
 | 
			
		||||
ARG WAZUH_FILEBEAT_MODULE="wazuh-filebeat-0.1.tar.gz"
 | 
			
		||||
RUN curl -s https://packages.wazuh.com/3.x/filebeat/${WAZUH_FILEBEAT_MODULE} | tar -xvz -C /usr/share/filebeat/module
 | 
			
		||||
 | 
			
		||||
# Run all services
 | 
			
		||||
ENTRYPOINT ["/entrypoint.sh"]
 | 
			
		||||
@@ -1,5 +1,5 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
 | 
			
		||||
# Wazuh container bootstrap. See the README for information of the environment
 | 
			
		||||
# variables expected by this script.
 | 
			
		||||
@@ -50,15 +50,7 @@ if [  -e ${WAZUH_INSTALL_PATH}/etc-template  ]
 | 
			
		||||
then
 | 
			
		||||
    cp -p /var/ossec/etc-template/internal_options.conf /var/ossec/etc/internal_options.conf
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
# copy missing files from queue-template (in case this is an upgrade from previous versions)
 | 
			
		||||
for filename in /var/ossec/queue-template/*; do
 | 
			
		||||
  fname=$(basename $filename)
 | 
			
		||||
  echo $fname
 | 
			
		||||
  if test ! -e "/var/ossec/data/queue/$fname"; then
 | 
			
		||||
    cp -rp "/var/ossec/queue-template/$fname" /var/ossec/data/queue/
 | 
			
		||||
  fi
 | 
			
		||||
done
 | 
			
		||||
rm /var/ossec/queue/db/.template.db
 | 
			
		||||
 | 
			
		||||
touch ${DATA_PATH}/process_list
 | 
			
		||||
chgrp ossec ${DATA_PATH}/process_list
 | 
			
		||||
@@ -112,22 +104,10 @@ function ossec_shutdown(){
 | 
			
		||||
  ${WAZUH_INSTALL_PATH}/bin/ossec-control stop;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
##############################################################################
 | 
			
		||||
# Allow users to set the container hostname as <node_name> dynamically on
 | 
			
		||||
# container start.
 | 
			
		||||
#
 | 
			
		||||
# To use this:
 | 
			
		||||
# 1. Create your own ossec.conf file
 | 
			
		||||
# 2. In your ossec.conf file, set to_be_replaced_by_hostname as your node_name
 | 
			
		||||
# 3. Mount your custom ossec.conf file at $WAZUH_CONFIG_MOUNT/etc/ossec.conf
 | 
			
		||||
##############################################################################
 | 
			
		||||
sed -i 's/<node_name>to_be_replaced_by_hostname<\/node_name>/<node_name>'"${HOSTNAME}"'<\/node_name>/g' ${WAZUH_INSTALL_PATH}/etc/ossec.conf
 | 
			
		||||
 | 
			
		||||
# Trap exit signals and do a proper shutdown
 | 
			
		||||
trap "ossec_shutdown; exit" SIGINT SIGTERM
 | 
			
		||||
 | 
			
		||||
chmod -R g+rw ${DATA_PATH}
 | 
			
		||||
chmod 750 /var/ossec/agentless/*
 | 
			
		||||
 | 
			
		||||
##############################################################################
 | 
			
		||||
# Interpret any passed arguments (via docker command to this entrypoint) as
 | 
			
		||||
 
 | 
			
		||||
@@ -1,5 +1,5 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
# Wazuh App Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh App Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
 | 
			
		||||
set -e
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -2,7 +2,14 @@ i=0
 | 
			
		||||
DATA_DIRS[((i++))]="api/configuration"
 | 
			
		||||
DATA_DIRS[((i++))]="etc"
 | 
			
		||||
DATA_DIRS[((i++))]="logs"
 | 
			
		||||
DATA_DIRS[((i++))]="queue"
 | 
			
		||||
DATA_DIRS[((i++))]="agentless"
 | 
			
		||||
DATA_DIRS[((i++))]="queue/db"
 | 
			
		||||
DATA_DIRS[((i++))]="queue/rootcheck"
 | 
			
		||||
DATA_DIRS[((i++))]="queue/agent-groups"
 | 
			
		||||
DATA_DIRS[((i++))]="queue/agent-info"
 | 
			
		||||
DATA_DIRS[((i++))]="queue/agents-timestamp"
 | 
			
		||||
DATA_DIRS[((i++))]="queue/agentless"
 | 
			
		||||
DATA_DIRS[((i++))]="queue/cluster"
 | 
			
		||||
DATA_DIRS[((i++))]="queue/rids"
 | 
			
		||||
DATA_DIRS[((i++))]="queue/fts"
 | 
			
		||||
DATA_DIRS[((i++))]="var/multigroups"
 | 
			
		||||
export DATA_DIRS
 | 
			
		||||
 
 | 
			
		||||
@@ -1,5 +1,5 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
 | 
			
		||||
# It will run every .sh script located in entrypoint-scripts folder in lexicographical order
 | 
			
		||||
for script in `ls /entrypoint-scripts/*.sh | sort -n`; do
 | 
			
		||||
 
 | 
			
		||||
@@ -1,4 +1,4 @@
 | 
			
		||||
#!/bin/sh
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
service filebeat start
 | 
			
		||||
tail -f /var/log/filebeat/filebeat
 | 
			
		||||
 
 | 
			
		||||
@@ -1,15 +1,53 @@
 | 
			
		||||
# Wazuh - Filebeat configuration file
 | 
			
		||||
filebeat.modules:
 | 
			
		||||
  - module: wazuh
 | 
			
		||||
    alerts:
 | 
			
		||||
      enabled: true
 | 
			
		||||
    archives:
 | 
			
		||||
      enabled: false
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
filebeat.inputs:
 | 
			
		||||
  - type: log
 | 
			
		||||
    paths:
 | 
			
		||||
      - '/var/ossec/logs/alerts/alerts.json'
 | 
			
		||||
 | 
			
		||||
setup.template.json.enabled: true
 | 
			
		||||
setup.template.json.path: '/etc/filebeat/wazuh-template.json'
 | 
			
		||||
setup.template.json.name: 'wazuh'
 | 
			
		||||
setup.template.json.path: "/etc/filebeat/wazuh-template.json"
 | 
			
		||||
setup.template.json.name: "wazuh"
 | 
			
		||||
setup.template.overwrite: true
 | 
			
		||||
setup.ilm.enabled: false
 | 
			
		||||
 | 
			
		||||
output.elasticsearch.hosts: ['http://elasticsearch:9200']
 | 
			
		||||
processors:
 | 
			
		||||
  - decode_json_fields:
 | 
			
		||||
      fields: ['message']
 | 
			
		||||
      process_array: true
 | 
			
		||||
      max_depth: 200
 | 
			
		||||
      target: ''
 | 
			
		||||
      overwrite_keys: true
 | 
			
		||||
  - drop_fields:
 | 
			
		||||
      fields: ['message', 'ecs', 'beat', 'input_type', 'tags', 'count', '@version', 'log', 'offset', 'type', 'host']
 | 
			
		||||
  - rename:
 | 
			
		||||
      fields:
 | 
			
		||||
        - from: "data.aws.sourceIPAddress"
 | 
			
		||||
          to: "@src_ip"
 | 
			
		||||
      ignore_missing: true
 | 
			
		||||
      fail_on_error: false
 | 
			
		||||
      when:
 | 
			
		||||
        regexp:
 | 
			
		||||
          data.aws.sourceIPAddress: \b\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\b
 | 
			
		||||
  - rename:
 | 
			
		||||
      fields:
 | 
			
		||||
        - from: "data.srcip"
 | 
			
		||||
          to: "@src_ip"
 | 
			
		||||
      ignore_missing: true
 | 
			
		||||
      fail_on_error: false
 | 
			
		||||
      when:
 | 
			
		||||
        regexp:
 | 
			
		||||
          data.srcip: \b\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\b
 | 
			
		||||
  - rename:
 | 
			
		||||
      fields:
 | 
			
		||||
        - from: "data.win.eventdata.ipAddress"
 | 
			
		||||
          to: "@src_ip"
 | 
			
		||||
      ignore_missing: true
 | 
			
		||||
      fail_on_error: false
 | 
			
		||||
      when:
 | 
			
		||||
        regexp:
 | 
			
		||||
          data.win.eventdata.ipAddress: \b\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\b
 | 
			
		||||
 | 
			
		||||
output.elasticsearch:
 | 
			
		||||
  hosts: ['http://elasticsearch:9200']
 | 
			
		||||
  #pipeline: geoip
 | 
			
		||||
  indices:
 | 
			
		||||
    - index: 'wazuh-alerts-3.x-%{+yyyy.MM.dd}'
 | 
			
		||||
 
 | 
			
		||||
@@ -1,5 +1,5 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
 | 
			
		||||
# Initialize the custom data directory layout
 | 
			
		||||
source /data_dirs.env
 | 
			
		||||
 
 | 
			
		||||
@@ -1,4 +1,4 @@
 | 
			
		||||
#!/bin/sh
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
service postfix start
 | 
			
		||||
tail -f /var/log/mail.log
 | 
			
		||||
 
 | 
			
		||||
@@ -1,4 +1,5 @@
 | 
			
		||||
#!/bin/sh
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
service wazuh-api start
 | 
			
		||||
tail -f /var/ossec/data/logs/api.log
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -1,4 +1,5 @@
 | 
			
		||||
#!/bin/sh
 | 
			
		||||
# Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2)
 | 
			
		||||
# Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2)
 | 
			
		||||
service wazuh-manager start
 | 
			
		||||
tail -f /var/ossec/data/logs/ossec.log
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user