Handle invalid JSON in Revolut
This commit is contained in:
parent
04c20b6b69
commit
b6fe0b433d
|
@ -3,6 +3,7 @@ from twisted.logger import Logger
|
||||||
|
|
||||||
# Other library imports
|
# Other library imports
|
||||||
from json import dumps
|
from json import dumps
|
||||||
|
from json.decoder import JSONDecodeError
|
||||||
import requests
|
import requests
|
||||||
|
|
||||||
# Project imports
|
# Project imports
|
||||||
|
@ -16,23 +17,27 @@ class Revolut(object):
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.log = Logger("revolut")
|
self.log = Logger("revolut")
|
||||||
|
self.token = None
|
||||||
|
|
||||||
def get_new_token(self):
|
def get_new_token(self):
|
||||||
headers = {"Content-Type": "application/x-www-form-urlencoded"}
|
headers = {"Content-Type": "application/x-www-form-urlencoded"}
|
||||||
data = {
|
data = {
|
||||||
"grant_type": "refresh_token",
|
"grant_type": "refresh_token",
|
||||||
"refresh_token": settings.refresh_token,
|
"refresh_token": settings.Revolut.RefreshToken,
|
||||||
"client_id": settings.client_id,
|
"client_id": settings.Revolut.ClientID,
|
||||||
"client_assertion_type": "urn:ietf:params:oauth:client-assertion-type:jwt-bearer",
|
"client_assertion_type": "urn:ietf:params:oauth:client-assertion-type:jwt-bearer",
|
||||||
"client_assertion": settings.jwt,
|
"client_assertion": settings.Revolut.JWT,
|
||||||
}
|
}
|
||||||
r = requests.post(f"{settings.api_base}/auth/token", data=data, headers=headers)
|
r = requests.post(f"{settings.Revolut.Base}/auth/token", data=data, headers=headers)
|
||||||
parsed = r.json()
|
try:
|
||||||
|
parsed = r.json()
|
||||||
|
except JSONDecodeError:
|
||||||
|
return False
|
||||||
if r.status_code == 200:
|
if r.status_code == 200:
|
||||||
if "access_token" in parsed.keys():
|
if "access_token" in parsed.keys():
|
||||||
settings.access_token = parsed["access_token"]
|
self.token = parsed["access_token"]
|
||||||
if len(settings.access_token) == len(settings.refresh_token):
|
if len(self.token) == len(settings.Revolut.RefreshToken):
|
||||||
self.log.info("Refreshed access token: {access_token}", access_token=settings.access_token)
|
self.log.info("Refreshed access token: {access_token}", access_token=self.token)
|
||||||
return True
|
return True
|
||||||
else:
|
else:
|
||||||
self.log.error(f"Token refresh didn't contain access token: {parsed}", parsed=parsed)
|
self.log.error(f"Token refresh didn't contain access token: {parsed}", parsed=parsed)
|
||||||
|
@ -42,12 +47,12 @@ class Revolut(object):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def setup_webhook(self):
|
def setup_webhook(self):
|
||||||
self.log.info("Setting up webhook: {url}", url=settings.webhook_url)
|
self.log.info("Setting up webhook: {url}", url=settings.Revolut.WebhookURL)
|
||||||
headers = {"Authorization": f"Bearer {settings.access_token}"}
|
headers = {"Authorization": f"Bearer {self.token}"}
|
||||||
data = {"url": settings.webhook_url}
|
data = {"url": settings.Revolut.WebhookURL}
|
||||||
r = requests.post(f"{settings.api_base}/webhook", data=dumps(data), headers=headers)
|
r = requests.post(f"{settings.Revolut.Base}/webhook", data=dumps(data), headers=headers)
|
||||||
if r.status_code == 204:
|
if r.status_code == 204:
|
||||||
self.log.info("Set up webhook: {url}", url=settings.webhook_url)
|
self.log.info("Set up webhook: {url}", url=settings.Revolut.WebhookURL)
|
||||||
return dumps({"success": True})
|
return dumps({"success": True})
|
||||||
else:
|
else:
|
||||||
parsed = r.json()
|
parsed = r.json()
|
||||||
|
|
Loading…
Reference in New Issue