mirror of
				https://github.com/telekom-security/tpotce.git
				synced 2025-10-25 09:44:45 +00:00 
			
		
		
		
	 de38e5e86f
			
		
	
	
		de38e5e86f
		
	
	
	
	
		
			
			Setting static limits for Elasticsearch / Logstash on Xms, Xmx and Container RAM results in unwanted side effects for some installations. With Elastic supporting dynamic heap management for Java 14+ we now use OpenJDK 16 JRE and as such remove limitations. This should improve stability for T-Pot, provided the minimum requirements will be met.
		
			
				
	
	
		
			235 lines
		
	
	
	
		
			5.5 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			235 lines
		
	
	
	
		
			5.5 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| # T-Pot (Medical)
 | |
| # Do not erase ports sections, these are used by /opt/tpot/bin/rules.sh to setup iptables ACCEPT rules for NFQ (honeytrap / glutton)
 | |
| version: '2.3'
 | |
| 
 | |
| networks:
 | |
|   cyberchef_local:
 | |
|   dicompot_local:
 | |
|   medpot_local:
 | |
|   ewsposter_local:
 | |
|   spiderfoot_local:
 | |
| 
 | |
| services:
 | |
| 
 | |
| ##################
 | |
| #### Honeypots
 | |
| ##################
 | |
| 
 | |
| # Dicompot service
 | |
| # Get the Horos Client for testing: https://horosproject.org/
 | |
| # Get Dicom images (CC BY 3.0): https://www.cancerimagingarchive.net/collections/
 | |
| # Put images (which must be in Dicom DCM format or it will not work!) into /data/dicompot/images
 | |
|   dicompot:
 | |
|     container_name: dicompot
 | |
|     restart: always
 | |
|     networks:
 | |
|      - dicompot_local
 | |
|     ports:
 | |
|      - "11112:11112"
 | |
|     image: "dtagdevsec/dicompot:2006"
 | |
|     read_only: true
 | |
|     volumes:
 | |
|      - /data/dicompot/log:/var/log/dicompot
 | |
| #     - /data/dicompot/images:/opt/dicompot/images
 | |
| 
 | |
| # Medpot service
 | |
|   medpot:
 | |
|     container_name: medpot
 | |
|     restart: always
 | |
|     networks:
 | |
|      - medpot_local
 | |
|     ports:
 | |
|      - "2575:2575"
 | |
|     image: "dtagdevsec/medpot:2006"
 | |
|     read_only: true
 | |
|     volumes:
 | |
|      - /data/medpot/log/:/var/log/medpot
 | |
| 
 | |
| ##################
 | |
| #### NSM
 | |
| ##################
 | |
| 
 | |
| # Fatt service
 | |
|   fatt:
 | |
|     container_name: fatt
 | |
|     restart: always
 | |
|     network_mode: "host"
 | |
|     cap_add:
 | |
|      - NET_ADMIN
 | |
|      - SYS_NICE
 | |
|      - NET_RAW
 | |
|     image: "dtagdevsec/fatt:2006"
 | |
|     volumes:
 | |
|      - /data/fatt/log:/opt/fatt/log
 | |
| 
 | |
| # P0f service
 | |
|   p0f:
 | |
|     container_name: p0f
 | |
|     restart: always
 | |
|     network_mode: "host"
 | |
|     image: "dtagdevsec/p0f:2006"
 | |
|     read_only: true
 | |
|     volumes:
 | |
|      - /data/p0f/log:/var/log/p0f
 | |
| 
 | |
| # Suricata service
 | |
|   suricata:
 | |
|     container_name: suricata
 | |
|     restart: always
 | |
|     environment:
 | |
|     # For ET Pro ruleset replace "OPEN" with your OINKCODE
 | |
|      - OINKCODE=OPEN
 | |
|     network_mode: "host"
 | |
|     cap_add:
 | |
|      - NET_ADMIN
 | |
|      - SYS_NICE
 | |
|      - NET_RAW
 | |
|     image: "dtagdevsec/suricata:2006"
 | |
|     volumes:
 | |
|      - /data/suricata/log:/var/log/suricata
 | |
| 
 | |
| 
 | |
| ##################
 | |
| #### Tools
 | |
| ##################
 | |
| 
 | |
| # Cyberchef service
 | |
|   cyberchef:
 | |
|     container_name: cyberchef
 | |
|     restart: always
 | |
|     networks:
 | |
|      - cyberchef_local
 | |
|     ports:
 | |
|      - "127.0.0.1:64299:8000"
 | |
|     image: "dtagdevsec/cyberchef:2006"
 | |
|     read_only: true
 | |
| 
 | |
| #### ELK
 | |
| ## Elasticsearch service
 | |
|   elasticsearch:
 | |
|     container_name: elasticsearch
 | |
|     restart: always
 | |
|     environment:
 | |
|      - bootstrap.memory_lock=true
 | |
| #     - ES_JAVA_OPTS=-Xms2048m -Xmx2048m
 | |
|      - ES_TMPDIR=/tmp
 | |
|     cap_add:
 | |
|      - IPC_LOCK
 | |
|     ulimits:
 | |
|       memlock:
 | |
|         soft: -1
 | |
|         hard: -1
 | |
|       nofile:
 | |
|         soft: 65536
 | |
|         hard: 65536
 | |
| #    mem_limit: 4g
 | |
|     ports:
 | |
|      - "127.0.0.1:64298:9200"
 | |
|     image: "dtagdevsec/elasticsearch:2006"
 | |
|     volumes:
 | |
|      - /data:/data
 | |
| 
 | |
| ## Kibana service
 | |
|   kibana:
 | |
|     container_name: kibana
 | |
|     restart: always
 | |
|     depends_on:
 | |
|       elasticsearch:
 | |
|         condition: service_healthy
 | |
|     ports:
 | |
|      - "127.0.0.1:64296:5601"
 | |
|     image: "dtagdevsec/kibana:2006"
 | |
| 
 | |
| ## Logstash service
 | |
|   logstash:
 | |
|     container_name: logstash
 | |
|     restart: always
 | |
| #    environment:
 | |
| #     - LS_JAVA_OPTS=-Xms2048m -Xmx2048m
 | |
|     depends_on:
 | |
|       elasticsearch:
 | |
|         condition: service_healthy
 | |
|     env_file:
 | |
|      - /opt/tpot/etc/compose/elk_environment
 | |
|     image: "dtagdevsec/logstash:2006"
 | |
|     volumes:
 | |
|      - /data:/data
 | |
| 
 | |
| ## Elasticsearch-head service
 | |
|   head:
 | |
|     container_name: head
 | |
|     restart: always
 | |
|     depends_on:
 | |
|       elasticsearch:
 | |
|         condition: service_healthy
 | |
|     ports:
 | |
|      - "127.0.0.1:64302:9100"
 | |
|     image: "dtagdevsec/head:2006"
 | |
|     read_only: true
 | |
| 
 | |
| # Ewsposter service
 | |
|   ewsposter:
 | |
|     container_name: ewsposter
 | |
|     restart: always
 | |
|     networks:
 | |
|      - ewsposter_local
 | |
|     environment:
 | |
|      - EWS_HPFEEDS_ENABLE=false
 | |
|      - EWS_HPFEEDS_HOST=host
 | |
|      - EWS_HPFEEDS_PORT=port
 | |
|      - EWS_HPFEEDS_CHANNELS=channels
 | |
|      - EWS_HPFEEDS_IDENT=user
 | |
|      - EWS_HPFEEDS_SECRET=secret
 | |
|      - EWS_HPFEEDS_TLSCERT=false
 | |
|      - EWS_HPFEEDS_FORMAT=json
 | |
|     env_file:
 | |
|      - /opt/tpot/etc/compose/elk_environment
 | |
|     image: "dtagdevsec/ewsposter:2006"
 | |
|     volumes:
 | |
|      - /data:/data
 | |
|      - /data/ews/conf/ews.ip:/opt/ewsposter/ews.ip
 | |
| 
 | |
| # Nginx service
 | |
|   nginx:
 | |
|     container_name: nginx
 | |
|     restart: always
 | |
|     environment:
 | |
|     ### If set to YES all changes within Heimdall will remain for the next start
 | |
|     ### Make sure to uncomment the corresponding volume statements below, or the setting will prevent a successful start of T-Pot.
 | |
|      - HEIMDALL_PERSIST=NO
 | |
|     tmpfs:
 | |
|      - /var/tmp/nginx/client_body
 | |
|      - /var/tmp/nginx/proxy
 | |
|      - /var/tmp/nginx/fastcgi
 | |
|      - /var/tmp/nginx/uwsgi
 | |
|      - /var/tmp/nginx/scgi 
 | |
|      - /run
 | |
|      - /var/log/php7/
 | |
|      - /var/lib/nginx/tmp:uid=100,gid=82 
 | |
|      - /var/lib/nginx/html/storage/logs:uid=100,gid=82
 | |
|      - /var/lib/nginx/html/storage/framework/views:uid=100,gid=82
 | |
|     network_mode: "host"
 | |
|     ports:
 | |
|      - "64297:64297"
 | |
|      - "127.0.0.1:64304:64304"
 | |
|     image: "dtagdevsec/nginx:2006"
 | |
|     read_only: true
 | |
|     volumes:
 | |
|      - /data/nginx/cert/:/etc/nginx/cert/:ro
 | |
|      - /data/nginx/conf/nginxpasswd:/etc/nginx/nginxpasswd:ro
 | |
|      - /data/nginx/log/:/var/log/nginx/
 | |
|     ### Enable the following volumes if you set HEIMDALL_PERSIST=YES
 | |
|     # - /data/nginx/heimdall/database:/var/lib/nginx/html/database
 | |
|     # - /data/nginx/heimdall/storage:/var/lib/nginx/html/storage
 | |
| 
 | |
| # Spiderfoot service
 | |
|   spiderfoot:
 | |
|     container_name: spiderfoot
 | |
|     restart: always
 | |
|     networks:
 | |
|      - spiderfoot_local
 | |
|     ports:
 | |
|      - "127.0.0.1:64303:8080"
 | |
|     image: "dtagdevsec/spiderfoot:2006"
 | |
|     volumes:
 | |
|      - /data/spiderfoot/spiderfoot.db:/home/spiderfoot/spiderfoot.db
 |