mirror of
				https://github.com/wazuh/wazuh-docker.git
				synced 2025-10-24 16:43:37 +00:00 
			
		
		
		
	Compare commits
	
		
			57 Commits
		
	
	
		
			v3.11.2_7.
			...
			devel
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | e9fec0e497 | ||
|  | 7042854bfa | ||
|  | b63c294288 | ||
|  | 9df61de961 | ||
|  | 86ff04c0b3 | ||
|  | 0992111200 | ||
|  | a1a27922de | ||
|  | eba6bc6752 | ||
|  | 2df878f040 | ||
|  | 4acc3b402b | ||
|  | eba4fdf8eb | ||
|  | 1f825c13be | ||
|  | 3cfa63fc2e | ||
|  | 77b163bf10 | ||
|  | 2921d67de1 | ||
|  | edb1c69294 | ||
|  | 9536ff5963 | ||
|  | 146dbff787 | ||
|  | 489bd01f36 | ||
|  | 54c5c643da | ||
|  | 7e9abfab60 | ||
|  | 183519e2d5 | ||
|  | 75e7f3df62 | ||
|  | 99ddc15cf6 | ||
|  | c0a503bc81 | ||
|  | 966a3dcef7 | ||
|  | 9fc689206d | ||
|  | 9b329b095e | ||
|  | f0ba8c3e63 | ||
|  | edae7d3c6a | ||
|  | af5db1efac | ||
|  | 14f0d6d622 | ||
|  | cb60fc8b77 | ||
|  | 4f612e5426 | ||
|  | 90074777da | ||
|  | 320061f022 | ||
|  | 125f83e6df | ||
|  | 707fe87804 | ||
|  | c9a43bd5ff | ||
|  | 26679d46f6 | ||
|  | 627e9517d8 | ||
|  | ced83faef0 | ||
|  | 3b1814ec7b | ||
|  | 26d381b403 | ||
|  | 79f402ca2f | ||
|  | d0ba0465fe | ||
|  | 5dbfa958b7 | ||
|  | c13680e084 | ||
|  | e2559957da | ||
|  | 6afb9d0779 | ||
|  | 6412cb90f9 | ||
|  | bde4351a2a | ||
|  | 4f7ae19d81 | ||
|  | d1f1e401b1 | ||
|  | ea27c239b2 | ||
|  | e437c1a4ec | ||
|  | 1f57ad6619 | 
							
								
								
									
										69
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										69
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,6 +1,73 @@ | ||||
| # Change Log | ||||
| All notable changes to this project will be documented in this file. | ||||
|  | ||||
| ## Wazuh Docker v3.13.1_7.8.0 | ||||
|  | ||||
| ### 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 | ||||
| @@ -182,7 +249,7 @@ All notable changes to this project will be documented in this file. | ||||
| - Add env credentials for nginx. ([#86](https://github.com/wazuh/wazuh-docker/pull/86)) | ||||
| - Improve filebeat configuration ([#88](https://github.com/wazuh/wazuh-docker/pull/88)) | ||||
|  | ||||
| ### Fixed  | ||||
| ### Fixed | ||||
|  | ||||
| - Temporary fix for Wazuh cluster master node in Kubernetes. ([#84](https://github.com/wazuh/wazuh-docker/pull/84)) | ||||
|  | ||||
|   | ||||
							
								
								
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							| @@ -1,5 +1,5 @@ | ||||
|  | ||||
|  Portions Copyright (C) 2019 Wazuh, Inc. | ||||
|  Portions Copyright (C) 2020 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 | ||||
|   | ||||
| @@ -10,9 +10,9 @@ In this repository you will find the containers to run: | ||||
| * wazuh: It runs the Wazuh manager, Wazuh API and Filebeat (for integration with Elastic Stack) | ||||
| * wazuh-kibana: Provides a web user interface to browse through alerts data. It includes Wazuh plugin for Kibana, that allows you to visualize agents configuration and status. | ||||
| * wazuh-nginx: Proxies the Kibana container, adding HTTPS (via self-signed SSL certificate) and [Basic authentication](https://developer.mozilla.org/en-US/docs/Web/HTTP/Authentication#Basic_authentication_scheme). | ||||
| * wazuh-elasticsearch: An Elasticsearch container (working as a single-node cluster) using Elastic Stack Docker images. **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).**  | ||||
| * wazuh-elasticsearch: An Elasticsearch container (working as a single-node cluster) using Elastic Stack Docker images. **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).** | ||||
|  | ||||
| In addition, a docker-compose file is provided to launch the containers mentioned above.  | ||||
| In addition, a docker-compose file is provided to launch the containers mentioned above. | ||||
|  | ||||
| * Elasticsearch cluster. In the Elasticsearch Dockerfile we can visualize variables to configure an Elasticsearch Cluster. These variables are used in the file *config_cluster.sh* to set them in the *elasticsearch.yml* configuration file. You can see the meaning of the node variables [here](https://www.elastic.co/guide/en/elasticsearch/reference/current/modules-node.html) and other cluster settings [here](https://github.com/elastic/elasticsearch/blob/master/distribution/src/config/elasticsearch.yml). | ||||
|  | ||||
| @@ -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.10.2_7.5.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.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. | ||||
|  | ||||
| ## 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) 2019 Wazuh Inc. (License GPLv2) | ||||
| Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
|  | ||||
| ## Web references | ||||
|  | ||||
|   | ||||
							
								
								
									
										4
									
								
								VERSION
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								VERSION
									
									
									
									
									
								
							| @@ -1,2 +1,2 @@ | ||||
| WAZUH-DOCKER_VERSION="3.11.2_7.5.1" | ||||
| REVISION="31120" | ||||
| WAZUH-DOCKER_VERSION="3.13.1_7.8.0" | ||||
| REVISION="31310" | ||||
|   | ||||
| @@ -1,9 +1,9 @@ | ||||
| # Wazuh App Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh App Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
| version: '2' | ||||
|  | ||||
| services: | ||||
|   wazuh: | ||||
|     image: wazuh/wazuh:3.11.2_7.5.1 | ||||
|     image: wazuh/wazuh:3.13.1_7.8.0 | ||||
|     hostname: wazuh-manager | ||||
|     restart: always | ||||
|     ports: | ||||
| @@ -13,7 +13,7 @@ services: | ||||
|       - "55000:55000" | ||||
|  | ||||
|   elasticsearch: | ||||
|     image: wazuh/wazuh-elasticsearch:3.11.2_7.5.1 | ||||
|     image: wazuh/wazuh-elasticsearch:3.13.1_7.8.0 | ||||
|     hostname: elasticsearch | ||||
|     restart: always | ||||
|     ports: | ||||
| @@ -30,7 +30,7 @@ services: | ||||
|     mem_limit: 2g | ||||
|  | ||||
|   kibana: | ||||
|     image: wazuh/wazuh-kibana:3.11.2_7.5.1 | ||||
|     image: wazuh/wazuh-kibana:3.13.1_7.8.0 | ||||
|     hostname: kibana | ||||
|     restart: always | ||||
|     depends_on: | ||||
| @@ -38,8 +38,9 @@ services: | ||||
|     links: | ||||
|       - elasticsearch:elasticsearch | ||||
|       - wazuh:wazuh | ||||
|  | ||||
|   nginx: | ||||
|     image: wazuh/wazuh-nginx:3.11.2_7.5.1 | ||||
|     image: wazuh/wazuh-nginx:3.13.1_7.8.0 | ||||
|     hostname: nginx | ||||
|     restart: always | ||||
|     environment: | ||||
| @@ -51,4 +52,4 @@ services: | ||||
|     depends_on: | ||||
|       - kibana | ||||
|     links: | ||||
|       - kibana:kibana | ||||
|       - kibana:kibana | ||||
| @@ -1,5 +1,5 @@ | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| ARG ELASTIC_VERSION=7.5.1 | ||||
| # 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 | ||||
| ARG S3_PLUGIN_URL="https://artifacts.elastic.co/downloads/elasticsearch-plugins/repository-s3/repository-s3-${ELASTIC_VERSION}.zip" | ||||
| @@ -12,17 +12,18 @@ ENV ALERTS_SHARDS="1" \ | ||||
| ENV API_USER="foo" \ | ||||
|     API_PASS="bar" | ||||
|  | ||||
| ENV XPACK_ML="true"  | ||||
| ENV XPACK_ML="true" | ||||
|  | ||||
| ENV ENABLE_CONFIGURE_S3="false" | ||||
|  | ||||
| ARG TEMPLATE_VERSION=v3.11.2 | ||||
| ARG TEMPLATE_VERSION=v3.13.1 | ||||
|  | ||||
| # 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" \ | ||||
| @@ -35,7 +36,7 @@ ENV ELASTIC_CLUSTER="false" \ | ||||
|     CLUSTER_DELAYED_TIMEOUT="1m" \ | ||||
|     CLUSTER_INITIAL_MASTER_NODES="wazuh-elasticsearch" | ||||
|  | ||||
| COPY config/entrypoint.sh /entrypoint.sh  | ||||
| COPY config/entrypoint.sh /entrypoint.sh | ||||
|  | ||||
| RUN chmod 755 /entrypoint.sh | ||||
|  | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
| #!/bin/bash | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
|  | ||||
| elastic_config_file="/usr/share/elasticsearch/config/elasticsearch.yml" | ||||
|  | ||||
| remove_single_node_conf(){ | ||||
|   if grep -Fq "discovery.type" $1; then | ||||
|     sed -i '/discovery.type\: /d' $1  | ||||
|     sed -i '/discovery.type\: /d' $1 | ||||
|   fi | ||||
| } | ||||
|  | ||||
| @@ -24,12 +24,12 @@ if [[ $CLUSTER_NODE_MASTER == "true" ]]; then | ||||
| # cluster.initial_master_nodes for bootstrap the cluster | ||||
| cat > $elastic_config_file << EOF | ||||
| # cluster node | ||||
| network.host: 0.0.0.0 | ||||
| network.host: $CLUSTER_NETWORK_HOST | ||||
| node.name: $CLUSTER_MASTER_NODE_NAME | ||||
| node.master: $CLUSTER_NODE_MASTER | ||||
| cluster.initial_master_nodes:  | ||||
| cluster.initial_master_nodes: | ||||
|   - $CLUSTER_MASTER_NODE_NAME | ||||
| # end cluster config"  | ||||
| # end cluster config" | ||||
| EOF | ||||
|  | ||||
| elif [[ $CLUSTER_NODE_NAME != "" ]];then | ||||
| @@ -39,13 +39,13 @@ remove_cluster_config $elastic_config_file | ||||
|  | ||||
| cat > $elastic_config_file << EOF | ||||
| # cluster node | ||||
| network.host: 0.0.0.0 | ||||
| network.host: $CLUSTER_NETWORK_HOST | ||||
| node.name: $CLUSTER_NODE_NAME | ||||
| node.master: false | ||||
| discovery.seed_hosts:  | ||||
| discovery.seed_hosts: | ||||
|   - $CLUSTER_MASTER_NODE_NAME | ||||
|   - $CLUSTER_NODE_NAME | ||||
| # end cluster config"  | ||||
| # end cluster config" | ||||
| EOF | ||||
| fi | ||||
| # If the cluster is disabled, then set a single-node configuration | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| #!/bin/bash | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
|  | ||||
| set -e | ||||
|  | ||||
| @@ -10,7 +10,7 @@ function CheckArgs() | ||||
| { | ||||
|     if [ $1 != 4 ] && [ $1 != 5 ];then | ||||
|         echo "Use: configure_s3.sh <Elastic_Server_IP:Port> <Bucket> <Path> <RepositoryName> (By default <current_elasticsearch_major_version> is added to the path and the repository name)" | ||||
|         echo "or use: configure_s3.sh <Elastic_Server_IP:Port> <Bucket> <Path> <RepositoryName> <Elasticsearch major version>"  | ||||
|         echo "or use: configure_s3.sh <Elastic_Server_IP:Port> <Bucket> <Path> <RepositoryName> <Elasticsearch major version>" | ||||
|         exit 1 | ||||
|  | ||||
|     fi | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| #!/bin/bash | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
|  | ||||
| # For more information https://github.com/elastic/elasticsearch-docker/blob/6.8.0/build/elasticsearch/bin/docker-entrypoint.sh | ||||
|  | ||||
| @@ -24,7 +24,7 @@ run_as_other_user_if_needed() { | ||||
|  | ||||
| elasticsearch_config_file="/usr/share/elasticsearch/config/elasticsearch.yml" | ||||
| if grep -Fq  "#xpack features" "$elasticsearch_config_file"; | ||||
| then  | ||||
| then | ||||
|   declare -A CONFIG_MAP=( | ||||
|   [xpack.ml.enabled]=$XPACK_ML | ||||
|   ) | ||||
| @@ -49,4 +49,4 @@ fi | ||||
|  | ||||
| # Execute elasticsearch | ||||
|  | ||||
| run_as_other_user_if_needed /usr/share/elasticsearch/bin/elasticsearch  | ||||
| run_as_other_user_if_needed /usr/share/elasticsearch/bin/elasticsearch | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| #!/bin/bash | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
|  | ||||
| set -e | ||||
|  | ||||
| @@ -24,13 +24,13 @@ if [ $ENABLE_CONFIGURE_S3 ]; then | ||||
|   sleep 10 | ||||
|   IP_PORT="${ELASTICSEARCH_IP}:${ELASTICSEARCH_PORT}" | ||||
|  | ||||
|   if [ "x$S3_PATH" != "x" ]; then  | ||||
|   if [ "x$S3_PATH" != "x" ]; then | ||||
|  | ||||
|     if [ "x$S3_ELASTIC_MAJOR" != "x" ]; then  | ||||
|       ./config/configure_s3.sh $IP_PORT $S3_BUCKET_NAME $S3_PATH $S3_REPOSITORY_NAME $S3_ELASTIC_MAJOR  | ||||
|     if [ "x$S3_ELASTIC_MAJOR" != "x" ]; then | ||||
|       ./config/configure_s3.sh $IP_PORT $S3_BUCKET_NAME $S3_PATH $S3_REPOSITORY_NAME $S3_ELASTIC_MAJOR | ||||
|  | ||||
|     else | ||||
|       ./config/configure_s3.sh $IP_PORT $S3_BUCKET_NAME $S3_PATH $S3_REPOSITORY_NAME  | ||||
|       ./config/configure_s3.sh $IP_PORT $S3_BUCKET_NAME $S3_PATH $S3_REPOSITORY_NAME | ||||
|  | ||||
|     fi | ||||
|  | ||||
| @@ -38,7 +38,7 @@ 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": { | ||||
| @@ -46,6 +46,7 @@ curl -XPUT "$el_url/_cluster/settings" ${auth} -H 'Content-Type: application/jso | ||||
|   } | ||||
| } | ||||
| ' | ||||
| fi | ||||
|  | ||||
| # Set cluster delayed timeout when node falls | ||||
| curl -X PUT "$el_url/_all/_settings" -H 'Content-Type: application/json' -d' | ||||
|   | ||||
| @@ -1,15 +1,14 @@ | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| FROM docker.elastic.co/kibana/kibana:7.5.1 | ||||
| # Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
| FROM docker.elastic.co/kibana/kibana:7.8.0 | ||||
| USER kibana | ||||
| ARG ELASTIC_VERSION=7.5.1 | ||||
| ARG WAZUH_VERSION=3.11.2 | ||||
| ARG ELASTIC_VERSION=7.8.0 | ||||
| ARG WAZUH_VERSION=3.13.1 | ||||
| ARG WAZUH_APP_VERSION="${WAZUH_VERSION}_${ELASTIC_VERSION}" | ||||
|  | ||||
| #ADD  https://packages.wazuh.com/wazuhapp/wazuhapp-${WAZUH_APP_VERSION}.zip /usr/share/kibana/ | ||||
|  | ||||
| RUN /usr/share/kibana/bin/kibana-plugin install https://packages.wazuh.com/wazuhapp/wazuhapp-${WAZUH_APP_VERSION}.zip | ||||
| # RUN rm -rf /tmp/wazuhapp-${WAZUH_APP_VERSION}.zip | ||||
| WORKDIR /usr/share/kibana | ||||
| RUN ./bin/kibana-plugin install https://packages.wazuh.com/wazuhapp/wazuhapp-${WAZUH_APP_VERSION}.zip | ||||
|  | ||||
| WORKDIR / | ||||
| USER root | ||||
| COPY config/entrypoint.sh ./entrypoint.sh | ||||
| RUN chmod 755 ./entrypoint.sh | ||||
| @@ -71,6 +70,6 @@ RUN chmod +x ./welcome_wazuh.sh | ||||
|  | ||||
| RUN ./welcome_wazuh.sh | ||||
| USER kibana | ||||
| RUN /usr/local/bin/kibana-docker --optimize | ||||
| RUN NODE_OPTIONS="--max-old-space-size=2048" /usr/local/bin/kibana-docker --optimize | ||||
|  | ||||
| ENTRYPOINT ./entrypoint.sh | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| #!/bin/bash | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
|  | ||||
| set -e | ||||
|  | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| #!/bin/bash | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
|  | ||||
| WAZUH_MAJOR=3 | ||||
|  | ||||
| ############################################################################## | ||||
| # Wait for the Kibana API to start. It is necessary to do it in this container | ||||
| # because the others are running Elastic Stack and we can not interrupt them.  | ||||
| #  | ||||
| # because the others are running Elastic Stack and we can not interrupt them. | ||||
| # | ||||
| # The following actions are performed: | ||||
| # | ||||
| # Add the wazuh alerts index as default. | ||||
| @@ -44,12 +44,17 @@ else | ||||
|   kibana_ip="kibana" | ||||
| fi | ||||
|  | ||||
| while [[ "$(curl -XGET -I  -s -o /dev/null -w ''%{http_code}'' $kibana_ip:5601/status)" != "200" ]]; do | ||||
| # 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 | ||||
|   echo "Waiting for Kibana API. Sleeping 5 seconds" | ||||
|   sleep 5 | ||||
| done | ||||
|  | ||||
| # Prepare index selection.  | ||||
| # Prepare index selection. | ||||
| echo "Kibana API is running" | ||||
|  | ||||
| default_index="/tmp/default_index.json" | ||||
|   | ||||
| @@ -1,12 +1,14 @@ | ||||
| #!/bin/bash | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 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/plugins/wazuh/wazuh.yml" | ||||
| kibana_config_file="/usr/share/kibana/optimize/wazuh/config/wazuh.yml" | ||||
| mkdir -p /usr/share/kibana/optimize/wazuh/config/ | ||||
| touch $kibana_config_file | ||||
|  | ||||
| declare -A CONFIG_MAP=( | ||||
|   [pattern]=$PATTERN | ||||
| @@ -53,7 +55,8 @@ grep -q 1513629884013 $kibana_config_file | ||||
| _config_exists=$? | ||||
|  | ||||
| if [[ "x$CONFIG_CODE" != "x200" && $_config_exists -ne 0 ]]; then | ||||
| cat << EOF >> $kibana_config_file  | ||||
| cat << EOF > $kibana_config_file | ||||
| hosts: | ||||
|   - 1513629884013: | ||||
|       url: $wazuh_url | ||||
|       port: $wazuh_port | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| #!/bin/bash | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
|  | ||||
| if [[ $CHANGE_WELCOME == "true" ]] | ||||
| then | ||||
| @@ -21,4 +21,3 @@ 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,9 +1,9 @@ | ||||
| #!/bin/bash | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # 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  | ||||
| then | ||||
|   declare -A CONFIG_MAP=( | ||||
|     [xpack.apm.ui.enabled]=$XPACK_APM | ||||
|     [xpack.grokdebugger.enabled]=$XPACK_DEVTOOLS | ||||
| @@ -11,7 +11,7 @@ then | ||||
|     [xpack.ml.enabled]=$XPACK_ML | ||||
|     [xpack.canvas.enabled]=$XPACK_CANVAS | ||||
|     [xpack.infra.enabled]=$XPACK_INFRA | ||||
|     [xpack.monitoring.enabled]=$XPACK_MONITORING | ||||
|     [monitoring.enabled]=$XPACK_MONITORING | ||||
|     [console.enabled]=$XPACK_DEVTOOLS | ||||
|   ) | ||||
|   for i in "${!CONFIG_MAP[@]}" | ||||
| @@ -23,7 +23,7 @@ then | ||||
| else | ||||
|   echo " | ||||
| #xpack features | ||||
| xpack.apm.ui.enabled: $XPACK_APM  | ||||
| xpack.apm.ui.enabled: $XPACK_APM | ||||
| xpack.grokdebugger.enabled: $XPACK_DEVTOOLS | ||||
| xpack.searchprofiler.enabled: $XPACK_DEVTOOLS | ||||
| xpack.ml.enabled: $XPACK_ML | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 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) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 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 | ||||
|         echo ${credentials[1]}|htpasswd -i -c /etc/nginx/conf.d/kibana.htpasswd ${credentials[0]} >/dev/null | ||||
|         htpasswd -b -c /etc/nginx/conf.d/kibana.htpasswd ${credentials[0]} ${credentials[1]} >/dev/null | ||||
|       else | ||||
|         echo ${credentials[1]}|htpasswd -i /etc/nginx/conf.d/kibana.htpasswd  ${credentials[0]} >/dev/null | ||||
|         htpasswd -b /etc/nginx/conf.d/kibana.htpasswd  ${credentials[0]} ${credentials[1]} >/dev/null | ||||
|       fi | ||||
|     done | ||||
|   else | ||||
|     # NGINX_PWD and NGINX_NAME are declared in nginx/Dockerfile  | ||||
|     echo $NGINX_PWD|htpasswd -i -c /etc/nginx/conf.d/kibana.htpasswd $NGINX_NAME >/dev/null | ||||
|     # 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 | ||||
|   fi | ||||
| else | ||||
|   echo "Kibana credentials already configured" | ||||
| @@ -52,17 +52,19 @@ 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:${NGINX_PORT}\$request_uri; | ||||
|     return 301 https://\$host\$request_uri; | ||||
| } | ||||
|  | ||||
| server { | ||||
|     listen ${NGINX_PORT} default_server; | ||||
|     listen [::]:${NGINX_PORT}; | ||||
|     ssl on; | ||||
|     listen ${NGINX_PORT} default_server ssl http2; | ||||
|     listen [::]:${NGINX_PORT} ssl http2; | ||||
|     ssl_certificate /etc/nginx/conf.d/ssl/certs/kibana-access.pem; | ||||
|     ssl_certificate_key /etc/nginx/conf.d/ssl/private/kibana-access.key; | ||||
|     location / { | ||||
| @@ -75,5 +77,21 @@ 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 | ||||
|  | ||||
| nginx -g 'daemon off;' | ||||
| exec nginx -g 'daemon off;' | ||||
|   | ||||
| @@ -1,14 +1,14 @@ | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| FROM phusion/baseimage:latest | ||||
| # Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
| FROM phusion/baseimage:0.10.2 | ||||
|  | ||||
| ARG FILEBEAT_VERSION=7.5.1 | ||||
| ARG FILEBEAT_VERSION=7.8.0 | ||||
|  | ||||
| ARG WAZUH_VERSION=3.11.2-1 | ||||
| ARG WAZUH_VERSION=3.13.1-1 | ||||
|  | ||||
| ENV API_USER="foo" \ | ||||
|    API_PASS="bar" | ||||
|  | ||||
| ARG TEMPLATE_VERSION="v3.11.2" | ||||
| ARG TEMPLATE_VERSION="v3.13.1" | ||||
|  | ||||
| # Set repositories. | ||||
| RUN set -x && echo "deb https://packages.wazuh.com/3.x/apt/ stable main" | tee /etc/apt/sources.list.d/wazuh.list && \ | ||||
| @@ -70,11 +70,14 @@ COPY config/filebeat.runit.service /etc/service/filebeat/run | ||||
| RUN chmod +x /etc/service/wazuh-api/run && \ | ||||
|    chmod +x /etc/service/wazuh/run && \ | ||||
|    chmod +x /etc/service/postfix/run && \ | ||||
|    chmod +x /etc/service/filebeat/run  | ||||
|    chmod +x /etc/service/filebeat/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  | ||||
| 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) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
|  | ||||
| # Wazuh container bootstrap. See the README for information of the environment | ||||
| # variables expected by this script. | ||||
| @@ -50,7 +50,15 @@ if [  -e ${WAZUH_INSTALL_PATH}/etc-template  ] | ||||
| then | ||||
|     cp -p /var/ossec/etc-template/internal_options.conf /var/ossec/etc/internal_options.conf | ||||
| fi | ||||
| rm /var/ossec/queue/db/.template.db | ||||
|  | ||||
| # 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 | ||||
|  | ||||
| touch ${DATA_PATH}/process_list | ||||
| chgrp ossec ${DATA_PATH}/process_list | ||||
| @@ -119,6 +127,7 @@ sed -i 's/<node_name>to_be_replaced_by_hostname<\/node_name>/<node_name>'"${HOST | ||||
| 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 | ||||
| @@ -143,4 +152,4 @@ echo "Change Wazuh API user credentials" | ||||
| change_user="node htpasswd -b -c user $API_USER $API_PASS" | ||||
| eval $change_user | ||||
|  | ||||
| popd | ||||
| popd | ||||
|   | ||||
| @@ -1,19 +1,10 @@ | ||||
| #!/bin/bash | ||||
| # Wazuh App Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh App Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
|  | ||||
| set -e | ||||
|  | ||||
| WAZUH_FILEBEAT_MODULE=wazuh-filebeat-0.1.tar.gz | ||||
|  | ||||
| # Modify the output to Elasticsearch if th ELASTICSEARCH_URL is set | ||||
| if [ "$ELASTICSEARCH_URL" != "" ]; then | ||||
|   >&2 echo "Customize Elasticsearch ouput IP." | ||||
|   sed -i 's|http://elasticsearch:9200|'$ELASTICSEARCH_URL'|g' /etc/filebeat/filebeat.yml | ||||
| fi | ||||
|  | ||||
| # Install Wazuh Filebeat Module | ||||
|  | ||||
| curl -s "https://packages.wazuh.com/3.x/filebeat/${WAZUH_FILEBEAT_MODULE}" | tar -xvz -C /usr/share/filebeat/module | ||||
| mkdir -p /usr/share/filebeat/module/wazuh | ||||
| chmod 755 -R /usr/share/filebeat/module/wazuh | ||||
|  | ||||
|   | ||||
| @@ -2,14 +2,7 @@ i=0 | ||||
| DATA_DIRS[((i++))]="api/configuration" | ||||
| DATA_DIRS[((i++))]="etc" | ||||
| DATA_DIRS[((i++))]="logs" | ||||
| 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++))]="queue" | ||||
| DATA_DIRS[((i++))]="agentless" | ||||
| DATA_DIRS[((i++))]="var/multigroups" | ||||
| export DATA_DIRS | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| #!/bin/bash | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 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 | ||||
| @@ -11,4 +11,4 @@ done | ||||
| # Start Wazuh Server. | ||||
| ############################################################################## | ||||
|  | ||||
| /sbin/my_init  | ||||
| /sbin/my_init | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| #!/bin/sh | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
| service filebeat start | ||||
| tail -f /var/log/filebeat/filebeat | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| #!/bin/bash | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
|  | ||||
| # Initialize the custom data directory layout | ||||
| source /data_dirs.env | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| #!/bin/sh | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
| service postfix start | ||||
| tail -f /var/log/mail.log | ||||
|   | ||||
| @@ -1,5 +1,4 @@ | ||||
| #!/bin/sh | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
| service wazuh-api start | ||||
| tail -f /var/ossec/data/logs/api.log | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,4 @@ | ||||
| #!/bin/sh | ||||
| # Wazuh Docker Copyright (C) 2019 Wazuh Inc. (License GPLv2) | ||||
| # Wazuh Docker Copyright (C) 2020 Wazuh Inc. (License GPLv2) | ||||
| service wazuh-manager start | ||||
| tail -f /var/ossec/data/logs/ossec.log | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user