summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristian Pointner <equinox@spreadspace.org>2020-05-24 19:12:00 +0200
committerChristian Pointner <equinox@spreadspace.org>2020-05-24 19:57:53 +0200
commit841fbea3dbdbf5eb877b046bc5e965330ba61cc1 (patch)
tree7d74545803a75f33ef7590a2c131da271303f29e
parentremove sk-testvm from standalone-kubelet group (diff)
custom image support for collabora code
-rw-r--r--roles/apps/collabora/code/defaults/main.yml6
-rw-r--r--roles/apps/collabora/code/tasks/custom-image.yml27
-rw-r--r--roles/apps/collabora/code/tasks/main.yml7
-rw-r--r--roles/apps/collabora/code/templates/pod.yml.j22
4 files changed, 41 insertions, 1 deletions
diff --git a/roles/apps/collabora/code/defaults/main.yml b/roles/apps/collabora/code/defaults/main.yml
index 2f025db5..2f93cf88 100644
--- a/roles/apps/collabora/code/defaults/main.yml
+++ b/roles/apps/collabora/code/defaults/main.yml
@@ -11,3 +11,9 @@ collabora_code_base_path: /srv/collabora/code
# password: S3cret
# backend_storages:
# - cloud.example.com
+# custom_image: # optional
+# from: foo/bar:1.0 # optional
+# dockerfile: |
+# USER root
+# RUN apt-get install ...
+# USER 101
diff --git a/roles/apps/collabora/code/tasks/custom-image.yml b/roles/apps/collabora/code/tasks/custom-image.yml
new file mode 100644
index 00000000..088e9318
--- /dev/null
+++ b/roles/apps/collabora/code/tasks/custom-image.yml
@@ -0,0 +1,27 @@
+---
+- name: create build directory for custom image
+ file:
+ path: "{{ collabora_code_base_path }}/{{ item.key }}/build"
+ state: directory
+
+- name: generate Dockerfile for custom image
+ copy:
+ content: |
+ FROM {{ item.value.custom_image.from | default('collabora/code:' + item.value.version) }}
+ {{ item.value.custom_image.dockerfile }}
+ dest: "{{ collabora_code_base_path }}/{{ item.key }}/build/Dockerfile"
+
+- name: install python-docker
+ apt:
+ name: python-docker
+ state: present
+
+- name: build custom image
+ docker_image:
+ name: "collabora/code/{{ item.key }}:{{ item.value.version }}"
+ state: present
+ source: build
+ build:
+ path: "{{ collabora_code_base_path }}/{{ item.key }}/build"
+ network: host
+ pull: yes
diff --git a/roles/apps/collabora/code/tasks/main.yml b/roles/apps/collabora/code/tasks/main.yml
index e283035b..57bdfa34 100644
--- a/roles/apps/collabora/code/tasks/main.yml
+++ b/roles/apps/collabora/code/tasks/main.yml
@@ -14,6 +14,13 @@
src: "config/loolwsd.{{ item.value.version }}.xml.j2"
dest: "{{ collabora_code_base_path }}/{{ item.key }}/config/loolwsd.xml"
+- name: build custom image
+ loop: "{{ collabora_code_instances | dict2items }}"
+ loop_control:
+ label: "{{ item.key }}"
+ when: "'custom_image' in item.value"
+ include_tasks: custom-image.yml
+
- name: generate pod manifests
loop: "{{ collabora_code_instances | dict2items }}"
loop_control:
diff --git a/roles/apps/collabora/code/templates/pod.yml.j2 b/roles/apps/collabora/code/templates/pod.yml.j2
index eb771de7..53fb4c0d 100644
--- a/roles/apps/collabora/code/templates/pod.yml.j2
+++ b/roles/apps/collabora/code/templates/pod.yml.j2
@@ -5,7 +5,7 @@ metadata:
spec:
containers:
- name: collabora-code
- image: "collabora/code:{{ item.value.version }}"
+ image: "collabora/code{% if 'custom_image' in item.value %}/{{ item.key }}{% endif %}:{{ item.value.version }}"
resources:
limits:
memory: "4Gi"