]>
Commit | Line | Data |
---|---|---|
930848e7 WY |
1 | # Dockerfile for building Ansible image from source for Debian 8 (jessie), 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 | |
10 | FROM debian:jessie | |
11 | ||
12 | MAINTAINER William Yeh <william.pjyeh@gmail.com> | |
13 | ||
14 | ||
97d48efe WY |
15 | RUN echo "===> Adding Ansible's prerequisites..." && \ |
16 | apt-get update -y && apt-get install --fix-missing && \ | |
930848e7 WY |
17 | DEBIAN_FRONTEND=noninteractive \ |
18 | apt-get install --no-install-recommends -y -q \ | |
19 | build-essential ca-certificates \ | |
20 | python-pip python-dev python-yaml \ | |
97d48efe | 21 | libffi-dev libssl-dev \ |
930848e7 WY |
22 | libxml2-dev libxslt1-dev zlib1g-dev \ |
23 | git sudo curl && \ | |
97d48efe WY |
24 | apt-get -y --purge remove python-cffi && \ |
25 | pip install --upgrade cffi && \ | |
930848e7 WY |
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 | \ | |
97d48efe | 46 | echo "===> Clean up..." && \ |
930848e7 | 47 | apt-get remove -y --auto-remove \ |
97d48efe WY |
48 | build-essential python-pip python-dev git libffi-dev libssl-dev && \ |
49 | apt-get clean && \ | |
50 | rm -rf /var/lib/apt/lists/* && \ | |
930848e7 WY |
51 | \ |
52 | \ | |
53 | echo "===> Adding hosts for convenience..." && \ | |
54 | mkdir -p /etc/ansible && \ | |
7b2618d5 | 55 | echo 'localhost' > /etc/ansible/hosts |
930848e7 WY |
56 | |
57 | ||
58 | ENV PATH /opt/ansible/bin:$PATH | |
59 | ENV PYTHONPATH /opt/ansible/lib:$PYTHONPATH | |
60 | ENV MANPATH /opt/ansible/docs/man:$MANPATH | |
61 | ||
62 | ||
63 | COPY ansible-playbook-wrapper /usr/local/bin/ | |
64 | ||
65 | ONBUILD RUN DEBIAN_FRONTEND=noninteractive apt-get update && \ | |
66 | echo "===> Updating TLS certificates..." && \ | |
67 | apt-get install -y openssl ca-certificates | |
68 | ||
69 | ONBUILD WORKDIR /tmp | |
70 | ONBUILD COPY . /tmp | |
71 | ONBUILD RUN \ | |
72 | echo "===> Diagnosis: host information..." && \ | |
73 | ansible -c local -m setup all | |
74 | ||
75 | ||
76 | ||
77 | # default command: display Ansible version | |
78 | CMD [ "ansible-playbook", "--version" ] |