-
Notifications
You must be signed in to change notification settings - Fork 0
/
Dockerfile
189 lines (164 loc) · 6.95 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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
# syntax=docker/dockerfile:1
# NOTE Lint this file with https://hadolint.github.io/hadolint/
# SPDX-FileCopyrightText: 2022 - 2023 Robin Vobruba <[email protected]>
#
# SPDX-License-Identifier: Unlicense
FROM nimlang/nim:2.0.0
# Set parameters like so:
# docker build \
# --build-arg reuse_tool_release="1.0.0" \
# --build-arg okh_tool_bin="build/okh-tool" \
# .
ARG reuse_tool_release=1.0.0
ARG okh_tool_release=0.5.1
ARG okh_tool_bin=okh-tool
ARG repvar_release=0.13.0
ARG projvar_release=0.19.1
ARG mle_release=0.24.0
ARG mlc_release=0.17.1
ARG obadgen_release=0.2.1
ARG osh_dir_std_release=0.7.2
# Installs the FSF REUSE CLI tool
# NOTE This is a bug-fix/hack to ensure installation of dependency 'tzdata'
# to pass non-interactively; see:
# https://stackoverflow.com/a/58264927/586229
ENV DEBIAN_FRONTEND=noninteractive
RUN \
apt-get update && \
apt-get install -y --no-install-recommends \
git \
mercurial \
openssl \
pandoc \
python3.9 \
python3-pip \
rubygems \
wget \
jq \
bc \
&& \
rm -rf /var/lib/apt/lists/*
# libssl-dev \
# reuse \
# ruby-mdl \
# HACK This seems to be required because of an old Docker base image (Ubuntu) of this image (nimlang/nim).
# Otherwise we could just install ruby-mdl with apt (previous RUN command),
# and remove ruby-rubygems as well there.
RUN gem install mdl
# We need to use Python 3.9 (default is 3.8) because of this REUSE bug:
# https://github.com/fsfe/reuse-tool/issues/587
RUN \
rm -Rf /usr/bin/python3 /usr/bin/python && \
ln -sf /usr/bin/python3.9 /usr/bin/python3 && \
ln -sf /usr/bin/python3 /usr/bin/python
ENV PATH="${PATH}:${HOME}/.local/bin"
RUN python3.9 -m pip install reuse==$reuse_tool_release
ENV HOME="/root"
# NOTE Solution from:
# https://www.mail-archive.com/[email protected]/msg19329.html
#RUN \
# wget --quiet http://nz2.archive.ubuntu.com/ubuntu/pool/main/o/openssl/libssl1.1_1.1.1f-1ubuntu2.16_amd64.deb && \
# dpkg -i libssl1.1_*.deb && \
# rm /libssl1.1_*.deb
RUN mkdir /osh-tool
WORKDIR /osh-tool
# Copy the `osh` binary if it exists,
# otherwise downloads and extracts it.
# NOTE We use a begning HACK here,
# COPY-ing:
# * a glob-for-our-binary (build/okh-tool), and
# * a file-that-always-exists (config.nims),
# to be able to conditionally COPY the binary,
# only if it exists.
# Note however, that if the *dir* of the binary does not exist,
# this *will* fail the docker build,
# and thus we reffer to the CWD by default,
# but allow to overwrite this variable (okh_tool_bin);
# see the start of the file for how to.
COPY "$okh_tool_bin"* config.nims ./
ENV OKH_TOOL_PKG="okh-tool-$okh_tool_release-x86_64-unknown-linux-musl"
ENV OKH_TOOL_DL="https://github.com/OPEN-NEXT/LOSH-OKH-tool/releases/download/$okh_tool_release/$OKH_TOOL_PKG.tar.gz"
RUN rm config.nims && \
if ! [ -f okh-tool ] ; \
then \
wget --quiet "$OKH_TOOL_DL" && \
tar xf $OKH_TOOL_PKG.tar.gz && \
mv $OKH_TOOL_PKG/okh-tool ./ && \
rm $OKH_TOOL_PKG.tar.gz && \
rm -Rf $OKH_TOOL_PKG ; \
fi
ENV REPVAR_PKG="repvar-${repvar_release}-x86_64-unknown-linux-musl"
ENV REPVAR_DL="https://github.com/hoijui/repvar/releases/download/$repvar_release/$REPVAR_PKG.tar.gz"
RUN wget --quiet "$REPVAR_DL" && \
tar xf $REPVAR_PKG.tar.gz && \
mv $REPVAR_PKG/repvar ./ && \
rm $REPVAR_PKG.tar.gz && \
rm -Rf $REPVAR_PKG
ENV PROJVAR_PKG="projvar-${projvar_release}-x86_64-unknown-linux-musl"
ENV PROJVAR_DL="https://github.com/hoijui/projvar/releases/download/$projvar_release/$PROJVAR_PKG.tar.gz"
RUN wget --quiet "$PROJVAR_DL" && \
tar xf $PROJVAR_PKG.tar.gz && \
mv $PROJVAR_PKG/projvar ./ && \
rm $PROJVAR_PKG.tar.gz && \
rm -Rf $PROJVAR_PKG
ENV MLE_PKG="mle-${mle_release}-x86_64-unknown-linux-musl"
ENV MLE_DL="https://github.com/hoijui/mle/releases/download/$mle_release/$MLE_PKG.tar.gz"
RUN wget --quiet "$MLE_DL" && \
tar xf $MLE_PKG.tar.gz && \
mv $MLE_PKG/mle ./ && \
rm $MLE_PKG.tar.gz && \
rm -Rf $MLE_PKG
ENV MLC_PKG="mlc-${mlc_release}-x86_64-unknown-linux-musl"
ENV MLC_DL="https://github.com/hoijui/mlc/releases/download/$mlc_release/$MLC_PKG.tar.gz"
RUN wget --quiet "$MLC_DL" && \
tar xf $MLC_PKG.tar.gz && \
mv $MLC_PKG/mlc ./ && \
rm $MLC_PKG.tar.gz && \
rm -Rf $MLC_PKG
ENV OBADGEN_PKG="obadgen-${obadgen_release}-x86_64-unknown-linux-musl"
ENV OBADGEN_DL="https://github.com/hoijui/obadgen/releases/download/$obadgen_release/$OBADGEN_PKG.tar.gz"
RUN wget --quiet "$OBADGEN_DL" && \
tar xf $OBADGEN_PKG.tar.gz && \
mv $OBADGEN_PKG/obadgen ./ && \
rm $OBADGEN_PKG.tar.gz && \
rm -Rf $OBADGEN_PKG
ENV OSH_DIR_STD_PKG="osh-dir-std-${osh_dir_std_release}-x86_64-unknown-linux-musl"
ENV OSH_DIR_STD_DL="https://github.com/hoijui/osh-dir-std-rs/releases/download/$osh_dir_std_release/$OSH_DIR_STD_PKG.tar.gz"
RUN wget --quiet "$OSH_DIR_STD_DL" && \
tar xf $OSH_DIR_STD_PKG.tar.gz && \
mv $OSH_DIR_STD_PKG/osh-dir-std ./ && \
rm $OSH_DIR_STD_PKG.tar.gz && \
rm -Rf $OSH_DIR_STD_PKG
ENV IS_PUB_NAME="is-git-forge-public"
#ENV IS_PUB_CLONE_URL="https://github.com/hoijui/is-git-forge-public.git"
ENV IS_PUB_DL="https://raw.githubusercontent.com/hoijui/is-git-forge-public/master/src/software/$IS_PUB_NAME"
RUN wget "$IS_PUB_DL" && \
chmod +x "$IS_PUB_NAME"
# Ensures the `osh` tool is in PATH
ENV OSH_TOOL_CLONE_URL="https://github.com/hoijui/osh-tool.git"
RUN \
# Checkout all the osh-tool sources \
git clone --recurse-submodules $OSH_TOOL_CLONE_URL sources && \
cd /osh-tool/sources && \
git submodule update --init && \
# Builds the `osh` tool
nimble -y build && cp build/osh ../ && \
cd ..
# NOTE This fixes a bug; see:
# https://github.com/actions/runner/issues/2033
RUN git config --global --add safe.directory /github/workspace
COPY report_gen* /osh-tool/
ENV PATH="${PATH}:/osh-tool"
LABEL org.opencontainers.artifact.description: human readable description for the artifact (string)
LABEL org.opencontainers.image.authors="Robin Vobruba <[email protected]>"
LABEL org.opencontainers.image.url="https://github.com/hoijui/osh-tool/blob/master/README.md"
LABEL org.opencontainers.image.source="https://github.com/hoijui/osh-tool/blob/master/Dockerfile"
# org.opencontainers.image.version version of the packaged software
# The version MAY match a label or tag in the source code repository
# version MAY be Semantic versioning-compatible
# org.opencontainers.image.revision Source control revision identifier for the packaged software.
# org.opencontainers.image.licenses License(s) under which contained software is distributed as an SPDX License Expression.
LABEL org.opencontainers.image.title="OSH-Tool"
LABEL org.opencontainers.image.description="Contains the OSH Check/Linter CLI tool and all its requirements"
WORKDIR /data
CMD ["report_gen", "--download-badges"]