-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbuskill.py
264 lines (231 loc) · 8.53 KB
/
buskill.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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
#!/usr/bin/env python
import os
import time
import sys
import fnmatch
import subprocess
import datetime
def print_help():
print(
"""
For Normal Usage:
BusKill.py -D Device_Name -T Trigger_Name
triggers
-T -- USed to define the Trigger Buskill is configured to use
-Q -- Reads the TrigInfo.txt, this file contains information about the Trigger
-LT -- Lists Installed Triggers on the system
Devices
-D -- Used to define the Device Buskill is configured to use
-LD -- Creates a List for available Devices within MacOSX
Configuration
-SC -- Creates a configuration File. Use -SC at the end of normal usage to save the config
-CC -- Clears the Configuration File created by -SC
-C -- Uses a Configuration File, Must be created by -SC
other
-H -- Reads the Help File
""")
def Find_Run_Path():
dirname = os.path.abspath(__file__).split("/")
del dirname[len(dirname) - 1]
return "/".join(dirname)
def Write_Log(LOG_LOCATION, LEVEL, MESSAGE):
with open(LOG_LOCATION, "a") as logfile:
logfile.write(str(datetime.datetime.now().ctime()) + " - " + LEVEL + " - " + MESSAGE + "\n")
def Validation(LOG_LOCATION, Device, Trigger):
for trigger in Get_Triggers():
if Trigger.strip() == trigger:
Trig = True
break
else:
Trig = False
if Trig != True:
Write_Log(LOG_LOCATION, "ERROR", Trigger + " was not found")
else:
Write_Log(LOG_LOCATION, "INFO", Trigger + " was found")
for device in Get_Devices():
if Device.strip() == device:
Dev = True
break
try:
if Dev != True:
Dev = False
Write_Log(LOG_LOCATION, "ERROR", Device + " was not found")
else:
Write_Log(LOG_LOCATION, "INFO", Device + " was found")
except UnboundLocalError:
print("Device was not found.")
Write_Log(LOG_LOCATION, "ERROR", Device + " was not found")
return
return (Dev and Trig)
def Check_Device(LOG_LOCATION, Device):
if os.path.exists("/dev/"+Device) == True:
return True
else:
Write_Log(LOG_LOCATION, "INFO", Device + " has been removed")
return False
def Execute_Trigger(LOG_LOCATION, Trigger):
try:
Write_Log(LOG_LOCATION, "INFO", "Device Removal Detected!" + Trigger + " Executing")
subprocess.call("python Trigger.py", shell = True)
except IOError:
Write_Log(LOG_LOCATION, "ERROR", Trigger + " has not been found. Application Error")
print("Something went wrong!")
def Normal_Operation(LOG_LOCATION, Device, Trigger):
os.chdir("Triggers/"+Trigger+"/")
print("BusKill is now running")
Triggered = False
try:
while Triggered == False:
if Check_Device(LOG_LOCATION, Device) == False:
Execute_Trigger(LOG_LOCATION ,Trigger)
Write_Log(LOG_LOCATION, "INFO", "BusKill executed")
Triggered = True
time.sleep(5)
except KeyboardInterrupt:
Write_Log(LOG_LOCATION, "INFO", "BusKill was stopped via a KeyboardInterrupt")
print("\n BusKill Stopped")
def Save_Configuration(LOG_LOCATION, Device, Trigger):
if os.path.exists("config.txt") == True:
Write_Log(LOG_LOCATION, "ERROR", "Configuration Change attempted, failed due to Configuration existing")
print("CONFIG ALREADY EXISTS.")
print("PLEASE USE -CC TO CLEAR THE CONFIG")
Write_Log(LOG_LOCATION, "WARNING", "Attempted config save. However, already existed")
else:
with open("config.txt", "a") as config:
config.write("THIS FILE CAN BE MODIFIED MANUALLY. IF IT FAILS VALIDATION PLEASE USE - \n")
config.write("Device:" + Device + "\n")
config.write("Trigger:" + Trigger + "\n")
Write_Log(LOG_LOCATION, "INFO", "Config saved.")
def Get_Dev_From_Conf():
with open("config.txt") as conf:
return conf.readlines()[1].split(":")[1]
def Get_Trig_From_Conf():
with open("config.txt") as conf:
return conf.readlines()[2].split(":")[1]
def Clear_Config(LOG_LOCATION):
if os.path.exists("config.txt") == False:
print("No Config found!! Nothing to clear")
Write_Log(LOG_LOCATION, "INFO", "Config Removal attempted, not found")
else:
os.remove("config.txt")
if os.path.exists("config.txt"):
print("Internal Error, Please Try again (or raise a user story on Github)")
Write_Log(LOG_LOCATION, "ERROR", "BusKill could not remove the config file")
else:
print("Config Cleared!")
Write_Log(LOG_LOCATION, "WARNING", "Configuration Removed")
def Get_Devices():
subprocess.call("ioreg -p IOUSB -w0 | sed 's/[^o]*o //; s/@.*$//' | grep -v '^Root.*' > Devices.txt", shell=True)
Usable_Device = list()
with open("Devices.txt") as Devices:
for Device in Devices:
if Device.lower().__contains__("internal") == False:
if Device.lower().__contains__("built-in") == False:
if Device.lower().__contains__("hub") == False:
if Device.__contains__("IOUSBHostDevice") == False:
if Device.lower().__contains__("bluetooth") == False:
Usable_Device.append(Device)
return Usable_Device
def List_Devices():
Devices = Get_Devices()
counter = 0
for Device in Devices:
counter = counter + 1
print(str(counter) + " - " + Device)
def Get_Triggers():
Triggers = []
dirlist = os.listdir("Triggers/")
for dir in dirlist:
if os.path.isdir("Triggers/"+dir) == True:
Triggers.append(dir.lower())
return Triggers
def List_Triggers():
Triggers = Get_Triggers()
counter = 0
for Trigger in Triggers:
counter = counter + 1
print(str(counter) + " - " + Trigger)
def Query_Trigger(Trigger):
with open("Triggers/"+Trigger+"/TriggerInfo.txt") as InfoFile:
DATA = InfoFile.read().splitlines()
for line in DATA:
print(line)
def Main(args):
dirname = Find_Run_Path()
LOG_LOCATION = dirname + "/log.txt"
#remeber to change where all the write logs are pointing to
os.chdir(dirname)
Dev = False
Trig = False
Quer = False
Query = False
Config = False
Clear_Conf = False
Save_Conf = False
Help = False
List_Trig = False
List_Dev = False
for index, arg in enumerate(args):
if arg.upper() == "-T":
Trig = True
Trigger = index
elif arg.upper() == "-Q":
Quer = True
Query = index
elif arg.upper() == "-D":
Dev = True
Device = index
elif arg.upper() == "-SC":
Save_Conf = True
elif arg.upper() == "-C":
Config = True
elif arg.upper() == "-CC":
Clear_Conf = True
elif arg.upper() == "-H":
Help = True
elif arg.upper() == "-LT":
List_Trig = True
elif arg.upper() == "-LD":
List_Dev = True
if Dev and Trig == True:
Device = args[Device + 1]
Trigger = args[Trigger + 1]
if Validation(LOG_LOCATION, Device, Trigger):
if Save_Conf == True:
Save_Configuration(LOG_LOCATION, Device, Trigger)
Normal_Operation(LOG_LOCATION, Device, Trigger)
sys.exit()
else:
print("Something went wrong")
sys.exit()
if Quer == True:
Trigger = args[Query+1]
with open("/Triggers/"+Trigger+"/TriggerInfo.txt") as InfoFile:
print(InfoFile.readline())
sys.exit()
if Config == True:
Device = Get_Dev_From_Conf().strip()
Trigger = Get_Trig_From_Conf().strip()
if Validation(LOG_LOCATION, Device, Trigger):
Write_Log(LOG_LOCATION, "INFO", "Validation passed for " + Device + " and " + Trigger)
Normal_Operation(LOG_LOCATION, Device, Trigger)
sys.exit()
else:
Write_Log(LOG_LOCATION, "ERROR", "Validation failed for " + Device + " and " + Trigger)
print("Invalid Device or Trigger")
sys.exit()
if Clear_Conf == True:
Clear_Config(LOG_LOCATION)
sys.exit()
if List_Trig == True:
List_Triggers()
sys.exit()
if List_Dev == True:
List_Devices()
sys.exit()
if Help == True:
print_help()
sys.exit()
else:
print_help()
Main(sys.argv)