mirror of
				https://github.com/opensupports/opensupports.git
				synced 2025-10-31 03:24:38 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			82 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
| <?php
 | |
| use Respect\Validation\Validator as DataValidator;
 | |
| DataValidator::with('CustomValidations', true);
 | |
| 
 | |
| /**
 | |
|  * @api {post} /staff/un-assign-ticket Un-assign ticket
 | |
|  * @apiVersion 4.8.0
 | |
|  *
 | |
|  * @apiName Un-assign ticket
 | |
|  *
 | |
|  * @apiGroup Staff
 | |
|  *
 | |
|  * @apiDescription This path un-assigns a ticket to the current staff member.
 | |
|  *
 | |
|  * @apiPermission staff1
 | |
|  *
 | |
|  * @apiParam {Number} ticketNumber Ticket number to un-assign.
 | |
|  *
 | |
|  * @apiUse NO_PERMISSION
 | |
|  * @apiUse INVALID_TICKET
 | |
|  *
 | |
|  * @apiSuccess {Object} data Empty object
 | |
|  *
 | |
|  */
 | |
| 
 | |
| class UnAssignStaffController extends Controller {
 | |
|     const PATH = '/un-assign-ticket';
 | |
|     const METHOD = 'POST';
 | |
| 
 | |
|     private $user;
 | |
| 
 | |
|     public function __construct($user=null) {
 | |
|         $this->user = $user;
 | |
|     }
 | |
| 
 | |
|     public function validations() {
 | |
|         return [
 | |
|             'permission' => 'staff_1',
 | |
|             'requestData' => [
 | |
|                 'ticketNumber' => [
 | |
|                     'validation' => DataValidator::validTicketNumber(),
 | |
|                     'error' => ERRORS::INVALID_TICKET
 | |
|                 ]
 | |
|             ]
 | |
|         ];
 | |
|     }
 | |
| 
 | |
|     public function handler() {
 | |
|         $ticketNumber = Controller::request('ticketNumber');
 | |
|         $user = ($this->user? $this->user : Controller::getLoggedUser());
 | |
|         $ticket = Ticket::getByTicketNumber($ticketNumber);
 | |
|         $owner = $ticket->owner;
 | |
| 
 | |
|         if(!$user->canManageTicket($ticket)) {
 | |
|             throw new RequestException(ERRORS::NO_PERMISSION);
 | |
|         }
 | |
| 
 | |
|         if($owner) {
 | |
|             if(!$ticket->isAuthor($owner)) {
 | |
|                 $owner->sharedTicketList->remove($ticket);
 | |
|                 $owner->store();
 | |
|             }
 | |
| 
 | |
|             $ticket->owner = null;
 | |
|             $ticket->unread = !$ticket->isAuthor($user);
 | |
| 
 | |
|             $event = Ticketevent::getEvent(Ticketevent::UN_ASSIGN);
 | |
|             $event->setProperties(array(
 | |
|                 'authorStaff' => $user,
 | |
|                 'date' => Date::getCurrentDate(),
 | |
|                 'content' => $owner->name
 | |
|             ));
 | |
| 
 | |
|             $ticket->addEvent($event);
 | |
|             $ticket->store();
 | |
|             Response::respondSuccess();
 | |
|         } else {
 | |
|             throw new RequestException(ERRORS::NO_PERMISSION);
 | |
|         }
 | |
|     }
 | |
| }
 |