File: o-saft-docker-dev

package info (click to toggle)
o-saft 22.11.22-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, sid
  • size: 8,720 kB
  • sloc: perl: 22,252; makefile: 3,703; tcl: 3,499; sh: 3,048; awk: 319; ruby: 75; xml: 38; php: 32; csh: 13
file content (694 lines) | stat: -rwxr-xr-x 23,450 bytes parent folder | download
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
#?       @(#)  1.7 19/08/01 16:34:26
#?
#? 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/contrib	&& \\
        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 1.7"

ENV     o-saft-docker-build.$hostdate "$0 $args"
ENV     TERM xterm
ENV     PATH ${dir__o_saft}:${dir__o_saft}/contrib:${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 1.7" \
	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 <achim@owasp.org>"; ;;
	  '-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