Simplify fact gathering by using the cli instead of a webapi request
This commit is contained in:
parent
23e2941b3a
commit
b6ee8f76c2
6 changed files with 84 additions and 60 deletions
|
@ -28,14 +28,14 @@ class ActionModule(ActionBase):
|
|||
syncthing = hostvars['syncthing']
|
||||
peer = {
|
||||
'address': 'dynamic',
|
||||
'id': '0000000-0000000-0000000-0000000-0000000-0000000-0000000-0000000',
|
||||
'id': '',
|
||||
'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']:
|
||||
if 'ansible_local' in hostvars and 'syncthing' in hostvars['ansible_local']:
|
||||
peer['id'] = hostvars['ansible_local']['syncthing']['id']
|
||||
peers[hostname] = peer
|
||||
|
||||
|
@ -44,24 +44,9 @@ class ActionModule(ActionBase):
|
|||
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():
|
||||
|
|
46
action_plugins/syncthing_pre.py
Normal file
46
action_plugins/syncthing_pre.py
Normal file
|
@ -0,0 +1,46 @@
|
|||
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 = []
|
||||
|
||||
### Compiling host configuration ######################################
|
||||
config = {}
|
||||
if 'syncthing' in task_vars:
|
||||
config = {
|
||||
'config_path': "",
|
||||
'folders_to_create': [],
|
||||
'packages': [],
|
||||
'service': "syncthing",
|
||||
'user_group': "syncthing",
|
||||
}
|
||||
if task_vars['ansible_distribution'] == 'FreeBSD':
|
||||
config['config_dir'] = "/usr/local/etc/syncthing/"
|
||||
config['data_dir'] = "/var/syncthing"
|
||||
config['packages'] = ["syncthing"]
|
||||
elif task_vars['ansible_distribution'] == 'Gentoo':
|
||||
config['config_dir'] = "/var/lib/syncthing/.config/syncthing/"
|
||||
config['data_dir'] = "/var/lib/syncthing"
|
||||
config['packages'] = ["net-p2p/syncthing"]
|
||||
else:
|
||||
error_msgs.append(f"syncthing role does not support {task_vars['ansible_distribution']} hosts yet")
|
||||
|
||||
### Results compilation ##############################################
|
||||
if error_msgs != []:
|
||||
result['msg'] = ' ; '.join(error_msgs)
|
||||
result['failed'] = True
|
||||
|
||||
result['ansible_facts'] = {
|
||||
'syncthing_pre': config,
|
||||
}
|
||||
|
||||
return result
|
Reference in a new issue