api/v1/handlers/ticket/item/set_flag_active.py
2024-01-15 13:32:24 +01:00

96 lines
2.9 KiB
Python

import sys
import os
# I hate python imports
current = os.path.dirname(os.path.realpath(__file__))
parent = os.path.dirname(current)
sys.path.append(parent)
import tornado
from ioutils.protected import ProtectedHandler
from ioutils.errors import ErrorCode, ErrorMessage
from piracyshield_service.ticket.item.set_flag_active import TicketItemSetFlagActiveService
from piracyshield_data_model.account.role.model import AccountRoleModel
from piracyshield_component.exception import ApplicationException
class SetFlagActiveTicketItemHandler(ProtectedHandler):
"""
Handles setting the activity that can be done on a single ticket item.
"""
required_fields = [
'value'
]
async def post(self):
if self.initialize_account() == False:
return
if self.handle_post(self.required_fields) == False:
return
try:
self.permission_service.can_edit_ticket()
if self.account_data.get('role') == AccountRoleModel.INTERNAL.value:
ticket_item_set_flag_active_service = TicketItemSetFlagActiveService()
await tornado.ioloop.IOLoop.current().run_in_executor(
None,
ticket_item_set_flag_active_service.execute,
self.account_data.get('account_id'),
self.request_data.get('value'),
True
)
self.success()
else:
self.error(status_code = 403, error_code = ErrorCode.PERMISSION_DENIED, message = ErrorMessage.PERMISSION_DENIED)
except ApplicationException as e:
self.error(status_code = 400, error_code = e.code, message = e.message)
class SetFlagNonActiveTicketItemHandler(ProtectedHandler):
"""
Handles setting the activity that can be done on a single ticket item.
"""
required_fields = [
'value'
]
async def post(self):
if self.initialize_account() == False:
return
if self.handle_post(self.required_fields) == False:
return
try:
self.permission_service.can_edit_ticket()
if self.account_data.get('role') == AccountRoleModel.INTERNAL.value:
ticket_item_set_flag_active_service = TicketItemSetFlagActiveService()
await tornado.ioloop.IOLoop.current().run_in_executor(
None,
ticket_item_set_flag_active_service.execute,
self.account_data.get('account_id'),
self.request_data.get('value'),
False
)
self.success()
else:
self.error(status_code = 403, error_code = ErrorCode.PERMISSION_DENIED, message = ErrorMessage.PERMISSION_DENIED)
except ApplicationException as e:
self.error(status_code = 400, error_code = e.code, message = e.message)