mirror of
				https://github.com/telekom-security/tpotce.git
				synced 2025-10-26 02:04:42 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			117 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
| FROM ubuntu:20.04
 | |
| ENV DEBIAN_FRONTEND noninteractive
 | |
| #
 | |
| # Include dist
 | |
| COPY dist/ /root/dist/
 | |
| #
 | |
| # Determine arch, get and install packages
 | |
| RUN ARCH=$(arch) && \
 | |
|       if [ "$ARCH" = "x86_64" ]; then ARCH="amd64"; fi && \
 | |
|       if [ "$ARCH" = "aarch64" ]; then ARCH="arm64"; fi && \
 | |
|     echo "$ARCH" && \
 | |
|     cd /root/dist/ && \
 | |
|     apt-get update -y && \
 | |
|     apt-get install wget -y && \
 | |
|     wget http://ftp.us.debian.org/debian/pool/main/libe/libemu/libemu2_0.2.0+git20120122-1.2+b1_$ARCH.deb \
 | |
|          http://ftp.us.debian.org/debian/pool/main/libe/libemu/libemu-dev_0.2.0+git20120122-1.2+b1_$ARCH.deb && \
 | |
|     apt install ./libemu2_0.2.0+git20120122-1.2+b1_$ARCH.deb \
 | |
|                 ./libemu-dev_0.2.0+git20120122-1.2+b1_$ARCH.deb -y && \
 | |
|     apt-get install -y --no-install-recommends \
 | |
| 	build-essential \
 | |
| 	ca-certificates \
 | |
| 	check \
 | |
| 	cmake \
 | |
| 	cython3 \
 | |
| 	git \
 | |
|         libcap2-bin \
 | |
| 	libcurl4-openssl-dev \
 | |
| 	libev-dev \
 | |
| 	libglib2.0-dev \
 | |
| 	libloudmouth1-dev \
 | |
| 	libnetfilter-queue-dev \
 | |
| 	libnl-3-dev \
 | |
| 	libpcap-dev \
 | |
| 	libssl-dev \
 | |
| 	libtool \
 | |
| 	libudns-dev \
 | |
| 	procps \
 | |
| 	python3 \
 | |
| 	python3-dev \
 | |
| 	python3-boto3 \
 | |
| 	python3-bson \
 | |
| 	python3-yaml \
 | |
| 	fonts-liberation && \
 | |
| #
 | |
| # Get and install dionaea
 | |
|     # Latest master is unstable, SIP causes crashing
 | |
|     git clone --depth=1 https://github.com/dinotools/dionaea -b 0.11.0 /root/dionaea/ && \
 | |
|     cd /root/dionaea && \
 | |
|     #git checkout 1426750b9fd09c5bfeae74d506237333cd8505e2 && \
 | |
|     mkdir build && \
 | |
|     cd build && \
 | |
|     cmake -DCMAKE_INSTALL_PREFIX:PATH=/opt/dionaea .. && \
 | |
|     make && \
 | |
|     make install && \
 | |
| #
 | |
| # Setup user and groups
 | |
|     addgroup --gid 2000 dionaea && \
 | |
|     adduser --system --no-create-home --shell /bin/bash --uid 2000 --disabled-password --disabled-login --gid 2000 dionaea && \
 | |
|     setcap cap_net_bind_service=+ep /opt/dionaea/bin/dionaea && \
 | |
| #
 | |
| # Supply configs and set permissions
 | |
|     chown -R dionaea:dionaea /opt/dionaea/var && \
 | |
|     rm -rf /opt/dionaea/etc/dionaea/* && \
 | |
|     mv /root/dist/etc/* /opt/dionaea/etc/dionaea/ && \
 | |
| #
 | |
| # Setup runtime and clean up
 | |
|     apt-get purge -y \
 | |
|       build-essential \
 | |
|       ca-certificates \
 | |
|       check \
 | |
|       cmake \
 | |
|       cython3 \
 | |
|       git \
 | |
|       libcurl4-openssl-dev \
 | |
|       libemu-dev \
 | |
|       libev-dev \
 | |
|       libglib2.0-dev \
 | |
|       libloudmouth1-dev \
 | |
|       libnetfilter-queue-dev \
 | |
|       libnl-3-dev \
 | |
|       libpcap-dev \
 | |
|       libssl-dev \
 | |
|       libtool \
 | |
|       libudns-dev \
 | |
|       python3 \
 | |
|       python3-dev \   
 | |
|       python3-boto3 \
 | |
|       python3-bson \
 | |
|       python3-yaml \ 
 | |
|       wget && \ 
 | |
| #
 | |
|     apt-get install -y \
 | |
|       ca-certificates \
 | |
|       python3 \
 | |
|       python3-boto3 \
 | |
|       python3-bson \
 | |
|       python3-yaml \
 | |
|       libcurl4 \
 | |
|       libemu2 \
 | |
|       libev4 \
 | |
|       libglib2.0-0 \
 | |
|       libnetfilter-queue1 \
 | |
|       libnl-3-200 \
 | |
|       libpcap0.8 \
 | |
|       libpython3.8 \
 | |
|       libudns0 && \
 | |
| #
 | |
|     apt-get autoremove --purge -y && \
 | |
|     apt-get clean && \
 | |
|     rm -rf /root/* /var/lib/apt/lists/* /tmp/* /var/tmp/* /root/.cache /opt/dionaea/.git
 | |
| #
 | |
| # Start dionaea
 | |
| STOPSIGNAL SIGINT
 | |
| # Dionaea sometimes hangs at 100% CPU usage, if detected process will be killed and container restarts per docker-compose settings
 | |
| HEALTHCHECK CMD if [ $(ps -C mpv -p 1 -o %cpu | tail -n 1 | cut -f 1 -d ".") -gt 90 ]; then kill -2 1; else exit 0; fi
 | |
| USER dionaea:dionaea
 | |
| CMD ["/opt/dionaea/bin/dionaea", "-u", "dionaea", "-g", "dionaea", "-c", "/opt/dionaea/etc/dionaea/dionaea.cfg"]
 | 
