-
Notifications
You must be signed in to change notification settings - Fork 2
/
export_flow_nodered.yml
97 lines (89 loc) · 3.6 KB
/
export_flow_nodered.yml
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
# SPDX-License-Identifier: AGPL-3.0-only
#
# Komponist - Generate Your Favourite Compose Stack With the Least Effort
#
# Copyright (C) 2023 Shantanoo "Shan" Desai <[email protected]>
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published
# by the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
#
# export_flow_nodered.yml: Ansible Playbook that exports the current flow from an instance
# and create a flows file
---
- name: Export Complete Flow from Node-RED
hosts: localhost
gather_facts: true
vars_files:
- vars/config.yml
- vars/creds.yml
module_defaults:
ansible.builtin.uri:
method: POST
headers:
Content-Type: application/json
tasks:
- name: Get Node-RED user with all Privileges
ansible.builtin.set_fact:
nodered_creds: "{{ item }}"
when: "item.permissions is defined and item['permissions'] == '*'"
loop: "{{ credentials.nodered.users }}"
no_log: true
- name: Obtain Authentication Token
ansible.builtin.uri:
url: "http://localhost/nodered/auth/token"
body:
client_id: node-red-admin
grant_type: password
scope: "{{ nodered_creds.permissions }}"
username: "{{ nodered_creds.username }}"
password: "{{ nodered_creds.password }}"
body_format: json
status_code: 200
register: auth_token
when: nodered_creds is defined
- name: Lookup flows from Node-RED instance
ansible.builtin.set_fact:
main_flow: "{{ lookup('ansible.builtin.url', 'http://localhost/nodered/flows', headers=headers) }}"
vars:
headers:
Content-Type: application/json
Authorization: "{{ auth_token.json.token_type }} {{ auth_token.json.access_token }}"
Node-RED-API-Version: v2
- name: Obtain flows_cred file from Container
community.docker.docker_container_exec:
container: komponist_nodered
command: /bin/bash -c "cat /data/flows_cred.json"
register: flows_cred
ignore_errors: true
- name: Generate Flow JSON file Fact with Credentials
ansible.builtin.set_fact:
final_flow: "{{ main_flow | combine({'credentials': flows_cred.stdout | from_json}) | ansible.utils.remove_keys(['rev']) | trim }}"
when: flows_cred.rc == 0
- name: Generate Flow JSON file Fact without Credentials
ansible.builtin.set_fact:
final_flow: "{{ main_flow | ansible.utils.remove_keys(['rev']) | trim }}"
when: flows_cred.rc != 0
- name: Create flows.json into deploy/nodered directory
ansible.builtin.copy:
dest: "{{ komponist.deploy_dir }}/nodered/flows_{{ ansible_date_time.date }}.json"
content: "{{ final_flow | to_nice_json }}"
mode: '0644'
- name: Revoke Authentication Token
ansible.builtin.uri:
url: http://localhost/nodered/auth/revoke
headers:
Authorization: "{{ auth_token.json.token_type }} {{ auth_token.json.access_token }}"
body:
token: "{{ auth_token.json.access_token }}"
body_format: json
status_code: 200