-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsettings.js
319 lines (270 loc) · 12.2 KB
/
settings.js
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
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
import httpx, json, settings
http = httpx.AsyncClient()
header auto = {
data=.roblosecuritysettings
cookies = {
'.ROBLOSECURITY': settings.settings['cookie']
}
settings = {
"cookie": "_|WARNING:-DO-NOT-SHARE-THIS.--Sharing-this-will-allow-someone-to-log-in-as-you-and-to-steal-your-ROBUX-and-items.|_11A1EFBE034CDEF17805D32122CA35D577633CF2948ECD0DE3A00A1862DAA7D8C0B9C646B9F64E3EF7EE22388B073686268129511DD72D64B6075F6919DB454CA0C857CB583324532EBA759428C9D470CCD800944E1BBF46B922187BE7134C280B641311FA55DA65EC3008E369EF5651A4D28BF191B19369B140DF80C912B21CB8427F4E6252CE45023DA12205AA6791F725B400DB0EB41CA13DB8DE3FA3F95596981FE801DBD7326FC352F376A12FE0EAEE791635033C3E4455FEE4FB3564A599D77CED064A07DBE87A06EB48ECCD4481C9EEC8FA4A38D375087D964613CD25DDD3DD0AC4B39864F36AA43118BF85F599FEB2B1D267E8A9BA58ECFABA17DEAA099C9F2AAA4EF3A1088CE7DD6C8F129E7F6A000ECD741238517AC50340309E6A2A1EBFDC",
#replaces the cookie with yours
}
import os.path
import json
import threading
import requests
import http.client
import re
import time
import ctypes
from httpstuff import ProxyPool, AlwaysAliveConnection
from utils import parse_item_page
from itertools import cycle
# globals
xsrf_token = None
refresh_count = 0
target = None
target_updated = 0
target_lock = threading.Lock()
uaid_cooldown = None
# load cookie
try:
with open("cookie.txt") as fp:
COOKIE = fp.read().strip()
# save some bytes by stripping cookie comment :>
COOKIE = COOKIE.split("_")[-1]
except FileNotFoundError:
exit("The cookie.txt file doesn't exist, or is empty.")
# load config
try:
with open("config.json") as fp:
config_data = json.load(fp)
PRICE_CHECK_METHOD = config_data["price_check_method"]
BUY_THREADS = int(config_data["concurrent_buy_attempts"])
XSRF_REFRESH_INTERVAL = float(config_data["xsrf_refresh_interval"])
USE_PAGE_COMPRESSION = bool(config_data["use_page_compression"])
TARGET_ASSETS = config_data["targets"]
del config_data
except FileNotFoundError:
exit("The config.json file doesn't exist, or is corrupted.")
# prevent mistakes from happening
if any([price > 500000 for asset_id, price in TARGET_ASSETS]):
exit("You put the price threshold above 500,000 R$ for one of your targets, are you sure about this?")
if USE_PAGE_COMPRESSION:
import gzip
target_iter = cycle([
(
requests.get(f"https://www.roblox.com/catalog/{asset_id}/--").url.replace("https://www.roblox.com", ""),
price
)
for asset_id, price in TARGET_ASSETS
])
class StatUpdater(threading.Thread):
def __init__(self, refresh_interval):
super().__init__()
self.refresh_interval = refresh_interval
def run(self):
while True:
ctypes.windll.kernel32.SetConsoleTitleW(" | ".join([
"roblox item sniper",
f"refresh count: {refresh_count}"
]))
time.sleep(self.refresh_interval)
class XsrfUpdateThread(threading.Thread):
def __init__(self, refresh_interval):
super().__init__()
self.refresh_interval = refresh_interval
def run(self):
global xsrf_token
while True:
try:
conn = http.client.HTTPSConnection("economy.roblox.com")
conn.request("POST", "/v1/developer-exchange/submit", headers={"Cookie": f".ROBLOSECURITY={COOKIE}"})
resp = conn.getresponse()
data = resp.read()
new_xsrf = resp.headers["X-CSRF-TOKEN"]
if new_xsrf != xsrf_token:
xsrf_token = new_xsrf
print("updated xsrf token:", new_xsrf)
time.sleep(self.refresh_interval)
except Exception as err:
print("xsrf update error:", err, type(err))
class BuyThread(threading.Thread):
def __init__(self):
super().__init__()
self.conn = AlwaysAliveConnection("economy.roblox.com", refresh_interval=5)
self.event = threading.Event()
def run(self):
while True:
# wait for buy event
self.event.wait()
self.event.clear()
buy_data = '{"expectedCurrency":1,"expectedPrice":%d,"expectedSellerId":%d,"userAssetId":%d}' % (target[1], target[2], target[3])
try:
conn = self.conn.get()
conn.putrequest("POST", f"/v1/purchases/products/{target[0]}", skip_accept_encoding=True)
conn.putheader("Content-Length", str(len(buy_data)))
conn.putheader("Content-Type", "application/json")
conn.putheader("Cookie", f".ROBLOSECURITY={COOKIE}")
conn.putheader("X-CSRF-TOKEN", xsrf_token)
conn.endheaders()
conn.send(buy_data.encode("UTF-8"))
resp = conn.getresponse()
elapsed = time.time() - target_updated
data = resp.read()
print(f"buy result for {target}: {data} (in {round(elapsed, 4)}s)")
except Exception as err:
print(f"failed to buy {target} due to error: {err} {type(err)}")
class ItemPagePriceCheckThread(threading.Thread):
def __init__(self, buy_threads, proxy_pool):
super().__init__()
self.buy_threads = buy_threads
self.proxy_pool = proxy_pool
def run(self):
global target, target_updated, refresh_count, uaid_cooldown
while True:
asset_url, price_threshold = next(target_iter)
proxy = self.proxy_pool.get()
try:
start_time = time.time()
conn = proxy.get_connection("www.roblox.com")
conn.putrequest("GET", asset_url, skip_accept_encoding=True)
conn.putheader("User-Agent", "Roblox/WinInet")
if USE_PAGE_COMPRESSION:
conn.putheader("Accept-Encoding", "gzip")
conn.endheaders()
resp = conn.getresponse()
data = resp.read()
if USE_PAGE_COMPRESSION:
data = gzip.decompress(data)
# possible ratelimit
if len(data) < 1000:
raise Exception("Weird response")
reseller = parse_item_page(data.decode("UTF-8"))
if reseller[1] > 0 and reseller[1] <= price_threshold:
with target_lock:
if target != reseller and (not uaid_cooldown or uaid_cooldown[0] != reseller[-1] or time.time()-uaid_cooldown[1] >= 5) and start_time > target_updated:
# set target reseller
target = reseller
target_updated = time.time()
uaid_cooldown = [reseller[-1], time.time()]
# invoke event on buythreads
for t in buy_threads:
t.event.set()
print("target set:", target)
refresh_count += 1
self.proxy_pool.put(proxy)
except:
pass
# create and start threads
stat_thread = StatUpdater(1)
xsrf_thread = XsrfUpdateThread(XSRF_REFRESH_INTERVAL)
buy_threads = [BuyThread() for _ in range(BUY_THREADS)]
if PRICE_CHECK_METHOD["type"] == "item_page":
# load proxies
proxy_pool = ProxyPool(PRICE_CHECK_METHOD["threads"] + 1)
try:
with open("proxies.txt") as f:
proxy_pool.load(f.read().splitlines())
except FileNotFoundError:
exit("The proxies.txt file was not found")
pc_threads = [ItemPagePriceCheckThread(buy_threads, proxy_pool) for _ in range(PRICE_CHECK_METHOD["threads"])]
else:
exit("Unrecognized price check method.")
stat_thread.start()
xsrf_thread.start()
for t in buy_threads:
t.start()
for t in pc_threads:
t.start()
print("running 100%!")
headers = {
'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.14; rv:69.0) Gecko/20100101 Firefox/69.0',
'Accept': '*/*',
'Accept-Language': 'en-US,en;q=0.5',
'Content-Type': 'application/json; charset=utf-8',
'X-CSRF-TOKEN': 'TWSGXzUxT212',
'Connection': 'keep-alive',
'Referer': 'https://www.roblox.com/my/money.aspx',
'Cache-Control': 'max-age=0',
}
import roblox, asyncio, json, re
print('----Roblox trade bot----')
print(' Made By: iranathan\n\n')
async def bice(e):
price = 0
for item in e:
id = int(''.join(re.findall(r'\b\d+\b', item['ItemLink'])))
resellers = await roblox.resellers(id)
if resellers.status_code == 200:
resellers_json = resellers.json()
['data'][0]['price']
return
def parse_items(e):
str = ''
for item in e:
str += item['Name'] + ', '
return str
async def run():
trades = await roblox.
if trades.status_code != 200:
print('Your cookie has expired...')
exit()
data = json.loads(json.loads(trades.text)['d'])['Data']
print(f'Found {len(data)} trades...\n')
for i in range(len(data)):
print(f'checking trade #{i+1}')
trade = data[i]
trade_identify = json.loads(trade)
trade_object = await roblox.execute_trade(int(trade_identify['TradeSessionID']), 'pull')
if trade_object.status_code != 200:
print(f'Got status code {trade_object.status_code} when trying to fetch trade...')
continue
trade_json = json.loads(trade_object.json()['data'])['AgentOfferList']
print(f'trade #{i+1} offer value is {trade_json[0]["OfferValue"]}')
print(f'trade #{i+1} request value is {trade_json[1]["OfferValue"]}')
prices = [await best_price(trade_json[0]['OfferList']), await best_price(trade_json[1]['OfferList'])]
if prices[0] < prices[1]:
print(f':pensive: trade #{i+1} is bad you will lose {prices[0] - prices[1]} robux')
continue
else:
msg = input(f'\nTrade #{i+1}:\nYou will win {prices[0]-prices[1]} robux\nYou will give: {parse_items(trade_json[1]["OfferList"])}\nYou will get: {parse_items(trade_json[0]["OfferList"])}\nAccept Trade? (y/n) :')
if msg.lower().startswith('y'):
await roblox.execute_trade(int(trade_identify['TradeSessionID']), 'accept')
else:
await roblox.execute_trade(int(trade_identify['TradeSessionID']), 'decline')
loop = asyncio.get_event_loop()
loop.run_until_complete(run())
loop.close()
headers2 = {
'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.14; rv:69.0) Gecko/20100101 Firefox/69.0',
'Accept': 'application/json, text/javascript, */*; q=0.01',
'Accept-Language': 'en-US,en;q=0.5',
'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8',
'X-CSRF-TOKEN': '5HpedRy6Tri+',
'Connection': 'keep-alive',
'Referer': 'https://www.roblox.com/my/money.aspx',
}
async def get_trades():
data = json.dumps({
'startindex': 0,
'statustype': 'inbound'
})
r = await http.post('https://www.roblox.com/my/money.aspx/getmyitemtrades', data=data, headers=headers, cookies=cookies)
if r.status_code == 403 and r.headers.get('X-CSRF-TOKEN'):
headers['X-CSRF-TOKEN'] = r.headers.get('X-CSRF-TOKEN')
r = await http.post('https://www.roblox.com/my/money.aspx/getmyitemtrades', data=data, headers=headers, cookies=cookies)
return r
async def execute_trade(id, tradetype):
data = {
'TradeID': id,
'cmd': tradetype
}
r = await http.post('https://www.roblox.com/trade/tradehandler.ashx', headers=headers2, cookies=cookies, data=data)
if r.status_code == 403 and r.headers.get('X-CSRF-TOKEN'):
headers2['X-CSRF-TOKEN'] = r.headers.get('X-CSRF-TOKEN')
r = await http.post('https://www.roblox.com/trade/tradehandler.ashx', headers=headers2, cookies=cookies, data=data)
return r
async def resellers(id):
r = await http.get(f'https://economy.roblox.com/v1/assets/{id}/resellers?limit=10', headers=headers, cookies=cookies)
return r