-
Notifications
You must be signed in to change notification settings - Fork 4
/
Dockerfile
124 lines (88 loc) · 3.55 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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
# docker build -t firmadyne .
FROM ubuntu:18.04
WORKDIR /opt
ARG DEBIAN_FRONTEND=noninteractive
ENV DEBIAN_FRONTEND=noninteractive
# Update packages
RUN apt-get update && apt-get upgrade -y && apt-get install -y sudo
#TZ
ADD tzset.sh /tmp
RUN chmod +x /tmp/tzset.sh
RUN /tmp/tzset.sh
ENV TZ=America/New_York
RUN sudo apt-get update && sudo apt-get -y upgrade
RUN sudo apt-get install busybox-static fakeroot git tmux dmsetup kpartx netcat-openbsd nmap python-psycopg2 python3-psycopg2 libmagic1 python-lzma python-lzo liblzo2-dev python-six snmp uml-utilities util-linux vlan git unzip curl wget nano postgresql-client socat -y
RUN sudo apt-get install qemu-system-arm qemu-system-mips qemu-system-x86 qemu-utils build-essential liblzma-dev liblzo2-dev zlib1g-dev pkg-config libfontconfig1-dev -y
# Weird hijack to install on ubuntu 18....
RUN wget http://mirrors.kernel.org/ubuntu/pool/universe/c/cramfs/cramfsprogs_1.1-6ubuntu1_amd64.deb -O /tmp/cramfsprogs_1.1-6ubuntu1_amd64.deb && sudo dpkg -i /tmp/cramfsprogs_1.1-6ubuntu1_amd64.deb
RUN sudo apt-get install mtd-utils gzip bzip2 tar arj lhasa p7zip p7zip-full cabextract cramfsswap squashfs-tools sleuthkit default-jdk lzop srecord -y -m
# Adds for binwalk
RUN sudo apt install python3-distutils -y
# Python & pip
RUN sudo apt-get update && apt-get install -y python python-crcmod python3-pip
RUN sudo curl https://bootstrap.pypa.io/pip/2.7/get-pip.py -o ./get-pip.py
RUN sudo python get-pip.py
RUN sudo pip3 install python-magic
RUN cd /opt
RUN sudo -H pip install git+https://github.com/ahupp/python-magic
RUN sudo -H pip install git+https://github.com/sviehb/jefferson
# Ubifs
RUN cd /opt
RUN sudo git clone --recursive https://github.com/nlitsme/ubidump.git
RUN pip install crcmod
RUN cd /opt
RUN sudo git clone --recursive https://github.com/jrspruitt/ubi_reader.git -b v0.8.5-master
RUN cd ubi_reader
RUN sudo pip install ubi_reader
WORKDIR /opt/ubi_reader
RUN chmod +x /opt/ubi_reader/setup.py
RUN sudo python /opt/ubi_reader/setup.py install
WORKDIR /opt
# Rust cargo
RUN curl https://sh.rustup.rs -sSf | sh -s -- -y
ENV PATH="/root/.cargo/bin:${PATH}"
# Binwalk
RUN cd /opt
RUN wget https://github.com/ReFirmLabs/binwalk/archive/refs/tags/v3.1.0.zip
RUN unzip /opt/v3.1.0.zip
RUN cd /opt/binwalk-3.1.0/
RUN cargo install binwalk
#RUN sudo git clone --recursive https://github.com/ReFirmLabs/binwalk.git
#RUN cd /opt/binwalk/
#WORKDIR /opt/binwalk
#RUN python setup.py install
#RUN python3 setup.py install
# sasquatch
WORKDIR /opt
RUN cd /opt
RUN sudo git clone --recursive https://github.com/devttys0/sasquatch.git
RUN cd /opt/sasquatch/
WORKDIR /opt/sasquatch
RUN ./build.sh
# Clone Firmaadyne repo
WORKDIR /opt
RUN cd /opt
RUN git clone --recursive https://github.com/firmadyne/firmadyne.git
RUN mkdir -p /opt/firmadyne/samples/
RUN mkdir -p /opt/firmadyne/samples-out/
WORKDIR /opt/firmadyne
RUN /opt/firmadyne/download.sh
RUN sed -i '49 a USER=firmadyne' /opt/firmadyne/scripts/makeImage.sh
RUN sed -i '4 a FIRMWARE_DIR=/opt/firmadyne' /opt/firmadyne/firmadyne.config
# Postgres
RUN cd /opt
# Create firmadyne user
RUN useradd -m firmadyne
RUN echo "firmadyne:firmadyne" | chpasswd && adduser firmadyne sudo
USER root
COPY autodyne-0.5b.sh /opt/firmadyne
RUN chmod +x /opt/firmadyne/autodyne-0.5b.sh
COPY startup.sh /opt/firmadyne/startup.sh
RUN chmod +x /opt/firmadyne/startup.sh
COPY autodyne-cfg.sh /etc/autodyne-cfg.sh
RUN chmod +x /etc/autodyne-cfg.sh
RUN chown -R firmadyne:firmadyne /opt/firmadyne
RUN chown firmadyne:firmadyne /etc/autodyne-cfg.sh
#USER firmadyne
ENTRYPOINT ["/opt/firmadyne/startup.sh"]
CMD ["/bin/bash"]