summaryrefslogtreecommitdiff
path: root/action_plugins/syncthing_init.py
diff options
context:
space:
mode:
authorJulien Dessaux2023-01-22 00:16:43 +0100
committerJulien Dessaux2023-01-22 00:20:57 +0100
commit23e2941b3a6aff6415913cc91198147128260b06 (patch)
tree5c9f27dace6a077a447d5f1267de033b454f0f42 /action_plugins/syncthing_init.py
parentInitial import (diff)
downloadsyncthing-ansible-role-1.0.tar.gz
syncthing-ansible-role-1.0.tar.bz2
syncthing-ansible-role-1.0.zip
Imported from personal ansible repository1.0
Diffstat (limited to 'action_plugins/syncthing_init.py')
-rw-r--r--action_plugins/syncthing_init.py79
1 files changed, 79 insertions, 0 deletions
diff --git a/action_plugins/syncthing_init.py b/action_plugins/syncthing_init.py
new file mode 100644
index 0000000..eb6cf9f
--- /dev/null
+++ b/action_plugins/syncthing_init.py
@@ -0,0 +1,79 @@
+from ansible.plugins.action import ActionBase
+import re
+import yaml
+from yaml.loader import SafeLoader
+
+class ActionModule(ActionBase):
+ def run(self, tmp=None, task_vars=None):
+ if task_vars is None:
+ task_vars = dict()
+ result = super(ActionModule, self).run(tmp, task_vars)
+ result['changed'] = False
+ result['failed'] = False
+
+ error_msgs = []
+
+ ### Syncthing variables for non ansible hosts #########################
+ peers = {}
+ with open('syncthing_data.yaml') as f:
+ data = yaml.load(f, Loader=SafeLoader)
+ for peer in data:
+ peers[peer['name']] = peer
+ if not 'address' in peer.keys():
+ peer['address'] = 'dynamic'
+
+ ### Syncthing host vars ###############################################
+ for hostname, hostvars in task_vars['hostvars'].items() :
+ if 'syncthing' in hostvars.keys():
+ syncthing = hostvars['syncthing']
+ peer = {
+ 'address': 'dynamic',
+ 'id': '0000000-0000000-0000000-0000000-0000000-0000000-0000000-0000000',
+ 'shared': [],
+ }
+ if 'address' in syncthing.keys():
+ peer['address'] = syncthing['address']
+ for shared in syncthing['shared']:
+ peer['shared'].append({ 'name': shared['name'], 'path': shared['path'], 'peers': shared['peers']})
+ if 'syncthing' in hostvars['ansible_local']:
+ peer['id'] = hostvars['ansible_local']['syncthing']['id']
+ peers[hostname] = peer
+
+ ### Compiling host configuration ######################################
+ config = {}
+ if task_vars['ansible_host'] in peers.keys():
+ myself = peers[task_vars['ansible_host']]
+ config = {
+ 'config_path': "",
+ 'folders_to_create': [],
+ 'packages': [],
+ 'peers': {},
+ 'service': "syncthing",
+ 'shared': myself['shared'],
+ 'user_group': "syncthing",
+ }
+ if task_vars['ansible_distribution'] == 'FreeBSD':
+ config['config_path'] = "/usr/local/etc/syncthing/config.xml"
+ config['folders_to_create'] = ["/usr/local/etc/syncthing/", "/var/syncthing"]
+ config['packages'] = ["p5-libwww", "syncthing"]
+ elif task_vars['ansible_distribution'] == 'Gentoo':
+ config['config_path'] = "/var/lib/syncthing/.config/syncthing/config.xml"
+ config['folders_to_create'] = ["/var/lib/syncthing/.config/syncthing"]
+ config['packages'] = ["net-p2p/syncthing"]
+ else:
+ error_msgs.append(f"syncthing role does not support {task_vars['ansible_distribution']} hosts yet")
+ for shared in myself['shared']:
+ for peer in shared['peers']:
+ if not peer in config['peers'].keys():
+ config['peers'][peer] = { 'id': peers[peer]['id'], 'address': peers[peer]['address'] }
+
+ ### Results compilation ##############################################
+ if error_msgs != []:
+ result['msg'] = ' ; '.join(error_msgs)
+ result['failed'] = True
+
+ result['ansible_facts'] = {
+ 'syncthing_config': config,
+ }
+
+ return result