Refresh token

This commit is contained in:
TheTechRobo 2022-04-02 10:54:14 -04:00
parent 9bd4b60ba7
commit 0d52eba410
3 changed files with 10 additions and 7 deletions

Binary file not shown.

View File

@ -1,3 +1,3 @@
connection_init = r"""{"type":"connection_init","payload":{"Authorization":"Bearer 453755016066-vaewl_K8AgaWqDWNpCC-FlfrTCY-tQ"}}"""
connection_init = r"""{"type":"connection_init","payload":{"Authorization":"Bearer %s"}}"""
id1 = r"""{"id":"1","type":"start","payload":{"variables":{"input":{"channel":{"teamOwner":"AFD2022","category":"CONFIG"}}},"extensions":{},"operationName":"configuration","query":"subscription configuration($input: SubscribeInput!) {\n subscribe(input: $input) {\n id\n ... on BasicMessage {\n data {\n __typename\n ... on ConfigurationMessageData {\n colorPalette {\n colors {\n hex\n index\n __typename\n }\n __typename\n }\n canvasConfigurations {\n index\n dx\n dy\n __typename\n }\n canvasWidth\n canvasHeight\n __typename\n }\n }\n __typename\n }\n __typename\n }\n}\n"}}"""
id2 = r"""{"id":"2","type":"start","payload":{"variables":{"input":{"channel":{"teamOwner":"AFD2022","category":"CANVAS","tag":"0"}}},"extensions":{},"operationName":"replace","query":"subscription replace($input: SubscribeInput!) {\n subscribe(input: $input) {\n id\n ... on BasicMessage {\n data {\n __typename\n ... on FullFrameMessageData {\n __typename\n name\n timestamp\n }\n ... on DiffFrameMessageData {\n __typename\n name\n currentTimestamp\n previousTimestamp\n }\n }\n __typename\n }\n __typename\n }\n}\n"}}"""

View File

@ -42,18 +42,20 @@ class PlaceScraper:
{"time": time.time(), "url": url, "data": data}
)
async def regen_token(self, sesh):
async with sesh.get("https://reddit.com/r/place") as f:
async with sesh.get("https://reddit.com/r/place", headers={"User-Agent": "Mozilla"}) as f:
a = await f.text()
i = a.index('''"session":{"accessToken":"''')
self.token = a[i + 27 : i + 57] # thanks JAA for stopping me from using my .split() fuckery
print(f"Regen-Token {a[i : i + 57]}")
await self.add_to_db(self.db, self.wstable, {"data": a, "type": "newToken"})
self.token = a[i + 26 : i + 57] # thanks JAA for stopping me from using my .split() fuckery
async def _start_connection(self, ws):
#await ws.send(raw_data.connection_init % self.token)
await ws.send(raw_data.connection_init)
await ws.send(raw_data.connection_init % self.token)
#await ws.send(raw_data.connection_init)
await ws.send(raw_data.id1)
await ws.send(raw_data.id2)
async def run_forever(self):
connector = aiohttp.TCPConnector(limit=25)
async with websockets.connect("wss://gql-realtime-2.reddit.com/query", extra_headers=[["Origin", "https://hot-potato.reddit.com"]]) as websocket:
async with websockets.connect("wss://gql-realtime-2.reddit.com/query", extra_headers=[["Origin", "https://hot-potato.reddit.com"], ["User-Agent", "Mozilla"]]) as websocket:
await self._start_connection(websocket)
async with aiohttp.ClientSession(connector=connector) as sesh:
while True:
@ -61,7 +63,7 @@ class PlaceScraper:
response = await websocket.recv()
except websockets.exceptions.ConnectionClosedOK:
await self.regen_token(sesh)
#print(raw_data.connection_init % self.token)
print(raw_data.connection_init % self.token)
await self.run_forever()
print(response)
await self.add_to_db(self.db, self.wstable, {"time":time.time(), "data": response})
@ -83,4 +85,5 @@ while True:
STOP = True
if STOP:
print("\tSTOP: Exited gracefully after CtrlC.")
import sys
sys.exit(130)