mirror of
https://github.com/Andre0512/pyhOn.git
synced 2025-01-03 08:35:31 +00:00
Get new token via refresh-token #10
This commit is contained in:
parent
8fa01343bc
commit
eb6741145a
|
@ -1,3 +1,4 @@
|
||||||
|
import datetime
|
||||||
import json
|
import json
|
||||||
import logging
|
import logging
|
||||||
import re
|
import re
|
||||||
|
@ -146,7 +147,7 @@ class HonAuth:
|
||||||
if not await self._get_token(url):
|
if not await self._get_token(url):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
post_headers = {"Content-Type": "application/json", "id-token": self._id_token}
|
post_headers = {"id-token": self._id_token}
|
||||||
data = self._device.get()
|
data = self._device.get()
|
||||||
async with self._session.post(f"{const.API_URL}/auth/v1/login", headers=post_headers, json=data) as resp:
|
async with self._session.post(f"{const.API_URL}/auth/v1/login", headers=post_headers, json=data) as resp:
|
||||||
try:
|
try:
|
||||||
|
@ -156,3 +157,18 @@ class HonAuth:
|
||||||
return False
|
return False
|
||||||
self._cognito_token = json_data["cognitoUser"]["Token"]
|
self._cognito_token = json_data["cognitoUser"]["Token"]
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
async def refresh(self):
|
||||||
|
params = {
|
||||||
|
"client_id": const.CLIENT_ID,
|
||||||
|
"refresh_token": self._refresh_token,
|
||||||
|
"grant_type": "refresh_token"
|
||||||
|
}
|
||||||
|
async with self._session.post(f"{const.AUTH_API}/services/oauth2/token", params=params) as resp:
|
||||||
|
if resp.status >= 400:
|
||||||
|
return False
|
||||||
|
data = await resp.json()
|
||||||
|
self._id_token = data["id_token"]
|
||||||
|
self._access_token = data["access_token"]
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -66,23 +66,31 @@ class HonConnectionHandler(HonBaseConnectionHandler):
|
||||||
return {h: v for h, v in self._request_headers.items() if h not in headers}
|
return {h: v for h, v in self._request_headers.items() if h not in headers}
|
||||||
|
|
||||||
@asynccontextmanager
|
@asynccontextmanager
|
||||||
async def get(self, *args, loop=0, **kwargs):
|
async def _intercept(self, method, *args, loop=0, **kwargs):
|
||||||
kwargs["headers"] = await self._check_headers(kwargs.get("headers", {}))
|
kwargs["headers"] = await self._check_headers(kwargs.get("headers", {}))
|
||||||
async with self._session.get(*args, **kwargs) as response:
|
async with method(*args, **kwargs) as response:
|
||||||
if response.status == 403 and not loop:
|
if response.status == 403 and not loop:
|
||||||
|
_LOGGER.info("Try refreshing token...")
|
||||||
|
await self._auth.refresh()
|
||||||
|
yield await self._intercept(method, *args, loop=loop + 1, **kwargs)
|
||||||
|
elif response.status == 403 and loop < 2:
|
||||||
_LOGGER.warning("%s - Error %s - %s", response.request_info.url, response.status, await response.text())
|
_LOGGER.warning("%s - Error %s - %s", response.request_info.url, response.status, await response.text())
|
||||||
await self.create()
|
await self.create()
|
||||||
yield await self.get(*args, loop=loop + 1, **kwargs)
|
yield await self._intercept(method, *args, loop=loop + 1, **kwargs)
|
||||||
elif loop >= 2:
|
elif loop >= 2:
|
||||||
_LOGGER.error("%s - Error %s - %s", response.request_info.url, response.status, await response.text())
|
_LOGGER.error("%s - Error %s - %s", response.request_info.url, response.status, await response.text())
|
||||||
raise PermissionError()
|
raise PermissionError("Login failure")
|
||||||
else:
|
else:
|
||||||
yield response
|
yield response
|
||||||
|
|
||||||
|
@asynccontextmanager
|
||||||
|
async def get(self, *args, **kwargs):
|
||||||
|
async with self._intercept(self._session.get, *args, **kwargs) as response:
|
||||||
|
yield response
|
||||||
|
|
||||||
@asynccontextmanager
|
@asynccontextmanager
|
||||||
async def post(self, *args, **kwargs):
|
async def post(self, *args, **kwargs):
|
||||||
kwargs["headers"] = await self._check_headers(kwargs.get("headers", {}))
|
async with self._intercept(self._session.post, *args, **kwargs) as response:
|
||||||
async with self._session.post(*args, **kwargs) as response:
|
|
||||||
yield response
|
yield response
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue