mirror of
https://github.com/fuckpiracyshield/api.git
synced 2025-01-09 21:25:35 +01:00
97 lines
2.9 KiB
Python
97 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)
|