forked from MobSF/Mobile-Security-Framework-MobSF
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Dockerfile
105 lines (86 loc) · 2.96 KB
/
Dockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
# Base image
FROM ubuntu:20.04
# Labels and Credits
LABEL \
name="MobSF" \
author="Ajin Abraham <ajin25@gmail.com>" \
maintainer="Ajin Abraham <ajin25@gmail.com>" \
contributor_1="OscarAkaElvis <oscar.alfonso.diaz@gmail.com>" \
contributor_2="Vincent Nadal <vincent.nadal@orange.fr>" \
description="Mobile Security Framework (MobSF) is an automated, all-in-one mobile application (Android/iOS/Windows) pen-testing, malware analysis and security assessment framework capable of performing static and dynamic analysis."
# Environment vars
ENV DEBIAN_FRONTEND="noninteractive" \
ANALYZER_IDENTIFIER="" \
JDK_FILE="openjdk-16.0.1_linux-x64_bin.tar.gz" \
JDK_FILE_ARM="openjdk-16.0.1_linux-aarch64_bin.tar.gz" \
WKH_FILE="wkhtmltox_0.12.6-1.focal_amd64.deb" \
WKH_FILE_ARM="wkhtmltox_0.12.6-1.focal_arm64.deb" \
JAVA_HOME="/jdk-16.0.1"
ENV PATH="$JAVA_HOME/bin:$PATH"
# See https://docs.docker.com/develop/develop-images/dockerfile_best-practices/#run
RUN apt update -y && apt install -y --no-install-recommends \
build-essential \
locales \
sqlite3 \
fontconfig-config \
libjpeg-turbo8 \
libxrender1 \
libfontconfig1 \
libxext6 \
fontconfig \
xfonts-75dpi \
xfonts-base \
python3.9 \
python3-dev \
python3-pip \
wget \
curl \
git \
android-tools-adb
# Set locales
RUN locale-gen en_US.UTF-8
ENV LANG='en_US.UTF-8' LANGUAGE='en_US:en' LC_ALL='en_US.UTF-8'
# Install wkhtmltopdf & OpenJDK
ARG TARGETPLATFORM
COPY scripts/install_java_wkhtmltopdf.sh .
RUN ./install_java_wkhtmltopdf.sh
RUN groupadd -g 9901 mobsf
RUN adduser mobsf --shell /bin/false -u 9901 --ingroup mobsf --gecos "" --disabled-password
# Install Requirements
COPY requirements.txt .
RUN pip3 install --upgrade --no-cache-dir setuptools pip && \
pip3 install --quiet --no-cache-dir -r requirements.txt
# Cleanup
RUN \
apt remove -y \
libssl-dev \
libffi-dev \
libxml2-dev \
libxslt1-dev \
python3-dev \
wget && \
apt clean && \
apt autoclean && \
apt autoremove -y && \
rm -rf /var/lib/apt/lists/* /tmp/* > /dev/null 2>&1
WORKDIR /home/mobsf/Mobile-Security-Framework-MobSF
# Copy source code
COPY . .
# Set adb binary path and apktool directory
RUN sed -i "s#ADB_BINARY = ''#ADB_BINARY = '/usr/bin/adb'#" mobsf/MobSF/settings.py && \
mkdir -p /home/mobsf/.local/share/apktool/framework
# Postgres support is set to false by default
ARG POSTGRES=False
ENV POSTGRES_USER=postgres
ENV POSTGRES_PASSWORD=password
ENV POSTGRES_DB=mobsf
ENV POSTGRES_HOST=postgres
# Check if Postgres support needs to be enabled
RUN ./scripts/postgres_support.sh $POSTGRES
HEALTHCHECK CMD curl --fail http://host.docker.internal:8000/ || exit 1
# Expose MobSF Port and Proxy Port
EXPOSE 8000 8000 1337 1337
RUN chown -R mobsf:mobsf /home/mobsf/Mobile-Security-Framework-MobSF
USER mobsf
# Run MobSF
CMD ["/home/mobsf/Mobile-Security-Framework-MobSF/scripts/entrypoint.sh"]