2016-05-15 00:08:30 +02:00
|
|
|
<?php
|
2017-04-20 05:55:38 +02:00
|
|
|
/**
|
|
|
|
* @api {OBJECT} Ticket Ticket
|
2017-06-28 15:02:54 +02:00
|
|
|
* @apiVersion 4.1.0
|
2017-04-20 05:55:38 +02:00
|
|
|
* @apiGroup Data Structures
|
2017-04-21 05:34:20 +02:00
|
|
|
* @apiParam {Number} ticketNumber The number of the ticket.
|
|
|
|
* @apiParam {String} title The title of the ticket.
|
|
|
|
* @apiParam {String} content The content of the ticket.
|
|
|
|
* @apiParam {Object} department The department of the ticket.
|
|
|
|
* @apiParam {Number} department.id The id of the department of the ticket.
|
|
|
|
* @apiParam {String} department.name The department's name of the ticket.
|
2017-05-11 21:37:03 +02:00
|
|
|
* @apiParam {String} file The filename of the ticket if attached.
|
2017-04-21 05:34:20 +02:00
|
|
|
* @apiParam {String} language The language of the ticket.
|
2017-05-11 21:37:03 +02:00
|
|
|
* @apiParam {Boolean} unread Indicates if the user has already read the last comment.
|
|
|
|
* @apiParam {Boolean} unreadStaff Indicates if the staff has already read the last comment.
|
|
|
|
* @apiParam {Boolean} closed Indicates if the ticket is closed.
|
|
|
|
* @apiParam {String} priority The priority of the ticket. It can be LOW, MEDIUM or HIGH.
|
2017-04-21 05:34:20 +02:00
|
|
|
* @apiParam {Object} author The author of the ticket.
|
|
|
|
* @apiParam {Number} author.id The id of the author of the ticket.
|
|
|
|
* @apiParam {String} author.name The author's name of the ticket.
|
|
|
|
* @apiParam {String} author.email The author's email of the ticket.
|
|
|
|
* @apiParam {Object} owner The owner of the ticket.
|
|
|
|
* @apiParam {Number} owner.id The owner's id of the ticket.
|
|
|
|
* @apiParam {String} owner.name The owner's name of the ticket.
|
|
|
|
* @apiParam {String} owner.email The owner's email of the ticket.
|
2017-04-20 07:23:30 +02:00
|
|
|
* @apiParam {[TicketEvent](#api-Data_Structures-ObjectTicketevent)[]} events Events related to the ticket.
|
2017-04-20 05:55:38 +02:00
|
|
|
*/
|
2016-07-04 02:32:34 +02:00
|
|
|
use RedBeanPHP\Facade as RedBean;
|
2016-05-15 00:08:30 +02:00
|
|
|
|
|
|
|
class Ticket extends DataStore {
|
2016-07-04 02:32:34 +02:00
|
|
|
const TABLE = 'ticket';
|
2016-05-15 00:08:30 +02:00
|
|
|
|
|
|
|
public static function getProps() {
|
|
|
|
return array(
|
2016-07-04 02:32:34 +02:00
|
|
|
'ticketNumber',
|
2016-05-15 00:08:30 +02:00
|
|
|
'title',
|
|
|
|
'content',
|
|
|
|
'language',
|
|
|
|
'department',
|
|
|
|
'file',
|
|
|
|
'date',
|
|
|
|
'unread',
|
|
|
|
'closed',
|
2016-09-29 22:09:34 +02:00
|
|
|
'priority',
|
2016-05-15 00:08:30 +02:00
|
|
|
'author',
|
|
|
|
'owner',
|
2016-10-21 06:08:06 +02:00
|
|
|
'ownTicketeventList',
|
2016-12-21 05:09:35 +01:00
|
|
|
'unreadStaff',
|
2017-01-16 20:07:53 +01:00
|
|
|
'language',
|
|
|
|
'authorEmail',
|
|
|
|
'authorName'
|
2016-05-15 00:08:30 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2016-06-30 23:03:17 +02:00
|
|
|
public static function getTicket($value, $property = 'id') {
|
|
|
|
return parent::getDataStore($value, $property);
|
|
|
|
}
|
2017-03-04 06:57:51 +01:00
|
|
|
|
2016-09-04 02:46:08 +02:00
|
|
|
public static function getByTicketNumber($value) {
|
|
|
|
return Ticket::getTicket($value, 'ticketNumber');
|
|
|
|
}
|
2016-08-21 02:16:07 +02:00
|
|
|
|
2016-07-04 02:32:34 +02:00
|
|
|
public function getDefaultProps() {
|
2016-07-06 01:40:30 +02:00
|
|
|
return array(
|
2016-09-29 22:09:34 +02:00
|
|
|
'priority' => 'low',
|
2016-10-21 21:38:08 +02:00
|
|
|
'unread' => false,
|
|
|
|
'unreadStaff' => true,
|
2016-08-17 04:49:40 +02:00
|
|
|
'ticketNumber' => $this->generateUniqueTicketNumber()
|
2016-07-06 01:40:30 +02:00
|
|
|
);
|
2016-05-15 00:08:30 +02:00
|
|
|
}
|
2016-08-21 02:16:07 +02:00
|
|
|
|
2016-07-06 01:40:30 +02:00
|
|
|
public function store() {
|
|
|
|
parent::store();
|
|
|
|
}
|
2016-09-29 19:34:20 +02:00
|
|
|
|
2016-08-17 04:49:40 +02:00
|
|
|
public function generateUniqueTicketNumber() {
|
2017-01-12 20:45:01 +01:00
|
|
|
$linearCongruentialGenerator = new LinearCongruentialGenerator();
|
2016-11-04 23:10:32 +01:00
|
|
|
$ticketQuantity = Ticket::count();
|
2017-03-04 06:57:51 +01:00
|
|
|
|
2016-08-17 04:49:40 +02:00
|
|
|
if ($ticketQuantity === 0) {
|
2017-11-30 22:06:09 +01:00
|
|
|
$ticketNumber = Setting::getSetting('ticket-first-number');
|
2016-08-17 04:49:40 +02:00
|
|
|
} else {
|
2017-01-12 20:45:01 +01:00
|
|
|
$linearCongruentialGenerator->setGap(Setting::getSetting('ticket-gap')->value);
|
2017-11-30 22:06:09 +01:00
|
|
|
$linearCongruentialGenerator->setFirst(Setting::getSetting('ticket-first-number')->value);
|
2017-03-04 06:57:51 +01:00
|
|
|
|
2017-01-12 20:45:01 +01:00
|
|
|
$ticketNumber = $linearCongruentialGenerator->generate($ticketQuantity);
|
2016-08-17 04:49:40 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return $ticketNumber;
|
|
|
|
}
|
2017-03-04 06:57:51 +01:00
|
|
|
|
2016-09-04 02:46:08 +02:00
|
|
|
public function toArray() {
|
|
|
|
return [
|
|
|
|
'ticketNumber' => $this->ticketNumber,
|
|
|
|
'title' => $this->title,
|
|
|
|
'content' => $this->content,
|
|
|
|
'department' => [
|
|
|
|
'id' => $this->department->id,
|
|
|
|
'name' => $this->department->name
|
|
|
|
],
|
|
|
|
'date' => $this->date,
|
|
|
|
'file' => $this->file,
|
|
|
|
'language' => $this->language,
|
|
|
|
'unread' => !!$this->unread,
|
2016-11-21 03:01:38 +01:00
|
|
|
'unreadStaff' => !!$this->unreadStaff,
|
2016-09-04 02:46:08 +02:00
|
|
|
'closed' => !!$this->closed,
|
2016-09-29 22:09:34 +02:00
|
|
|
'priority' => $this->priority,
|
2016-09-04 02:46:08 +02:00
|
|
|
'author' => $this->authorToArray(),
|
|
|
|
'owner' => $this->ownerToArray(),
|
2017-03-04 01:39:59 +01:00
|
|
|
'events' => $this->eventsToArray()
|
2016-09-04 02:46:08 +02:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
public function authorToArray() {
|
|
|
|
$author = $this->author;
|
|
|
|
|
|
|
|
if ($author && !$author->isNull()) {
|
|
|
|
return [
|
|
|
|
'id' => $author->id,
|
|
|
|
'name' => $author->name,
|
|
|
|
'email' => $author->email
|
|
|
|
];
|
|
|
|
} else {
|
2017-03-04 01:39:59 +01:00
|
|
|
return [
|
|
|
|
'name' => $this->authorName,
|
|
|
|
'email' => $this->authorEmail
|
|
|
|
];
|
2016-09-04 02:46:08 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function ownerToArray() {
|
|
|
|
$owner = $this->owner;
|
|
|
|
|
|
|
|
if ($owner && !$owner->isNull()) {
|
|
|
|
return [
|
|
|
|
'id' => $owner->id,
|
|
|
|
'name' => $owner->name,
|
|
|
|
'email' => $owner->email
|
|
|
|
];
|
|
|
|
} else {
|
2016-11-21 03:01:38 +01:00
|
|
|
return null;
|
2016-09-04 02:46:08 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-09-29 19:34:20 +02:00
|
|
|
public function eventsToArray() {
|
|
|
|
$events = [];
|
|
|
|
|
|
|
|
foreach ($this->ownTicketeventList as $ticketEvent) {
|
|
|
|
$event = [
|
|
|
|
'type' => $ticketEvent->type,
|
|
|
|
'content'=> $ticketEvent->content,
|
|
|
|
'author' => [],
|
|
|
|
'date'=> $ticketEvent->date,
|
|
|
|
'file'=> $ticketEvent->file
|
2016-09-04 02:46:08 +02:00
|
|
|
];
|
2016-09-29 19:34:20 +02:00
|
|
|
|
|
|
|
$author = $ticketEvent->getAuthor();
|
|
|
|
if(!$author->isNull()) {
|
|
|
|
$event['author'] = [
|
|
|
|
'id'=> $author->id,
|
|
|
|
'name' => $author->name,
|
|
|
|
'email' =>$author->email,
|
2016-11-21 03:01:38 +01:00
|
|
|
'profilePic' => ($author instanceof Staff) ? $author->profilePic : null,
|
2016-09-29 19:34:20 +02:00
|
|
|
'staff' => $author instanceof Staff
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
$events[] = $event;
|
2016-09-04 02:46:08 +02:00
|
|
|
}
|
|
|
|
|
2016-09-29 19:34:20 +02:00
|
|
|
return $events;
|
2016-09-04 02:46:08 +02:00
|
|
|
}
|
2017-03-04 06:57:51 +01:00
|
|
|
|
2016-09-29 19:46:31 +02:00
|
|
|
public function addEvent(Ticketevent $event) {
|
|
|
|
$this->ownTicketeventList->add($event);
|
|
|
|
}
|
2016-08-21 02:16:07 +02:00
|
|
|
}
|