Browse code

Add generate.sh for armhf deb Dockerfiles

Signed-off-by: Kenfe-Mickael Laventure <mickael.laventure@gmail.com>

Kenfe-Mickael Laventure authored on 2016/11/22 06:21:45
Showing 6 changed files
... ...
@@ -1,15 +1,20 @@
1
+#
2
+# THIS FILE IS AUTOGENERATED; SEE "contrib/builder/deb/armhf/generate.sh"!
3
+#
4
+
1 5
 FROM armhf/debian:jessie
2 6
 
3
-# allow replacing httpredir mirror
4
-ARG APT_MIRROR=httpredir.debian.org
5
-RUN sed -i s/httpredir.debian.org/$APT_MIRROR/g /etc/apt/sources.list
7
+# allow replacing httpredir or deb mirror
8
+ARG APT_MIRROR=deb.debian.org
9
+RUN sed -ri "s/(httpredir|deb).debian.org/$APT_MIRROR/g" /etc/apt/sources.list
6 10
 
7
-RUN apt-get update && apt-get install -y apparmor bash-completion btrfs-tools build-essential cmake curl ca-certificates debhelper dh-apparmor dh-systemd git libapparmor-dev libdevmapper-dev libltdl-dev libsqlite3-dev libsystemd-journal-dev vim-common --no-install-recommends && rm -rf /var/lib/apt/lists/*
11
+RUN apt-get update && apt-get install -y apparmor bash-completion btrfs-tools build-essential cmake curl ca-certificates debhelper dh-apparmor dh-systemd git libapparmor-dev libdevmapper-dev libltdl-dev  libsqlite3-dev pkg-config vim-common libsystemd-journal-dev --no-install-recommends && rm -rf /var/lib/apt/lists/*
8 12
 
9 13
 ENV GO_VERSION 1.7.3
10 14
 RUN curl -fSL "https://golang.org/dl/go${GO_VERSION}.linux-armv6l.tar.gz" | tar xzC /usr/local
11 15
 ENV PATH $PATH:/usr/local/go/bin
12 16
 
13 17
 ENV AUTO_GOPATH 1
14
-ENV DOCKER_BUILDTAGS apparmor selinux
18
+
19
+ENV DOCKER_BUILDTAGS apparmor pkcs11 selinux
15 20
 ENV RUNC_BUILDTAGS apparmor selinux
16 21
new file mode 100755
... ...
@@ -0,0 +1,158 @@
0
+#!/bin/bash
1
+set -e
2
+
3
+# usage: ./generate.sh [versions]
4
+#    ie: ./generate.sh
5
+#        to update all Dockerfiles in this directory
6
+#    or: ./generate.sh debian-jessie
7
+#        to only update debian-jessie/Dockerfile
8
+#    or: ./generate.sh debian-newversion
9
+#        to create a new folder and a Dockerfile within it
10
+
11
+cd "$(dirname "$(readlink -f "$BASH_SOURCE")")"
12
+
13
+versions=( "$@" )
14
+if [ ${#versions[@]} -eq 0 ]; then
15
+	versions=( */ )
16
+fi
17
+versions=( "${versions[@]%/}" )
18
+
19
+for version in "${versions[@]}"; do
20
+	distro="${version%-*}"
21
+	suite="${version##*-}"
22
+	from="${distro}:${suite}"
23
+
24
+	case "$from" in
25
+		raspbian:jessie)
26
+			from="resin/rpi-raspbian:jessie"
27
+			;;
28
+		*)
29
+			from="armhf/$from"
30
+			;;
31
+	esac
32
+
33
+	mkdir -p "$version"
34
+	echo "$version -> FROM $from"
35
+	cat > "$version/Dockerfile" <<-EOF
36
+		#
37
+		# THIS FILE IS AUTOGENERATED; SEE "contrib/builder/deb/armhf/generate.sh"!
38
+		#
39
+
40
+		FROM $from
41
+	EOF
42
+
43
+	echo >> "$version/Dockerfile"
44
+
45
+	if [[ "$distro" = "debian" || "$distro" = "raspbian" ]]; then
46
+		cat >> "$version/Dockerfile" <<-'EOF'
47
+			# allow replacing httpredir or deb mirror
48
+			ARG APT_MIRROR=deb.debian.org
49
+			RUN sed -ri "s/(httpredir|deb).debian.org/$APT_MIRROR/g" /etc/apt/sources.list
50
+		EOF
51
+
52
+		if [ "$suite" = "wheezy" ]; then
53
+			cat >> "$version/Dockerfile" <<-'EOF'
54
+				RUN sed -ri "s/(httpredir|deb).debian.org/$APT_MIRROR/g" /etc/apt/sources.list.d/backports.list
55
+			EOF
56
+		fi
57
+
58
+		echo "" >> "$version/Dockerfile"
59
+	fi
60
+
61
+	extraBuildTags='pkcs11'
62
+	runcBuildTags=
63
+
64
+	# this list is sorted alphabetically; please keep it that way
65
+	packages=(
66
+		apparmor # for apparmor_parser for testing the profile
67
+		bash-completion # for bash-completion debhelper integration
68
+		btrfs-tools # for "btrfs/ioctl.h" (and "version.h" if possible)
69
+		build-essential # "essential for building Debian packages"
70
+		cmake # tini dep
71
+		curl ca-certificates # for downloading Go
72
+		debhelper # for easy ".deb" building
73
+		dh-apparmor # for apparmor debhelper
74
+		dh-systemd # for systemd debhelper integration
75
+		git # for "git commit" info in "docker -v"
76
+		libapparmor-dev # for "sys/apparmor.h"
77
+		libdevmapper-dev # for "libdevmapper.h"
78
+		libltdl-dev # for pkcs11 "ltdl.h"
79
+		libseccomp-dev  # for "seccomp.h" & "libseccomp.so"
80
+		libsqlite3-dev # for "sqlite3.h"
81
+		pkg-config # for detecting things like libsystemd-journal dynamically
82
+		vim-common # tini dep
83
+	)
84
+	# packaging for "sd-journal.h" and libraries varies
85
+	case "$suite" in
86
+		precise|wheezy) ;;
87
+		jessie|trusty) packages+=( libsystemd-journal-dev );;
88
+		*) packages+=( libsystemd-dev );;
89
+	esac
90
+
91
+	# debian wheezy & ubuntu precise do not have the right libseccomp libs
92
+	# debian jessie & ubuntu trusty have a libseccomp < 2.2.1 :(
93
+	case "$suite" in
94
+		precise|wheezy|jessie|trusty)
95
+			packages=( "${packages[@]/libseccomp-dev}" )
96
+			runcBuildTags="apparmor selinux"
97
+			;;
98
+		*)
99
+			extraBuildTags+=' seccomp'
100
+			runcBuildTags="apparmor seccomp selinux"
101
+			;;
102
+	esac
103
+
104
+
105
+	if [ "$suite" = 'precise' ]; then
106
+		# precise has a few package issues
107
+
108
+		# - dh-systemd doesn't exist at all
109
+		packages=( "${packages[@]/dh-systemd}" )
110
+
111
+		# - libdevmapper-dev is missing critical structs (too old)
112
+		packages=( "${packages[@]/libdevmapper-dev}" )
113
+		extraBuildTags+=' exclude_graphdriver_devicemapper'
114
+
115
+		# - btrfs-tools is missing "ioctl.h" (too old), so it's useless
116
+		#   (since kernels on precise are old too, just skip btrfs entirely)
117
+		packages=( "${packages[@]/btrfs-tools}" )
118
+		extraBuildTags+=' exclude_graphdriver_btrfs'
119
+	fi
120
+
121
+	if [ "$suite" = 'wheezy' ]; then
122
+		# pull a couple packages from backports explicitly
123
+		# (build failures otherwise)
124
+		backportsPackages=( btrfs-tools )
125
+		for pkg in "${backportsPackages[@]}"; do
126
+			packages=( "${packages[@]/$pkg}" )
127
+		done
128
+		echo "RUN apt-get update && apt-get install -y -t $suite-backports ${backportsPackages[*]} --no-install-recommends && rm -rf /var/lib/apt/lists/*" >> "$version/Dockerfile"
129
+	fi
130
+
131
+	echo "RUN apt-get update && apt-get install -y ${packages[*]} --no-install-recommends && rm -rf /var/lib/apt/lists/*" >> "$version/Dockerfile"
132
+
133
+	echo >> "$version/Dockerfile"
134
+
135
+	awk '$1 == "ENV" && $2 == "GO_VERSION" { print; exit }' ../../../../Dockerfile >> "$version/Dockerfile"
136
+	if [ "$distro" == 'raspbian' ];
137
+	then
138
+		cat <<EOF >> "$version/Dockerfile"
139
+# GOARM is the ARM architecture version which is unrelated to the above Golang version
140
+ENV GOARM 6
141
+EOF
142
+	fi
143
+	echo 'RUN curl -fSL "https://golang.org/dl/go${GO_VERSION}.linux-armv6l.tar.gz" | tar xzC /usr/local' >> "$version/Dockerfile"
144
+	echo 'ENV PATH $PATH:/usr/local/go/bin' >> "$version/Dockerfile"
145
+
146
+	echo >> "$version/Dockerfile"
147
+
148
+	echo 'ENV AUTO_GOPATH 1' >> "$version/Dockerfile"
149
+
150
+	echo >> "$version/Dockerfile"
151
+
152
+	# print build tags in alphabetical order
153
+	buildTags=$( echo "apparmor selinux $extraBuildTags" | xargs -n1 | sort -n | tr '\n' ' ' | sed -e 's/[[:space:]]*$//' )
154
+
155
+	echo "ENV DOCKER_BUILDTAGS $buildTags" >> "$version/Dockerfile"
156
+	echo "ENV RUNC_BUILDTAGS $runcBuildTags" >> "$version/Dockerfile"
157
+done
... ...
@@ -1,10 +1,14 @@
1
+#
2
+# THIS FILE IS AUTOGENERATED; SEE "contrib/builder/deb/armhf/generate.sh"!
3
+#
4
+
1 5
 FROM resin/rpi-raspbian:jessie
2 6
 
3
-# allow replacing httpredir mirror
4
-ARG APT_MIRROR=httpredir.debian.org
5
-RUN sed -i s/httpredir.debian.org/$APT_MIRROR/g /etc/apt/sources.list
7
+# allow replacing httpredir or deb mirror
8
+ARG APT_MIRROR=deb.debian.org
9
+RUN sed -ri "s/(httpredir|deb).debian.org/$APT_MIRROR/g" /etc/apt/sources.list
6 10
 
7
-RUN apt-get update && apt-get install -y apparmor bash-completion btrfs-tools build-essential cmake curl ca-certificates debhelper dh-apparmor dh-systemd git libapparmor-dev libdevmapper-dev libltdl-dev libsqlite3-dev libsystemd-journal-dev vim-common --no-install-recommends && rm -rf /var/lib/apt/lists/*
11
+RUN apt-get update && apt-get install -y apparmor bash-completion btrfs-tools build-essential cmake curl ca-certificates debhelper dh-apparmor dh-systemd git libapparmor-dev libdevmapper-dev libltdl-dev  libsqlite3-dev pkg-config vim-common libsystemd-journal-dev --no-install-recommends && rm -rf /var/lib/apt/lists/*
8 12
 
9 13
 ENV GO_VERSION 1.7.3
10 14
 # GOARM is the ARM architecture version which is unrelated to the above Golang version
... ...
@@ -13,5 +17,6 @@ RUN curl -fSL "https://golang.org/dl/go${GO_VERSION}.linux-armv6l.tar.gz" | tar
13 13
 ENV PATH $PATH:/usr/local/go/bin
14 14
 
15 15
 ENV AUTO_GOPATH 1
16
-ENV DOCKER_BUILDTAGS apparmor selinux
16
+
17
+ENV DOCKER_BUILDTAGS apparmor pkcs11 selinux
17 18
 ENV RUNC_BUILDTAGS apparmor selinux
... ...
@@ -1,6 +1,10 @@
1
+#
2
+# THIS FILE IS AUTOGENERATED; SEE "contrib/builder/deb/armhf/generate.sh"!
3
+#
4
+
1 5
 FROM armhf/ubuntu:trusty
2 6
 
3
-RUN apt-get update && apt-get install -y apparmor bash-completion btrfs-tools build-essential cmake curl ca-certificates debhelper dh-apparmor dh-systemd git libapparmor-dev libdevmapper-dev libltdl-dev libsqlite3-dev pkg-config libsystemd-journal-dev vim-common --no-install-recommends && rm -rf /var/lib/apt/lists/*
7
+RUN apt-get update && apt-get install -y apparmor bash-completion btrfs-tools build-essential cmake curl ca-certificates debhelper dh-apparmor dh-systemd git libapparmor-dev libdevmapper-dev libltdl-dev  libsqlite3-dev pkg-config vim-common libsystemd-journal-dev --no-install-recommends && rm -rf /var/lib/apt/lists/*
4 8
 
5 9
 ENV GO_VERSION 1.7.3
6 10
 RUN curl -fSL "https://golang.org/dl/go${GO_VERSION}.linux-armv6l.tar.gz" | tar xzC /usr/local
... ...
@@ -1,6 +1,10 @@
1
+#
2
+# THIS FILE IS AUTOGENERATED; SEE "contrib/builder/deb/armhf/generate.sh"!
3
+#
4
+
1 5
 FROM armhf/ubuntu:xenial
2 6
 
3
-RUN apt-get update && apt-get install -y apparmor bash-completion btrfs-tools build-essential cmake curl ca-certificates debhelper dh-apparmor dh-systemd git libapparmor-dev libdevmapper-dev libltdl-dev libseccomp-dev libsqlite3-dev libsystemd-dev pkg-config vim-common --no-install-recommends && rm -rf /var/lib/apt/lists/*
7
+RUN apt-get update && apt-get install -y apparmor bash-completion btrfs-tools build-essential cmake curl ca-certificates debhelper dh-apparmor dh-systemd git libapparmor-dev libdevmapper-dev libltdl-dev libseccomp-dev libsqlite3-dev pkg-config vim-common libsystemd-dev --no-install-recommends && rm -rf /var/lib/apt/lists/*
4 8
 
5 9
 ENV GO_VERSION 1.7.3
6 10
 RUN curl -fSL "https://golang.org/dl/go${GO_VERSION}.linux-armv6l.tar.gz" | tar xzC /usr/local
... ...
@@ -1,6 +1,10 @@
1
+#
2
+# THIS FILE IS AUTOGENERATED; SEE "contrib/builder/deb/armhf/generate.sh"!
3
+#
4
+
1 5
 FROM armhf/ubuntu:yakkety
2 6
 
3
-RUN apt-get update && apt-get install -y apparmor bash-completion btrfs-tools build-essential cmake curl ca-certificates debhelper dh-apparmor dh-systemd git libapparmor-dev libdevmapper-dev libltdl-dev libsqlite3-dev pkg-config libsystemd-dev vim-common --no-install-recommends && rm -rf /var/lib/apt/lists/*
7
+RUN apt-get update && apt-get install -y apparmor bash-completion btrfs-tools build-essential cmake curl ca-certificates debhelper dh-apparmor dh-systemd git libapparmor-dev libdevmapper-dev libltdl-dev libseccomp-dev libsqlite3-dev pkg-config vim-common libsystemd-dev --no-install-recommends && rm -rf /var/lib/apt/lists/*
4 8
 
5 9
 ENV GO_VERSION 1.7.3
6 10
 RUN curl -fSL "https://golang.org/dl/go${GO_VERSION}.linux-armv6l.tar.gz" | tar xzC /usr/local
... ...
@@ -8,5 +12,5 @@ ENV PATH $PATH:/usr/local/go/bin
8 8
 
9 9
 ENV AUTO_GOPATH 1
10 10
 
11
-ENV DOCKER_BUILDTAGS apparmor pkcs11 selinux
12
-ENV RUNC_BUILDTAGS apparmor selinux
11
+ENV DOCKER_BUILDTAGS apparmor pkcs11 seccomp selinux
12
+ENV RUNC_BUILDTAGS apparmor seccomp selinux