service/src/piracyshield_service/log/ticket/item/get_all.py
2024-01-19 15:32:27 +01:00

57 lines
1.5 KiB
Python

from __future__ import annotations
from piracyshield_service.base import BaseService
from piracyshield_component.exception import ApplicationException
from piracyshield_data_storage.log.ticket.item.storage import LogTicketItemStorage, LogTicketItemStorageGetException
from piracyshield_service.log.ticket.item.errors import LogTicketItemErrorCode, LogTicketItemErrorMessage
class LogTicketItemGetAllService(BaseService):
"""
Gets all the logs of a ticket item.
"""
data_storage = None
def __init__(self):
"""
Inizialize logger and required modules.
"""
super().__init__()
self._prepare_modules()
def execute(self, ticket_item_id: str) -> list | Exception:
try:
response = self.data_storage.get_all(
ticket_item_id = ticket_item_id
)
batch = response.batch()
if not len(batch):
self.logger.debug(f'Could not find any log for ticket item `{ticket_item_id}`')
return list(batch)
except LogTicketItemStorageGetException as e:
self.logger.error(f'Could not get all the logs for ticket item `{ticket_item_id}`')
raise ApplicationException(LogTicketItemErrorCode.GENERIC, LogTicketItemErrorMessage.GENERIC, e)
def _schedule_task(self):
pass
def _validate_parameters(self):
pass
def _prepare_configs(self):
pass
def _prepare_modules(self):
self.data_storage = LogTicketItemStorage()