nodered: Initial version of role
This commit is contained in:
parent
a855e1fcaa
commit
22ef6bbc0a
5 changed files with 109 additions and 0 deletions
2
roles/nodered/defaults/main.yml
Normal file
2
roles/nodered/defaults/main.yml
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
---
|
||||||
|
nodered_version: latest
|
6
roles/nodered/handlers/main.yml
Normal file
6
roles/nodered/handlers/main.yml
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
---
|
||||||
|
- name: Restart nodered
|
||||||
|
ansible.builtin.systemd_service:
|
||||||
|
name: nodered-container
|
||||||
|
state: restarted
|
||||||
|
daemon_reload: true
|
4
roles/nodered/meta/main.yml
Normal file
4
roles/nodered/meta/main.yml
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
---
|
||||||
|
dependencies:
|
||||||
|
- {role: nginx}
|
||||||
|
- {role: podman}
|
79
roles/nodered/tasks/main.yml
Normal file
79
roles/nodered/tasks/main.yml
Normal file
|
@ -0,0 +1,79 @@
|
||||||
|
---
|
||||||
|
- name: Create group
|
||||||
|
ansible.builtin.group:
|
||||||
|
name: nodered
|
||||||
|
|
||||||
|
- name: Create user
|
||||||
|
ansible.builtin.user:
|
||||||
|
name: nodered
|
||||||
|
comment: Podman NodeRed
|
||||||
|
group: nodered
|
||||||
|
shell: /sbin/nologin
|
||||||
|
|
||||||
|
- name: Enable user lingering
|
||||||
|
ansible.builtin.command:
|
||||||
|
argv:
|
||||||
|
- loginctl
|
||||||
|
- enable-linger
|
||||||
|
- nodered
|
||||||
|
creates: /var/lib/systemd/linger/nodered
|
||||||
|
|
||||||
|
- name: Fix SELinux contexts from config directory
|
||||||
|
community.general.sefcontext:
|
||||||
|
path: /export/nodered(/.*)?
|
||||||
|
setype: container_file_t
|
||||||
|
when: ansible_selinux_python_present
|
||||||
|
|
||||||
|
- name: Get subgid number
|
||||||
|
ansible.builtin.command:
|
||||||
|
argv:
|
||||||
|
- awk
|
||||||
|
- "-F:"
|
||||||
|
- '{ if ($1 == "nodered") print $2 + 999 }'
|
||||||
|
- /etc/subgid
|
||||||
|
register: subgid
|
||||||
|
|
||||||
|
- name: Create config directory
|
||||||
|
ansible.builtin.file:
|
||||||
|
path: /export/nodered
|
||||||
|
state: directory
|
||||||
|
mode: "0770"
|
||||||
|
owner: root
|
||||||
|
group: "{{ subgid.stdout }}"
|
||||||
|
setype: _default
|
||||||
|
|
||||||
|
- name: Link config directory
|
||||||
|
ansible.builtin.file:
|
||||||
|
dest: /srv/nodered
|
||||||
|
src: /export/nodered
|
||||||
|
state: link
|
||||||
|
owner: root
|
||||||
|
group: "{{ ansible_wheel }}"
|
||||||
|
follow: false
|
||||||
|
|
||||||
|
- name: Create service file
|
||||||
|
ansible.builtin.template:
|
||||||
|
dest: /etc/systemd/system/nodered-container.service
|
||||||
|
src: nodered-container.service.j2
|
||||||
|
mode: "0644"
|
||||||
|
owner: root
|
||||||
|
group: "{{ ansible_wheel }}"
|
||||||
|
notify: Restart nodered
|
||||||
|
|
||||||
|
- name: Enable service
|
||||||
|
ansible.builtin.service:
|
||||||
|
name: nodered-container
|
||||||
|
state: started
|
||||||
|
enabled: true
|
||||||
|
|
||||||
|
- name: Copy nginx config
|
||||||
|
ansible.builtin.copy:
|
||||||
|
dest: "/etc/nginx/conf.d/{{ inventory_hostname }}/nodered.conf"
|
||||||
|
content: |
|
||||||
|
location /nodered/ {
|
||||||
|
proxy_pass http://127.0.0.1:8012;
|
||||||
|
}
|
||||||
|
mode: "0644"
|
||||||
|
owner: root
|
||||||
|
group: "{{ ansible_wheel }}"
|
||||||
|
notify: Restart nginx
|
18
roles/nodered/templates/nodered-container.service.j2
Normal file
18
roles/nodered/templates/nodered-container.service.j2
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
[Unit]
|
||||||
|
Description=NodeRed Container
|
||||||
|
Wants=network-online.target
|
||||||
|
After=network-online.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
User=nodered
|
||||||
|
ExecStart=/usr/bin/podman run \
|
||||||
|
--rm -p 127.0.0.1:8012:1880 \
|
||||||
|
--name nodered \
|
||||||
|
--env TZ=Europe/Helsinki \
|
||||||
|
--volume /srv/nodered:/data:rw \
|
||||||
|
docker.io/nodered/node-red:{{ nodered_version }}
|
||||||
|
ExecStop=/usr/bin/podman stop --ignore nodered
|
||||||
|
ExecStopPost=/usr/bin/podman rm -f --ignore nodered
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
Loading…
Add table
Add a link
Reference in a new issue