team-9/backend/auth/session.py

98 lines
3 KiB
Python
Raw Normal View History

2025-08-02 02:59:23 +02:00
import base64
import datetime
import os
import requests
SPOTIFY_CLIENT_ID = os.getenv("SPOTIFY_CLIENT_ID")
SPOTIFY_CLIENT_SECRET = os.getenv("SPOTIFY_CLIENT_SECRET")
class SessionData():
__access_token: str
__refresh_token: str
__expires_in: int
__creation_date: datetime.datetime
2025-08-02 04:23:49 +02:00
def __init__(self, __access_token, __refresh_token, __expires_in, __creation_date = None):
2025-08-02 02:59:23 +02:00
self.__access_token = __access_token
self.__refresh_token = __refresh_token
self.__expires_in = __expires_in
2025-08-02 04:23:49 +02:00
self.__creation_date = __creation_date or datetime.datetime.now()
2025-08-02 02:59:23 +02:00
def nearly_expired(self, before=30):
2025-08-02 05:31:20 +02:00
delta_time = datetime.datetime.now() - self.__creation_date
return delta_time.seconds > self.__expires_in - before
2025-08-02 02:59:23 +02:00
def is_expired(self):
return self.nearly_expired(0)
def refresh(self):
token_url = "https://accounts.spotify.com/api/token"
headers = {
"Authorization": "Basic " + base64.encode(SPOTIFY_CLIENT_ID + ":" + SPOTIFY_CLIENT_SECRET),
"Content-Type": "application/json"
}
data = {
"refresh_token": self.__refresh_token,
"grant_type": "refresh_token"
}
try:
response = requests.post(token_url, json=data, headers=headers)
response.raise_for_status()
result = response.json()
# Assumendo che la risposta contenga questi campi
self.__access_token = result["access_token"]
self.__refresh_token = result.get("refresh_token", self.__refresh_token)
self.__expires_in = result["expires_in"]
self.__creation_date = datetime.datetime.now()
except requests.exceptions.RequestException as e:
print(f"Errore durante il refresh del token: {e}")
2025-08-02 05:04:53 +02:00
raise e
2025-08-02 02:59:23 +02:00
@property
def access_tokens(self):
2025-08-02 05:04:53 +02:00
if self.nearly_expired():
self.refresh()
2025-08-02 02:59:23 +02:00
return self.__access_token
2025-08-02 07:04:38 +02:00
def __eq__(self, other):
if not isinstance(other, SessionData):
return False
return (self.__access_token == other.__access_token and
self.__refresh_token == other.__refresh_token and
self.__expires_in == other.__expires_in)
2025-08-02 02:59:23 +02:00
2025-08-02 04:08:11 +02:00
class SessionManager():
__current_session: SessionData
__instance: "SessionManager" = None
2025-08-02 04:08:11 +02:00
def __new__(cls, *args, **kwargs):
if cls.__instance is None:
cls.__instance = super(SessionManager, cls).__new__(cls)
return cls.__instance
def __init__(self):
self.__current_session = None
@classmethod
def instance(cls):
2025-08-02 04:21:13 +02:00
if cls.__instance is None:
cls.__instance = SessionManager()
2025-08-02 04:08:11 +02:00
return cls.__instance
def set_session(self, __current_session):
if self.__current_session is not None:
return
self.__current_session = __current_session
def get_current_session(self):
return self.__current_session