-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathAutomateDiagnostics.py
91 lines (78 loc) · 2.53 KB
/
AutomateDiagnostics.py
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
import json
import os
import subprocess
import platform
import base64
import getopt
import sys
import cgi
def system_call(command):
p = subprocess.Popen([command], stdout=subprocess.PIPE, shell=True)
return p.stdout.read()
# Read state file for info
with open("/usr/local/ltechagent/state","r") as read_file:
data = json.load(read_file)
lterrors = ""
try:
opts, args = getopt.getopt(sys.argv[1:],"e")
for opt, arg in opts:
if opt == '-e':
with open("/usr/local/ltechagent/agent.log","r") as log_file:
lterrors = cgi.escape(log_file.read())
except getopt.GetoptError:
pass
lterrors_bytes = lterrors.encode("ascii")
lterrors_b64_bytes = base64.b64encode(lterrors_bytes)
lterrors_str = lterrors_b64_bytes.decode("ascii")
# Get last contact date
lc = data["last_contact"]
last_contact = "{0}/{1}/{2} {3}:{4:02d}:{5:02d}".format(lc["month"],lc["day_of_month"],lc["year"],lc["hour"],lc["min"],lc["sec"])
old_version = data["version"]
system_call("/usr/local/ltechagent/ltupdate")
# Read state file for info
with open("/usr/local/ltechagent/state","r") as read_file:
data = json.load(read_file)
if old_version != data["version"]:
update = "Updated from "+old_version+" to "+ data["version"]
else:
update = "Already updated to "+ data["version"]
# Check services
if platform.system() == 'Darwin':
if system_call("launchctl list | grep com.labtechsoftware.LTSvc") != "":
statusname = "Running"
else:
os.system("launchctl stop com.labtechsoftware.LTSvc")
os.system("launchctl start com.labtechsoftware.LTSvc")
if system_call("launchctl list | grep com.labtechsoftware.LTSvc") != "":
statusname = "Running"
else:
statusname = "Stopped"
svc_ltsvc = { "Status": statusname, "User": "com.labtechsoftware.LTSvc", "Start Mode": "Auto"}
elif platform.system() == 'Linux':
status = os.system('service ltechagent status')
if status == 0:
statusname = "Running"
elif status == 3:
os.system('service ltechagent stop')
os.system('service ltechagent start')
status = os.system('service ltechagent status')
if status == 0:
statusname = "Running"
else:
statusname = "Stopped"
else:
statusname = "Stopped"
svc_ltsvc = { "Status": statusname, "User": "ltechagent", "Start Mode": "Auto"}
diag_result = {
'server_addr': data["last_good_server_url"],
'lastcontact': last_contact,
'update': update,
'version': data["version"],
'id': data['computer_id'],
'clientid': data['client_id'],
'online': data["is_signed_in"],
'svc_ltservice': svc_ltsvc,
'lterrors': lterrors_str
}
print("!---BEGIN JSON---!")
print(json.dumps(diag_result))