Initial commit of AthonetTools
This commit is contained in:
54
services/combocore/client.py
Normal file
54
services/combocore/client.py
Normal file
@@ -0,0 +1,54 @@
|
||||
from __future__ import annotations
|
||||
import requests
|
||||
from requests.adapters import HTTPAdapter
|
||||
from urllib3.util.retry import Retry
|
||||
|
||||
DEFAULT_TIMEOUT = 10.0
|
||||
|
||||
class ComboCoreClient:
|
||||
def __init__(self, host: str, username: str, password: str, verify_ssl: bool = False, timeout: float = DEFAULT_TIMEOUT):
|
||||
self.base = f"https://{host}"
|
||||
self.username = username
|
||||
self.password = password
|
||||
self.verify = verify_ssl
|
||||
self.timeout = timeout
|
||||
self._token = None
|
||||
self._s = requests.Session()
|
||||
retry = Retry(total=3, backoff_factor=0.3, status_forcelist=[429,500,502,503,504])
|
||||
self._s.mount("https://", HTTPAdapter(max_retries=retry))
|
||||
self._s.mount("http://", HTTPAdapter(max_retries=retry))
|
||||
|
||||
# ----- PLS auth -----
|
||||
def login(self) -> str:
|
||||
r = self._s.post(
|
||||
f"{self.base}/core/pls/api/1/auth/login",
|
||||
json={"username": self.username, "password": self.password},
|
||||
timeout=self.timeout, verify=self.verify
|
||||
)
|
||||
r.raise_for_status()
|
||||
j = r.json()
|
||||
self._token = j.get("access_token") or j.get("token")
|
||||
if not self._token:
|
||||
raise RuntimeError("No access token in login response.")
|
||||
return self._token
|
||||
|
||||
def _auth_headers(self):
|
||||
if not self._token:
|
||||
self.login()
|
||||
return {"Authorization": f"Bearer {self._token}"}
|
||||
|
||||
def get(self, path: str):
|
||||
r = self._s.get(f"{self.base}{path}", headers=self._auth_headers(), timeout=self.timeout, verify=self.verify)
|
||||
if r.status_code == 401:
|
||||
self._token = None
|
||||
r = self._s.get(f"{self.base}{path}", headers=self._auth_headers(), timeout=self.timeout, verify=self.verify)
|
||||
r.raise_for_status()
|
||||
return r.json()
|
||||
|
||||
def post(self, path: str, json=None):
|
||||
r = self._s.post(f"{self.base}{path}", headers=self._auth_headers(), json=json or {}, timeout=self.timeout, verify=self.verify)
|
||||
if r.status_code == 401:
|
||||
self._token = None
|
||||
r = self._s.post(f"{self.base}{path}", headers=self._auth_headers(), json=json or {}, timeout=self.timeout, verify=self.verify)
|
||||
r.raise_for_status()
|
||||
return r.json()
|
||||
Reference in New Issue
Block a user