forked from BC-SECURITY/Empire
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDockerfile
58 lines (42 loc) · 1.61 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
# NOTE: Only use this when you want to build image locally
# else use `docker pull bcsecurity/empire:{VERSION}`
# all image versions can be found at: https://hub.docker.com/r/bcsecurity/empire/
# -----BUILD COMMANDS----
# 1) build command: `docker build -t bcsecurity/empire .`
# 2) create volume storage: `docker create -v /empire --name data bcsecurity/empire`
# 3) run out container: `docker run -ti --volumes-from data bcsecurity/empire /bin/bash`
# -----RELEASE COMMANDS----
# Handled by GitHub Actions
# -----BUILD ENTRY-----
# image base
FROM python:3.9.4-buster
# extra metadata
LABEL maintainer="bc-security"
LABEL description="Dockerfile base for Empire server."
# env setup
ENV STAGING_KEY=RANDOM
ENV DEBIAN_FRONTEND=noninteractive
# set the def shell for ENV
SHELL ["/bin/bash", "-c"]
RUN apt-get update && \
apt-get -y install \
sudo \
python3-dev \
python3-pip \
apt-transport-https \
&& rm -rf /var/lib/apt/lists/*
RUN wget https://packages.microsoft.com/config/debian/10/packages-microsoft-prod.deb && \
sudo dpkg -i packages-microsoft-prod.deb && \
sudo apt-get update && \
sudo apt-get install -y powershell \
&& rm -rf /var/lib/apt/lists/*
WORKDIR /empire
COPY pyproject.toml /empire
COPY . /empire
RUN mkdir -p /usr/local/share/powershell/Modules && \
cp -r ./empire/server/powershell/Invoke-Obfuscation /usr/local/share/powershell/Modules
RUN sudo pip install poetry && sudo poetry config virtualenvs.create false && sudo poetry install
RUN /empire/setup/reset.sh
RUN rm -rf /empire/server/data/empire*
ENTRYPOINT ["./ps-empire"]
CMD ["server"]