-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathDockerfile
More file actions
59 lines (46 loc) · 1.28 KB
/
Dockerfile
File metadata and controls
59 lines (46 loc) · 1.28 KB
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
FROM alpine:3.23.2@sha256:865b95f46d98cf867a156fe4a135ad3fe50d2056aa3f25ed31662dff6da4eb62
HEALTHCHECK NONE
ENTRYPOINT []
ARG USER_NAME=default
ARG USER_HOME=/home/default
ARG USER_ID=1000
ARG USER_GECOS=Default
SHELL ["/bin/ash", "-euo", "pipefail", "-c"]
RUN apk upgrade --no-cache \
&& apk add --no-cache \
coreutils=9.8-r1 \
curl=8.17.0-r1 \
dasel=2.8.1-r14 \
gawk=5.3.2-r2 \
git=2.52.0-r0 \
grep=3.12-r0 \
jose=14-r0 \
jp=0.4.0-r0 \
jq=1.8.1-r0 \
miller=6.15.0-r7 \
npm=11.11.0-r0 \
openssl=3.5.6-r0 \
pandoc-cli=3.8.2.1-r0 \
pipx=1.8.0-r0 \
py3-pip=25.1.1-r1 \
python3=3.12.13-r0 \
yq-go=4.49.2-r5 \
&& apk cache --no-cache clean \
&& rm -rf /var/cache/apk/*
COPY requirements.txt /tmp/requirements.txt
RUN pipx ensurepath --global \
&& xargs -a /tmp/requirements.txt -n 1 pipx install --global \
&& rm -f /tmp/requirements.txt
COPY package.json /tmp/package.json
RUN jq -r '.dependencies | to_entries[] | "\(.key)@\(.value)"' /tmp/package.json \
| xargs -n 1 npm install -g \
&& rm -f /tmp/package.json
RUN adduser \
--home "${USER_HOME}" \
--uid "${USER_ID}" \
--gecos "${USER_GECOS}" \
--disabled-password \
"${USER_NAME}"
USER "${USER_NAME}"
ENV HOME="${USER_HOME}"
WORKDIR "${HOME}"