Refresh token
This commit is contained in:
parent
9bd4b60ba7
commit
0d52eba410
Binary file not shown.
|
@ -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"}}"""
|
||||
|
|
15
script.py
15
script.py
|
@ -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)
|
||||
|
|
Loading…
Reference in New Issue