-
-
Notifications
You must be signed in to change notification settings - Fork 85
/
Copy patho-saft-docker-dev
executable file
·694 lines (645 loc) · 22.9 KB
/
o-saft-docker-dev
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
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
#!/bin/sh
#?
#? NAME
#? $0 - wrapper script to build O-Saft in a Docker image
#?
#? SYNOPSIS
#? $0 build [build options]
#? $0 load [load options]
#? $0 pull [pull options]
# ? $0 config
#?
#? OPTIONS
#? -help got it
#? -n do not execute, just show what would be done
#? -v be a bit verbose
#? -- pass all remaining parameters to docker
#?
#? To create a Docker image, following additional options can be used:
#? --force-rm pass --force-rm option to "docker build"
#? --rm pass --rm option to "docker build"
#? -del delete saved image file after "docker load"
#? -clean shortcut for: --no-force-rm --no-rm -no-del
#? -save save and then load created image (removes layers)
#? -tag create addition tag for image (alias) o-saft
#? --no-force-rm do not pass --force-rm option to "docker build"
#? --no-rm do not pass --rm option to "docker build"
#? -no-del do not delete saved image file after "docker load"
#? -no-clean shortcut for: --force-rm --rm -del
#? -no-save do not save and then load created image
#? -no-tag do notcreate addition tag for image
#? -alpine build image based on alpine
#? -debian build image based on debian
#? -from=BASE build image based on BASE (value used for FROM key)
#? -author set MAINTAINER in Dockerfile
#?
#? Options for image content
#? -apt=CMD use CMD as command for package manager
# ? -tar=TAR use TAR file to build image instead of wget ...
# ? -sha256sum check SHA256 checksum of tar archive
# ? -no-sha256sum do not check SHA256 checksum of tar archive
#? -openssl install openssl-chacha in image
#? -iosocket install IO::Socket::SSL in image
#? -ssleay install Net::SSLeay in image
#? -tcl install Tcl/Tk (wish) in image
#? -no-openssl do not install openssl-chacha
#? -no-iosocket do not install IO::Socket::SSL
#? -no-ssleay do not install Net::SSLeay
#? -no-tcl do not install Tcl/Tk (wish)
#? TODO: need option to pass SHA256 values
# ? -pull [name[:tag]
# ? Pulls specified image from hub.docker.net. [name[:tag] is
# ? the same as for Docker's pull command. This command implies
# ? the options: -no-save -no-tag -no-del
#?
#? The defaults are: -f ./Dockerfile --force-rm --rm -del -save -tag
#? which results in:
#? docker build -f ./Dockerfile --force-rm --rm ...
#?
#? DESCRIPTION
#? The purpose of this script is to provide various modes to creates an
#? O-Saft Docker image. It's a more powerful version of o-saft-docker's
#? build command (mode) and provides some options mainly for debugging.
#?
#? It can operate in following modes:
#? build - use Docker's build command to create the image
#? load - use Docker's load command to create the image
#? pull - use Docker's pull command to create the image
#?
#? In build mode it generates a Dockerfile and then calls docker build
#? with. The Dockerfile consists mainly of five parts:
#? 1. initial data
#? 2. setup O-Saft
#? 3. setup IO::Socket::SSL (if necessary)
#? 4. setup special openssl (if enabled)
#? 5. final data
#?
#? It is highly recommended to use this script with the -n option first
#? and verify that the printed commands are correct.
#?
#? TERMINOLOGY
#? Please see also: o-saft-docker -help
#?
#? del(ete) vs. rm (remove) vs. clean
#? The term "remove" herein is used when objects, files, etc. inside
#? Docker images or containers are removed. The term "delete" is used
#? when objects, files, etc. on the host are deleted. The term "clean"
#? is used when both, targets inside Docker and on the host, are meant.
#? Options are named accordingly.
#?
#? build vs. load vs. pull
#? These terms are used as Docker does. "build" creates the image on
#? the local host. It uses the sources specified in the corresponding
#? Dockerfile. "load" creates an image from a local (on the host) tar
#? archive. And finally "pull" creates an image from a registry.
#? Please refer to WHY? and SECURITY below, to understand why this
#? difference is important.
#?
#? WHY?
#? Why using a script, which finally generates a Dockerfile, to create
#? Docker images, when simply using the Dockerfile would do the same?
#? Some reasons are:
#? used sources - Commands of the Dockerfile itself must be changed
#? when a source will be provided by the host (local
#? filesystem) instead of fetching from an internet
#? archive (such as hub.docker.com). The difference
#? is using COPY instead of RUN with wget.
#? trustworth - I.g. creating your own image on your host is more
#? trustworthy than downloading and blindly using an
#? preconfigured image from resources not under your
#? control. Using build provides full control over
#? all used resources. Contrary, using pull from
#? remote resources provides no control at all..
#? clean-up - After creating images, a proper clean-up must be
#? done at three places: while creating the image by
#? using proper option (like --force-rm), inside the
#? image (mainly the RUN commands) and on the host.
#? tagging - The name (registry:tag) for images must be given
#? to the build command, it is not possible to write
#? it inside the Dockerfile. Hence there is at least
#? one program call (docker build ...) which must be
#? closely related to the whole process of creating
#? a Docker image.
#? identity - Inside an image, it is hard, probably impossible,
#? to identify how and when the image was build.
#?
#? MODES
#? build
#? Build image from a Dockerfile.
#?
#? load
#? Install image with Docker's load command.
#?
#? pull
#? Install image with Docker's pull command. Remember WHY? above.
#?
#? SECURITY
#? Please see: o-saft-docker -help
#? That's why this script provides different modes to create an image.
#? The purpose is to make the build process as transparent as possible.
#? please refer to the "build" modes described above
#?
#? HACKER's INFO
# The purpose of this script is to build Docker images for o-saft.pl.
# Hence all default settings support this.
#
# Docker's ADD command promisses to fetch archives from a URL and also
# extract it. Unfortunately, modern archives can have various filename
# extensions and also may be compressed with different algorithms. So
# only COPY or wget is used to provide externa archives.
#
# The generated RUN commands to get and unpack archives depend on the
# source. If it is a tarball, this must be copied or mounted into the
# docker image. Unfortunately, this requires different syntax elements
# in the Dockerfile, i.e. "COPY ..." vs. "RUN wget ...". To generate
# the appropriate code, following functions take care of that:
# _copy_src $_src $_tar
# _run_wget $_src $_tar
# _run_sha2 $_tar $_sha
# _run_untar $_tar $_tmp
#
# Using sevaral independent Docker RUN commands, as the documentation
# recommends, is not a wice idea, because it results in one layer for
# each RUN command containing anything from the previous Docker layer.
# Hence each generated RUN command contains as much internal commands
# as possible (concatenated with &&).
#
# Docker itself provides no functionality to shrink an image while it
# is build. This must be done by additional Docker commands (save and
# load).
#
# Empty lines in Docker RUN commands may result in
# [WARNING]: Empty continuation lines will become errors in a future release.
# hence a single \ is used as "empty line".
#
#? LIMITATIONS
#? The options -n -v and -help must be specified first (leftmost)
#? if they should apply for this script.
#?
#? ENVIONMENT VARIABLES
#? Following environment variables can be used to pass settings to the
#? script:
#?
#? OSAFT_VERSION - version to be passed to Dockerfile
#? o_saft_docker_name - contains an image registry name
#? o_saft_docker_tag - contains an image tag
#?
#? SEE ALSO
#? o-saft-docker
#?
#? EXAMPLES
#? # FROM command sources openssl Tcl/Tk ... options
#? +-----+-------+-------+-------+-------+-------+-----------------------
#? alpine pull reg:tag -alpine -pull
#? alpine build http:// openssl -alpine
#? alpine build .tgz -alpine -tar=o-saft.tgz
#? debian build http:// wish -debian
#? debian build .tgz wish -debian -tar=o-saft.tgz
#?
#? VERSION
#? @(#) a 3.1 24/01/26 08:57:39
#?
#? AUTHOR
#? 17-jul-17 Achim Hoffmann
#?
# -----------------------------------------------------------------------------
try=
cmd=unknown
VERSION="${OSAFT_VERSION:-19.01.19}"
registry="${o_saft_docker_name}"; registry="${registry:-owasp/o-saft}"
image_tag="${o_saft_docker_tag}"; image_tag="${image_tag:-`date +%y.%m.%d`}"
image_name="${registry}:${image_tag}"
image_save="o-saft_docker.tar"
image_from="alpine:edge"
dockerfile="Dockerfile"
maintainer="" # must be set with -author
buildfrm="--force-rm"
build_rm="--rm=true"
buildtag=1
buildsav=1
inst_tcl=0
instwget=1
host_del=1
host_tar=""
hostdate=`date +%y%m%d%"H%"M%S`
apt="apk"
upd="$apt update"
apt_add="add"
apt_del="del"
apt__dev=""
apt__gcc="gcc make"
apt__tcl=""
apt_wget=""
check_sha256=1
make_o_saft=1
make_openssl=
make_iosocket=
make_ssleay=
dir__o_saft="/O-Saft"
dir_openssl="/openssl"
# sources
# NOTE: empty checksum must be specified as "-"
url__o_saft="https://github.com/OWASP/O-Saft/raw/master/o-saft.tgz"
sha__o_saft="29d4faa2ed3025ed18d31175e868d6be9312b36ba486c6e5f305afeb34947f68"
url_openssl="https://github.com/PeterMosmans/openssl/archive/1.0.2-chacha.tar.gz"
sha_openssl="-"
urliosocket="http://search.cpan.org/CPAN/authors/id/S/SU/SULLR/IO-Socket-SSL-2.049.tar.gz"
shaiosocket="-"
url__ssleay=""
sha__ssleay="-"
_dbx_config () {
cat <<EoConfig
#=== internal configuration {
# == commands and variables
# cmd = $cmd
# buildtag = $buildtag
# buildsav = $buildsav
# host_del = $host_del
# host_tar = $host_tar
# inst_tcl = $inst_tcl
# instwget = $instwget
# host_del = $host_del
# host_tar = $host_tar
# hostdate = $hostdate
# image_save = $image_save
# check_sha256 = $check_sha256
# make_o_saft = $make_o_saft
# make_openssl = $make_openssl
# make_iosocket = $make_iosocket
# make_ssleay = $make_ssleay
# dir__o_saft = $dir__o_saft
# dir_openssl = $dir_openssl
# == sources
# url__o_saft = $url__o_saft
# sha__o_saft = $sha__o_saft
# url_openssl = $url_openssl
# sha_openssl = $sha_openssl
# urliosocket = $urliosocket
# shaiosocket = $shaiosocket
# url__ssleay = $url__ssleay
# sha__ssleay = $sha__ssleay
# == docker
# cmd = $cmd
# options = $buildfrm $build_rm
# aliases = $buildtag
# image = $image_name
# dockerfile = $dockerfile
# image_from = $image_from
# maintainer = $maintainer
# == packages
# apt = $apt
# upd = $upd
# apt_add = $apt_add
# apt_del = $apt_del
# apt__dev = $apt__dev
# apt__gcc = $apt__gcc
# apt__tcl = $apt__tcl
# apt_wget = $apt_wget
#=== internal configuration }
EoConfig
}
_cfg_alpine () {
#? set global variables for alpine
_typ="$1"
image_from="${image_from:-alpine:3.6}"
make_openssl=${make_openssl:-1}
make_iosocket=${make_iosocket:-1}
make_ssleay=${make_ssleay:-0}
apt="apk"
upd="echo 'no update'" # alpine doesn't need it
apt__dev="perl perl-net-dns perl-net-ssleay ncurses" # alpine:3.6
apt__gcc="musl-dev gcc make zlib-dev"
adduser="adduser -D osaft -h $dir__o_saft"
[ $inst_tcl -eq 1 ] && apt__tcl="tcl tk xvfb"
[ $instwget -eq 1 ] && apt_wget="wget"
if [ "$_typ" = "alpine:edge" ]; then
# dirty hack
apt__dev="$apt__dev perl-io-socket-ssl"
make_iosocket=0
fi
#[ -z "$host_tar" ] && wget=wget
}
_cfg_debian () {
#? set global variables for debian
image_from="${image_from:-debian:stretch-slim}"
make_openssl=${make_openssl:-1}
make_iosocket=${make_iosocket:-0}
make_ssleay=${make_ssleay:-0}
apt="apt"
upd="$apt update"
apt__dev="libperl5.24 libio-socket-ssl-perl libnet-dns-perl libnet-ssleay-perl"
apt__gcc="gcc make"
adduser="adduser --disabled-password --gecos '' osaft"
# debian's adduser complains if GECOS is missing
[ $inst_tcl -eq 1 ] && apt__tcl="wish"
# debian installs X11 with Tcl/Tk, grrr ...
[ $instwget -eq 1 ] && apt_wget=wget
}
_copy_src () {
#? return Docker COPY command to get tarball
# src=${1} tar=${2}
echo "$1" | \egrep -q ^http && return; # return if URL
echo "COPY $1 /$2"
}
_run_wget () {
#? return part for Docker RUN command to get tarball
# url=${1} tar=${2}
echo "$1" | \egrep -q ^http || return; # return if not URL
cat <<EoRUN
wget --no-check-certificate $1 -O $2 && \\
EoRUN
}
_run_sha2 () {
#? return part for Docker RUN command to check SHA256 checksum
# tar=${1} sha=${2}
[ -z $2 ] && return
[ "$2" = "-" ] && return
# only generate code if checksum was given
cat <<EoRUN
echo "$2 $1" | sha256sum -c && \\
EoRUN
}
_run_untar () {
#? return part for Docker RUN command to extract tarball and cd to dir
# tar=${1} sha=${2} tmp=${3}
cat <<EoRUN
mkdir $2 && \\
tar -C $2 --strip-components=1 -xzf $1 && \\
cd $2 && \\
EoRUN
}
_run_iosocket $urliosocket $shaiosocket $__tar /iosocket
_run_iosocket () {
#? return Docker RUN command to build IO::Socket::SSL
_src_1=${1}
_sha_1=${2}
_tar_1=${3:-iosocket.tgz}
_dir_1=${4:-/iosocket} # not used
_tmp_1=${5:-/src_iosocket}
_copy_src $_src_1 $_tar_1
cat <<EoRUN
# Pull and build IO::Socket::SSL
RUN \\
# pull and extract module
EoRUN
_run_wget $_src_1 $_tar_1
_run_sha2 $_tar_1 $_sha_1
_run_untar $_tar_1 $_tmp_1
cat <<EoRUN
# install development tools
$apt $apt_add make && \\
# build iosocket
echo n | perl Makefile.PL && \\
make && make test && make install && \\
# cleanup
$apt $apt_del make && \\
cd / && rm -r $_tmp_1 && \\
EoRUN
}
_run__openssl () {
#? return Docker RUN command to build openssl
_src_2=${1}
_sha_2=${2}
_tar_2=${3:-openssl.tgz}
_dir_2=${4:-/openssl}
_tmp_2=${5:-/src_openssl}
_copy_src $_src_2 $_tar_2
cat <<EoRUN
# Pull and build enhanced openssl
RUN \\
# pull and extract module
EoRUN
_run_wget $_src_2 $_tar_2
_run_sha2 $_tar_2 $_sha_2
_run_untar $_tar_2 $_tmp_2
cat <<EoRUN
# install development tools
$apt $apt_add $apt__gcc && \\
# build openssl
./config --prefix=$_dir_2 --openssldir=$_dir_2/ssl \\
enable-zlib enable-ssl3 enable-rc5 enable-rc2 enable-GOST \\
enable-cms enable-md2 enable-mdc2 enable-ec enable-ec2m \\
enable-ecdh enable-ecdsa enable-seed enable-idea enable-camellia \\
enable-rfc3779 enable-ec_nistp_64_gcc_128 \\
-static experimental-jpake -DOPENSSL_USE_BUILD_DATE && \\
make depend && make && make report && make install && \\
# simple test
echo -e "# number of ciphers $_dir_2/bin/openssl: " && \\
$_dir_2/bin/openssl ciphers -V ALL:COMPLEMENTOFALL:aNULL|wc -l && \\
# cleanup
$apt $apt_del $apt__gcc && \\
cd / && rm -r $_tmp_2 && \\
EoRUN
}
_run_osaftrc () {
#? return partial command to patch .o-saft.pl
_dir_8=${1:-/O-Saft}
_openssl=${2:-/openssl}
cat <<EoRUN
mv $_dir_8/.o-saft.pl $_dir_8/.o-saft.pl-orig && \
sed -e "s:^#--openssl=.*:--openssl=$_openssl/bin/openssl:" \
< $_dir_8/.o-saft.pl-orig \
> $_dir_8/.o-saft.pl && \
EoRUN
}
_run_osaft () {
#? return Docker RUN command to build /O-Saft
_src_9=${1}
_sha_9=${2}
_tar_9=${3:-o-saft}
_dir_9=${4:-/O-Saft}
_copy_src $_src_9 $_tar_9
cat <<EoRUN
# Install O-Saft
RUN \\
EoRUN
_run_wget $_src_9 $_tar_9
_run_sha2 $_tar_9 $_sha_9
cat <<EoRUN
\\
tar -xzf $_tar_9 && \\
chown -R root:root $_dir_9 && \\
chown osaft:osaft $_dir_9 && \\
chown -R osaft:osaft $_dir_9/usr && \\
chown osaft:osaft $_dir_9/.o-saft.pl && \\
EoRUN
_run_osaftrc $_dir_9 /openssl
echo " chmod 666 $_dir_9/.o-saft.pl && \\"
}
dockerfile () {
# generate a Dockerfile; for options see general description above
_path='$PATH' # avoid \\ in strings
cat <<EoDockerfile
#!/usr/bin/docker build --force-rm --rm -f
FROM $image_from
$maintainer
LABEL VERSION="$image_tag" DESCRIPTION="O-Saft docker image build by $0 3.1"
ENV o-saft-docker-build.$hostdate "$0 $args"
ENV TERM xterm
ENV PATH ${dir__o_saft}:${dir__o_saft}/usr:${dir_openssl}/bin:$_path
RUN $upd && $apt $apt_add $apt__dev $apt__tcl $apt_wget
WORKDIR /
RUN $adduser
EoDockerfile
if [ $make_o_saft -eq 1 ]; then
__tar=o-saft.tgz
_run_osaft $url__o_saft $sha__o_saft $__tar $dir__o_saft
echo " rm $__tar"
fi
if [ $make_iosocket -eq 1 ]; then
__tar=iosocket.tgz
_run_iosocket $urliosocket $shaiosocket $__tar /iosocket
echo " rm $__tar"
fi
if [ $make_openssl -eq 1 ]; then
__tar=openssl.tgz
_run__openssl $url_openssl $sha_openssl $__tar $dir_openssl
echo " rm $__tar"
fi
cat <<EoDockerfile
WORKDIR ${dir__o_saft}
USER osaft
RUN o-saft-docker usage
ENTRYPOINT ["perl", "${dir__o_saft}/o-saft.pl"]
CMD ["--norc", "--help=docker"]
EoDockerfile
}
docker_clean () {
$try \docker image save -o ${image_save} ${image_name}
$try \docker image rm `$try docker image ls -q ${image_name}`
$try \docker image load -i ${image_save}
}
docker_build_file () {
name="$1"; shift
_file_f="$2"; shift
_dir_f=""
_dockerfile_f=./tmp-Dockerfile
make=`perl -ne 'print if m(# build {)..m(# build })' Dockerfile`
cat > $_dockerfile_f <<EoDockerfile
FROM $name
LABEL VERSION="$image_tag" DESCRIPTION="O-Saft docker image build by $0 3.1" \
SOURCE="$_file_f"
WORKDIR /
COPY $_file_f /
USER root
RUN $apt $apt_add
RUN $make
RUN $apt $apt_del
ENV o-saft-docker-build.$hostdate "$0 $args"
EoDockerfile
$try \docker image build --build-arg "OSAFT_VERSION=$VERSION" \
$buildfrm $build_rm -f $_dockerfile_f .
if [-d $_dir_f ]; then
echo
fi
}
docker_build () {
# create an image; for options see general description above
_dockerfile_b=$host_tmp/$dockerfile
# while [ $# -gt 0 ]; do
# case "$1" in
# *) _dockerfile_b=$1; break; ;;
# esac
# shift
# done
# für Osaft: wenn ein .tar-File da ist, das benutzen statt wget
# betrifft: osaft.tgz iosocket.tgz openssl.tgz $apt_wget
dockerfile > $_dockerfile_b
[ "$try" = "echo" ] && echo && cat $_dockerfile_b && echo
for file in $host_tar; do
$try docker_build_file ${image_name} $_dockerfile_b
done
$try \docker image build --build-arg "OSAFT_VERSION=$VERSION" \
$buildfrm $build_rm -f $_dockerfile_b -t ${image_name} .
[ $buildsav -eq 1 ] && docker_clean
[ $host_del -eq 1 ] && [ -f ${image_save} ] && $try \rm ${image_save}
[ $buildtag -eq 1 ] && $try \docker image tag ${image_name} o-saft
}
docker_pull () {
$try \docker image pull $@
}
docker_load () {
$try \docker image load $@
}
my_help () {
ich=${0##*/}
\sed -ne "s/\$0/$ich/g" -e '/^#?/s/#?//p' $0
}
_cfg_alpine # set defaults
args="$*"
while [ $# -gt 0 ]; do
case "$1" in
'-n') try=echo; ;;
'-v') set -x ; ;;
'-help') cmd=help; ;;
'build') cmd=build; ;;
'load') cmd=load; ;;
'pull') cmd=pull; ;;
'config') cmd=config; ;;
'dockerfile') cmd=config; ;;
'-alpine') _cfg_alpine alpine ; ;;
'-debian') _cfg_debian debian ; ;;
-from=*) image_from="`expr "$1" ':' '-from=\(.*\)'`"; ;;
-tar=*) host_tar="$host_tar `expr "$1" ':' '-tar=\(.*\)'`"; ;;
-apt=*) apt="`expr "$1" ':' '-apt=\(.*\)'`"; ;;
'-author') maintainer="MAINTAINER Achim <[email protected]>"; ;;
'-sha256sum') check_sha256=1; ;;
'-no-sha256sum') check_sha256=0; ;;
'-openssl') make_openssl=1; ;;
'-no-openssl') make_openssl=0; ;;
'-iosocket') make_iosocket=1; ;;
'-no-iosocket') make_iosocket=0; ;;
'-ssleay') make_ssleay=1; ;;
'-no-ssleay') make_ssleay=0; ;;
'-save') buildsav=1; ;;
'-no-save') buildsav=0; ;;
'-tag') buildtag=1; ;;
'-no-tag') buildtag=0; ;;
'-tcl' | '-wish') inst_tcl=1; ;;
'-no-tcl' | '-no-wish') inst_tcl=0; ;;
'-force-rm' | '--force-rm') buildfrm="--force-rm"; ;;
'-no-force-rm' | '--no-force-rm') buildfrm=""; ;;
'-rm' | '--rm') build_rm="--rm"; ;;
'-no-rm' | '--no-rm') build_rm=""; ;;
'-del' | '--delete') host_del=1; ;;
'-no-del' | '--no-delete') host_del=0; ;;
'-clean') host_del=1; build_rm="--rm"; buildfrm="--force-rm"; ;;
'-no-clean') host_del=0; build_rm=""; buildfrm=""; ;;
'--') shift; break; ;;
*) break; ;;
esac
shift
done
# TODO: options need to be documented
# adapt platform-specific settings according options
case "$image_from" in
alpine*) _cfg_alpine "$image_from"; ;;
debian*) _cfg_debian "$image_from"; ;;
esac
# commands for package manager
case "$apt" in
'apk') apt_add="add --no-cache"; apt_del="del --purge"; ;;
'apt') apt_add="install"; apt_del="purge"; ;;
esac
[ "$try" = "echo" ] && _dbx_config && echo
[ "$cmd" = "help" ] && my_help && exit 0; # just help, ready
# make temp. directory, avoids:
# unable to prepare context: the Dockerfile must be within the build context
host_tmp=/tmp/$hostdate
[ -d $host_tmp ] && echo "**ERROR: $host_tmp exists; aborted" && exit 2
\mkdir $host_tmp # no $try, because we need the dir
if [ $? -ne 0 ]; then
echo "**ERROR: create $host_tmp faild; aborted"
exit 2
fi
$try \cd $host_tmp
case "$cmd" in
'help') my_help $0; ;;
'config') dockerfile $@; ;;
'build') docker_build $@; ;;
'load') docker_load $@; ;;
'pull') docker_pull $@; ;;
*) echo && echo "**WARNING: $0 $cmd ... unknown mode, ignored" && echo ; ;;
esac
[ $host_del -eq 1 ] && \rm -r $host_tmp # # no $try, because we used the dir
exit