|
| 1 | +import json |
| 2 | +import os |
| 3 | +import time |
| 4 | +import urllib.request |
| 5 | + |
| 6 | +from ansible import context |
| 7 | +from ansible.cli import CLI |
| 8 | +from ansible.executor.playbook_executor import PlaybookExecutor |
| 9 | +from ansible.inventory.manager import InventoryManager |
| 10 | +from ansible.module_utils.common.collections import ImmutableDict |
| 11 | +from ansible.parsing.dataloader import DataLoader |
| 12 | +from ansible.vars.manager import VariableManager |
| 13 | + |
| 14 | + |
| 15 | +def runPlaybook(yml, evars): |
| 16 | + loader = DataLoader() |
| 17 | + context.CLIARGS = ImmutableDict(tags={}, timeout=300, listtags=False, listtasks=False, listhosts=False, syntax=False, connection='ssh', |
| 18 | + module_path=None, forks=100, private_key_file=None, ssh_common_args=None, ssh_extra_args=None, |
| 19 | + sftp_extra_args=None, scp_extra_args=None, become=False, become_method='sudo', become_user='root', |
| 20 | + verbosity=True, check=False, start_at_task=None, extra_vars=[{**{"ansible_python_interpreter": "/usr/bin/python3"}, **evars}]) |
| 21 | + inventory = InventoryManager(loader=loader, sources=('hosts',)) |
| 22 | + variable_manager = VariableManager(loader=loader, inventory=inventory, version_info=CLI.version_info(gitinfo=False)) |
| 23 | + pbex = PlaybookExecutor(playbooks=[yml], inventory=inventory, variable_manager=variable_manager, loader=loader, passwords={}) |
| 24 | + results = pbex.run() |
| 25 | + if results != 0: |
| 26 | + raise RuntimeError("Playbook failed to run correctly") |
| 27 | + |
| 28 | +def switch(plug, on): |
| 29 | + if on: |
| 30 | + state = "On" |
| 31 | + else: |
| 32 | + state = "Off" |
| 33 | + api_url = f"http://{plug}/cm?cmnd=Power%20{state}" |
| 34 | + request = urllib.request.Request(api_url) |
| 35 | + with urllib.request.urlopen(request) as response: |
| 36 | + data = json.loads(response.read().decode("utf-8")) |
| 37 | + if data['POWER'] != state.upper(): |
| 38 | + raise Exception("Failed to set power", data['POWER']) |
| 39 | + |
| 40 | +if __name__ == "__main__": |
| 41 | + |
| 42 | + plug = os.getenv('TASMOTA') |
| 43 | + if plug is None: |
| 44 | + raise Exception("Need to set TASMOTA env variable") |
| 45 | + |
| 46 | + COUNT = 3 |
| 47 | + for i in range(COUNT): |
| 48 | + print(f"At {i}") |
| 49 | + if i < COUNT - 1: |
| 50 | + runPlaybook("control.yml", {"shutdown" : True}) |
| 51 | + time.sleep(20) |
| 52 | + switch(plug, False) |
| 53 | + time.sleep(5) |
| 54 | + switch(plug, True) |
| 55 | + else: |
| 56 | + runPlaybook("control.yml", {}) |
0 commit comments