mirror of
https://github.com/matrix-org/pantalaimon.git
synced 2025-01-09 14:39:34 -05:00
main: Pass our store path to the nio client after logging in.
This commit is contained in:
parent
d51d47334b
commit
710939e5bd
88
main.py
88
main.py
@ -2,9 +2,14 @@
|
|||||||
|
|
||||||
import attr
|
import attr
|
||||||
import asyncio
|
import asyncio
|
||||||
|
import aiohttp
|
||||||
|
import os
|
||||||
|
import json
|
||||||
|
|
||||||
from aiohttp import web, ClientSession
|
from aiohttp import web, ClientSession
|
||||||
from nio import AsyncClient, LoginResponse
|
from nio import AsyncClient, LoginResponse
|
||||||
|
from appdirs import user_data_dir
|
||||||
|
from json import JSONDecodeError
|
||||||
|
|
||||||
HOMESERVER = "https://localhost:8448"
|
HOMESERVER = "https://localhost:8448"
|
||||||
|
|
||||||
@ -18,37 +23,105 @@ class ProxyDaemon:
|
|||||||
client_sessions = attr.ib(init=False, default=attr.Factory(dict))
|
client_sessions = attr.ib(init=False, default=attr.Factory(dict))
|
||||||
default_session = attr.ib(init=False, default=None)
|
default_session = attr.ib(init=False, default=None)
|
||||||
|
|
||||||
|
def get_access_token(self, request):
|
||||||
|
# type: (aiohttp.BaseRequest) -> str
|
||||||
|
"""Extract the access token from the request.
|
||||||
|
|
||||||
|
This method extracts the access token either from the query string or
|
||||||
|
from the Authorization header of the request.
|
||||||
|
|
||||||
|
Returns the access token if it was found.
|
||||||
|
"""
|
||||||
|
access_token = request.query.get("access_token", "")
|
||||||
|
|
||||||
|
if not access_token:
|
||||||
|
access_token = request.headers.get(
|
||||||
|
"Authorization",
|
||||||
|
""
|
||||||
|
).strip("Bearer ")
|
||||||
|
|
||||||
|
return access_token
|
||||||
|
|
||||||
async def router(self, request):
|
async def router(self, request):
|
||||||
path = request.path
|
path = request.path
|
||||||
method = request.method
|
method = request.method
|
||||||
data = await request.text()
|
data = await request.text()
|
||||||
|
headers = request.headers
|
||||||
|
params = request.query
|
||||||
|
|
||||||
print(method, path, data)
|
print(method, path, data)
|
||||||
|
|
||||||
|
session = None
|
||||||
|
|
||||||
|
token = self.get_access_token(request)
|
||||||
|
client = self.client_sessions.get(token, None)
|
||||||
|
|
||||||
|
if client:
|
||||||
|
session = client.client_session
|
||||||
|
|
||||||
|
if not session:
|
||||||
if not self.default_session:
|
if not self.default_session:
|
||||||
self.default_session = ClientSession()
|
self.default_session = ClientSession()
|
||||||
|
session = self.default_session
|
||||||
|
|
||||||
async with self.default_session.request(
|
async with session.request(
|
||||||
method,
|
method,
|
||||||
HOMESERVER + path,
|
HOMESERVER + path,
|
||||||
data=data,
|
data=data,
|
||||||
|
params=params,
|
||||||
|
headers=headers,
|
||||||
proxy=self.proxy,
|
proxy=self.proxy,
|
||||||
ssl=False
|
ssl=False
|
||||||
) as resp:
|
) as resp:
|
||||||
|
print("Returning resp {}".format(resp))
|
||||||
return(web.Response(text=await resp.text()))
|
return(web.Response(text=await resp.text()))
|
||||||
|
|
||||||
async def login(self, request):
|
async def login(self, request):
|
||||||
json = await request.json()
|
try:
|
||||||
|
body = await request.json()
|
||||||
|
except JSONDecodeError:
|
||||||
|
# TODO what to do here, quaternion retries the login if we raise an
|
||||||
|
# exception here, throws an error if we send out an 400 and hangs
|
||||||
|
# if we forward it to the router() method.
|
||||||
|
print("JSON ERROR IN LOGIN")
|
||||||
|
raise
|
||||||
|
# return web.Response(
|
||||||
|
# status=400,
|
||||||
|
# text=json.dumps({
|
||||||
|
# "errcode": "M_NOT_JSON",
|
||||||
|
# "error": "Request did not contain valid JSON."
|
||||||
|
# })
|
||||||
|
# )
|
||||||
|
|
||||||
user = json.get("user", "")
|
print("Login request")
|
||||||
password = json.get("password", "")
|
print(body)
|
||||||
device_id = json.get("device_id", "")
|
|
||||||
device_name = json.get("initial_device_display_name", "")
|
identifier = body.get("identifier", None)
|
||||||
|
|
||||||
|
if identifier:
|
||||||
|
user = identifier.get("user", None)
|
||||||
|
|
||||||
|
if not user:
|
||||||
|
user = body.get("user", "")
|
||||||
|
else:
|
||||||
|
user = body.get("user", "")
|
||||||
|
|
||||||
|
password = body.get("password", "")
|
||||||
|
device_id = body.get("device_id", "")
|
||||||
|
device_name = body.get("initial_device_display_name", "")
|
||||||
|
|
||||||
|
store_path = user_data_dir("pantalaimon", "")
|
||||||
|
|
||||||
|
try:
|
||||||
|
os.makedirs(store_path)
|
||||||
|
except OSError:
|
||||||
|
pass
|
||||||
|
|
||||||
client = AsyncClient(
|
client = AsyncClient(
|
||||||
HOMESERVER,
|
HOMESERVER,
|
||||||
user,
|
user,
|
||||||
device_id,
|
device_id,
|
||||||
|
store_path=store_path,
|
||||||
ssl=self.ssl,
|
ssl=self.ssl,
|
||||||
proxy=self.proxy
|
proxy=self.proxy
|
||||||
)
|
)
|
||||||
@ -59,6 +132,9 @@ class ProxyDaemon:
|
|||||||
|
|
||||||
if isinstance(response, LoginResponse):
|
if isinstance(response, LoginResponse):
|
||||||
self.client_sessions[response.access_token] = client
|
self.client_sessions[response.access_token] = client
|
||||||
|
else:
|
||||||
|
# TODO close the client and its session.
|
||||||
|
pass
|
||||||
|
|
||||||
return web.Response(
|
return web.Response(
|
||||||
status=response.transport_response.status,
|
status=response.transport_response.status,
|
||||||
|
1
setup.py
1
setup.py
@ -15,6 +15,7 @@ setup(
|
|||||||
install_requires=[
|
install_requires=[
|
||||||
"attrs",
|
"attrs",
|
||||||
"aiohttp",
|
"aiohttp",
|
||||||
|
"appdirs",
|
||||||
"aiohttp-socks",
|
"aiohttp-socks",
|
||||||
"typing;python_version<'3.5'",
|
"typing;python_version<'3.5'",
|
||||||
"matrix-nio @ git+https://github.com/poljar/matrix-nio.git@master#egg=matrix-nio-0"
|
"matrix-nio @ git+https://github.com/poljar/matrix-nio.git@master#egg=matrix-nio-0"
|
||||||
|
Loading…
Reference in New Issue
Block a user