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)