|
|
@ -8,22 +8,19 @@ def check_target_available(target_host: str):
|
|
|
|
# Ping the host to check if it's online
|
|
|
|
# Ping the host to check if it's online
|
|
|
|
ips = get_target_ips()
|
|
|
|
ips = get_target_ips()
|
|
|
|
ip_target = ips[target_host]
|
|
|
|
ip_target = ips[target_host]
|
|
|
|
|
|
|
|
target_node_route = f'http://{ip_target}:9713/status'
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
# Use subprocess to execute the ping command
|
|
|
|
response = requests.get(target_node_route, timeout=30)
|
|
|
|
response = subprocess.run(
|
|
|
|
#print(f"{response =}")
|
|
|
|
["ping", "-n", "1", "-w", "1000", ip_target], # Windows parameters: '-n 1' sends one ping, '-w 1000' sets a 1-second timeout
|
|
|
|
return response.status_code == 200
|
|
|
|
stdout=subprocess.PIPE,
|
|
|
|
except requests.exceptions.RequestException as re:
|
|
|
|
stderr=subprocess.PIPE
|
|
|
|
#print(f"Error: {str(re)}")
|
|
|
|
)
|
|
|
|
|
|
|
|
return response.returncode == 0
|
|
|
|
|
|
|
|
except Exception as e:
|
|
|
|
|
|
|
|
print(f"Error pinging the host: {e}")
|
|
|
|
|
|
|
|
return False
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def get_target_ips():
|
|
|
|
def get_target_ips():
|
|
|
|
targets = {
|
|
|
|
targets = {
|
|
|
|
'nuc_morroc': '192.168.178.52'
|
|
|
|
'nuc_morroc': '192.168.178.53'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return targets
|
|
|
|
return targets
|
|
|
|
|
|
|
|
|
|
|
@ -45,12 +42,12 @@ def send_wakeonlan(target_host: str):
|
|
|
|
def _send_command_to_target(target_ip: str, command: str = 'testcommand') -> str:
|
|
|
|
def _send_command_to_target(target_ip: str, command: str = 'testcommand') -> str:
|
|
|
|
target_node_route = f'http://{target_ip}:9713/osiris_execute'
|
|
|
|
target_node_route = f'http://{target_ip}:9713/osiris_execute'
|
|
|
|
response = requests.post(target_node_route, json={'command': command})
|
|
|
|
response = requests.post(target_node_route, json={'command': command})
|
|
|
|
|
|
|
|
result = response.json()
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
if response.status_code == 200:
|
|
|
|
if response.status_code == 200:
|
|
|
|
result = response.json()
|
|
|
|
|
|
|
|
print('Response:', result.get('message'))
|
|
|
|
print('Response:', result.get('message'))
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
print('Failed to execute script:', response.json())
|
|
|
|
print('Failed to execute script:', result.get('message'))
|
|
|
|
except requests.exceptions.RequestException as e:
|
|
|
|
except requests.exceptions.RequestException as e:
|
|
|
|
print(f"Error connecting to the host {target_host}: {e}")
|
|
|
|
print(f"Error connecting to the host {target_host}: {e}")
|
|
|
|
|
|
|
|
|
|
|
@ -69,16 +66,17 @@ def send_testcommand(target_host: str):
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
if __name__ == "__main__":
|
|
|
|
target_host = 'nuc_morroc'
|
|
|
|
target_host = 'nuc_morroc'
|
|
|
|
available = check_target_available(target_host)
|
|
|
|
print("Verfügbarkeit des Ziel-Hostes wird überprüft.")
|
|
|
|
if available:
|
|
|
|
if not check_target_available(target_host):
|
|
|
|
send_testcommand(target_host)
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
send_wakeonlan(target_host)
|
|
|
|
send_wakeonlan(target_host)
|
|
|
|
print(f"Host {target_host} wird auf geweckt")
|
|
|
|
print(f"Host {target_host} wird aufgeweckt. Warten auf Hochfaren...")
|
|
|
|
time.sleep(30)
|
|
|
|
time.sleep(60)
|
|
|
|
available = check_target_available(target_host)
|
|
|
|
|
|
|
|
if not available:
|
|
|
|
if check_target_available(target_host):
|
|
|
|
print(f"Host {target_host} reagiert nicht auf weckruf. Programm wird beendet.")
|
|
|
|
#send_testcommand(target_host)
|
|
|
|
|
|
|
|
#print(f"TestCommand an Host {target_host} gesendet.")
|
|
|
|
|
|
|
|
send_shutdown_command(target_host)
|
|
|
|
|
|
|
|
print(f"Shutdown an Host {target_host} gesendet.")
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
print(f"Host {target_host} ist aufgewacht. Kommando wird gesendet.")
|
|
|
|
print(f"Host {target_host} ist offline. Programm wird beendet.")
|
|
|
|
send_testcommand(target_host)
|
|
|
|
|