mirror of
https://github.com/fuckpiracyshield/service.git
synced 2024-05-20 05:56:17 +02:00
66 lines
1.9 KiB
Python
66 lines
1.9 KiB
Python
from __future__ import annotations
|
|
|
|
from piracyshield_service.base import BaseService
|
|
|
|
from piracyshield_component.config import Config
|
|
from piracyshield_component.exception import ApplicationException
|
|
from piracyshield_component.security.token import JWTToken, JWTTokenGenericException
|
|
|
|
from piracyshield_service.authentication.errors import AuthenticationErrorCode, AuthenticationErrorMessage
|
|
|
|
class AuthenticationGenerateRefreshTokenService(BaseService):
|
|
|
|
"""
|
|
Generates a refresh token.
|
|
"""
|
|
|
|
token = None
|
|
|
|
jwt_config = None
|
|
|
|
def __init__(self):
|
|
"""
|
|
Inizialize logger and required modules.
|
|
"""
|
|
|
|
super().__init__()
|
|
|
|
self._prepare_configs()
|
|
|
|
self._prepare_modules()
|
|
|
|
def execute(self, payload: dict) -> str | Exception:
|
|
try:
|
|
return self.token.generate_refresh_token(payload)
|
|
|
|
except JWTTokenGenericException as e:
|
|
self.logger.error(f'Cannot generate a refresh token for payload `{payload}`')
|
|
|
|
raise ApplicationException(AuthenticationErrorCode.GENERIC, AuthenticationErrorMessage.GENERIC, e)
|
|
|
|
def _schedule_task(self):
|
|
pass
|
|
|
|
def _validate_parameters(self, email: str, password: str) -> dict | Exception:
|
|
pass
|
|
|
|
def _prepare_configs(self) -> None:
|
|
"""
|
|
Loads the configs.
|
|
"""
|
|
|
|
self.jwt_config = Config('security/token').get('jwt_token')
|
|
|
|
def _prepare_modules(self) -> None:
|
|
"""
|
|
Initialize and set the instances.
|
|
"""
|
|
|
|
self.token = JWTToken(
|
|
access_secret_key = self.jwt_config.get('access_secret_key'),
|
|
refresh_secret_key = self.jwt_config.get('refresh_secret_key'),
|
|
access_expiration_time = self.jwt_config.get('access_expiration_time'),
|
|
refresh_expiration_time = self.jwt_config.get('refresh_expiration_time'),
|
|
algorithm = self.jwt_config.get('algorithm')
|
|
)
|