aboutsummaryrefslogtreecommitdiffhomepage
path: root/master-debian9-onbuild
diff options
context:
space:
mode:
Diffstat (limited to 'master-debian9-onbuild')
-rw-r--r--master-debian9-onbuild/Dockerfile78
-rwxr-xr-xmaster-debian9-onbuild/ansible-playbook-wrapper50
2 files changed, 128 insertions, 0 deletions
diff --git a/master-debian9-onbuild/Dockerfile b/master-debian9-onbuild/Dockerfile
new file mode 100644
index 0000000..dafbdf3
--- /dev/null
+++ b/master-debian9-onbuild/Dockerfile
@@ -0,0 +1,78 @@
1# Dockerfile for building Ansible image from source for Debian 9 (stretch), with as few additional software as possible.
2#
3# @see http://docs.ansible.com/ansible/intro_installation.html#running-from-source
4#
5# Version 1.0
6#
7
8
9# pull base image
10FROM debian:stretch
11
12MAINTAINER William Yeh <william.pjyeh@gmail.com>
13
14
15RUN echo "===> Adding Ansible's prerequisites..." && \
16 apt-get update -y && apt-get install --fix-missing && \
17 DEBIAN_FRONTEND=noninteractive \
18 apt-get install --no-install-recommends -y -q \
19 build-essential ca-certificates \
20 python python-pip python-dev \
21 libffi-dev libssl-dev \
22 libxml2-dev libxslt1-dev zlib1g-dev \
23 git sudo curl && \
24 pip install --upgrade setuptools pip wheel && \
25 pip install --upgrade cffi && \
26 pip install --upgrade pyyaml jinja2 pycrypto && \
27 \
28 \
29 echo "===> Downloading Ansible's source tree..." && \
30 git clone git://github.com/ansible/ansible.git --recursive && \
31 \
32 \
33 echo "===> Compiling Ansible..." && \
34 cd ansible && \
35 bash -c 'source ./hacking/env-setup' && \
36 \
37 \
38 echo "===> Moving useful Ansible stuff to /opt/ansible ..." && \
39 mkdir -p /opt/ansible && \
40 mv /ansible/bin /opt/ansible/bin && \
41 mv /ansible/lib /opt/ansible/lib && \
42 mv /ansible/docs /opt/ansible/docs && \
43 rm -rf /ansible && \
44 \
45 \
46 echo "===> Clean up..." && \
47 apt-get remove -y --auto-remove \
48 build-essential python-pip python-dev git libffi-dev libssl-dev && \
49 apt-get clean && \
50 rm -rf /var/lib/apt/lists/* && \
51 \
52 \
53 echo "===> Adding hosts for convenience..." && \
54 mkdir -p /etc/ansible && \
55 echo 'localhost' > /etc/ansible/hosts
56
57
58ENV PATH /opt/ansible/bin:$PATH
59ENV PYTHONPATH /opt/ansible/lib:$PYTHONPATH
60ENV MANPATH /opt/ansible/docs/man:$MANPATH
61
62
63COPY ansible-playbook-wrapper /usr/local/bin/
64
65ONBUILD RUN DEBIAN_FRONTEND=noninteractive apt-get update && \
66 echo "===> Updating TLS certificates..." && \
67 apt-get install -y openssl ca-certificates
68
69ONBUILD WORKDIR /tmp
70ONBUILD COPY . /tmp
71ONBUILD RUN \
72 echo "===> Diagnosis: host information..." && \
73 ansible -c local -m setup all
74
75
76
77# default command: display Ansible version
78CMD [ "ansible-playbook", "--version" ]
diff --git a/master-debian9-onbuild/ansible-playbook-wrapper b/master-debian9-onbuild/ansible-playbook-wrapper
new file mode 100755
index 0000000..afe4d97
--- /dev/null
+++ b/master-debian9-onbuild/ansible-playbook-wrapper
@@ -0,0 +1,50 @@
1#!/bin/sh
2#
3# Simple wrapper for executing ansible-galaxy and ansible-playbook
4# with local connection.
5#
6# USAGE:
7# ansible-playbook-wrapper [other ansible-playbook arguments]
8#
9# ENVIRONMENT VARIABLES:
10#
11# - REQUIREMENTS: requirements filename; default = "requirements.yml"
12# - PLAYBOOK: playbook filename; default = "playbook.yml"
13# - INVENTORY: inventory filename; default = "/etc/ansible/hosts"
14#
15
16
17#
18# install Galaxy roles, if any
19#
20
21if [ -z "$REQUIREMENTS" ]; then
22 REQUIREMENTS=requirements.yml
23fi
24
25if [ -f "$REQUIREMENTS" ]; then
26 apt-get install -y git
27 ansible-galaxy install -r $REQUIREMENTS
28fi
29
30
31#
32# execute playbook
33#
34
35if [ -z "$PLAYBOOK" ]; then
36 PLAYBOOK=playbook.yml
37fi
38
39
40if [ -z "$INVENTORY" ]; then
41 exec ansible-playbook \
42 $PLAYBOOK \
43 --connection=local \
44 "$@"
45else
46 exec ansible-playbook \
47 -i $INVENTORY $PLAYBOOK \
48 --connection=local \
49 "$@"
50fi