-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathlocalgrasslite.py
112 lines (102 loc) · 5.05 KB
/
localgrasslite.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
import asyncio
import random
import ssl
import json
import time
import uuid
import requests
import shutil
from loguru import logger
from websockets_proxy import Proxy, proxy_connect
from fake_useragent import UserAgent
from datetime import datetime
async def connect_to_wss(socks5_proxy, user_id):
user_agent = UserAgent(os=['windows', 'macos', 'linux'], browsers='chrome')
random_user_agent = user_agent.random
device_id = str(uuid.uuid3(uuid.NAMESPACE_DNS, socks5_proxy))
logger.info(device_id)
while True:
try:
await asyncio.sleep(random.randint(1, 10) / 10)
custom_headers = {
"User-Agent": random_user_agent,
"Origin": "chrome-extension://ilehaonighjijnmpnagapkhpcdbhclfg"
}
ssl_context = ssl.create_default_context()
ssl_context.check_hostname = False
ssl_context.verify_mode = ssl.CERT_NONE
urilist = ["wss://proxy2.wynd.network:4444/","wss://proxy2.wynd.network:4650/"]
uri = random.choice(urilist)
server_hostname = "proxy2.wynd.network"
proxy = Proxy.from_url(socks5_proxy)
async with proxy_connect(uri, proxy=proxy, ssl=ssl_context, server_hostname=server_hostname,
extra_headers=custom_headers) as websocket:
async def send_ping():
while True:
send_message = json.dumps(
{"id": str(uuid.uuid4()), "version": "1.0.0", "action": "PING", "data": {}})
logger.debug(send_message)
await websocket.send(send_message)
await asyncio.sleep(5)
await asyncio.sleep(1)
asyncio.create_task(send_ping())
while True:
response = await websocket.recv()
message = json.loads(response)
logger.info(message)
# Generate the current datetime in UTC
now = datetime.utcnow()
# Format the datetime as a string in the desired format
formatted_time = now.strftime('%a, %d %b %Y %H:%M:%S GMT')
if message.get("action") == "AUTH":
auth_response = {
"id": message["id"],
"origin_action": "AUTH",
"result": {
"browser_id": device_id,
"user_id": user_id,
"user_agent": custom_headers['User-Agent'],
"timestamp": int(time.time()),
"device_type": "extension",
"version": "4.26.2",
"extension_id": "ilehaonighjijnmpnagapkhpcdbhclfg"
}
}
logger.debug(auth_response)
await websocket.send(json.dumps(auth_response))
elif message.get("action") == "HTTP_REQUEST":
httpreq_response = {
"id": message["id"],
"origin_action": "HTTP_REQUEST",
"result": {
"url": message["url"],
"status": int(200),
"status_text": "OK",
"headers": {
"content-type": "application/json; charset=utf-8",
"date": formatted_time,
"keep-alive": "timeout=5",
"proxy-connection": "keep-alive",
"x-powered-by": "Express",
}
}
}
logger.debug(httpreq_response)
await websocket.send(json.dumps(httpreq_response))
elif message.get("action") == "PONG":
pong_response = {"id": message["id"], "origin_action": "PONG"}
logger.debug(pong_response)
await websocket.send(json.dumps(pong_response))
except Exception as e:
logger.error(e)
logger.error(socks5_proxy)
async def main():
#find user_id on the site in conlose localStorage.getItem('userId') (if you can't get it, write allow pasting)
_user_id = input('Please Enter your user ID: ')
with open('local_proxies.txt', 'r') as file:
local_proxies = file.read().splitlines()
tasks = [asyncio.ensure_future(connect_to_wss(i, _user_id)) for i in local_proxies]
await asyncio.gather(*tasks)
if __name__ == '__main__':
#letsgo
asyncio.run(main())