2016-12-29 01:55:00 +01:00
|
|
|
<?php
|
|
|
|
use RedBeanPHP\Facade as RedBean;
|
2017-04-21 05:34:20 +02:00
|
|
|
/**
|
|
|
|
* @api {OBJECT} Log Log
|
2022-01-04 17:24:06 +01:00
|
|
|
* @apiVersion 4.11.0
|
2017-04-21 05:34:20 +02:00
|
|
|
* @apiGroup Data Structures
|
|
|
|
* @apiParam {String} type The type of the log.
|
2017-05-11 21:37:03 +02:00
|
|
|
* @apiParam {String} to Object where the action was performed.
|
2017-04-21 05:34:20 +02:00
|
|
|
* @apiParam {Object} author Author of the log.
|
|
|
|
* @apiParam {String} author.name Name of the author.
|
|
|
|
* @apiParam {Number} author.id Id of the author.
|
2017-05-11 21:37:03 +02:00
|
|
|
* @apiParam {Boolean} author.staff Indicates if the author is a staff.
|
|
|
|
* @apiParam {String} date Date of the log creation.
|
2017-04-21 05:34:20 +02:00
|
|
|
*/
|
2016-12-29 01:55:00 +01:00
|
|
|
|
|
|
|
class Log extends DataStore {
|
|
|
|
const TABLE = 'log';
|
|
|
|
|
|
|
|
public static function getProps() {
|
|
|
|
return [
|
|
|
|
'type',
|
2016-12-29 06:04:35 +01:00
|
|
|
'authorUser',
|
2016-12-29 01:55:00 +01:00
|
|
|
'authorStaff',
|
2017-01-11 08:25:26 +01:00
|
|
|
'to',
|
2019-11-08 14:08:14 +01:00
|
|
|
'date',
|
|
|
|
'authorName'
|
2016-12-29 01:55:00 +01:00
|
|
|
];
|
|
|
|
}
|
2016-12-29 06:50:53 +01:00
|
|
|
|
2020-08-05 21:34:27 +02:00
|
|
|
public static function getFetchAs() {
|
|
|
|
return [
|
|
|
|
'authorUser' => 'user',
|
|
|
|
'authorStaff' => 'staff',
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2019-11-08 14:08:14 +01:00
|
|
|
public static function createLog($type, $to, $author = null) {
|
|
|
|
$session = Session::getInstance();
|
|
|
|
$authorName = '';
|
2019-11-08 14:41:50 +01:00
|
|
|
|
2019-11-08 14:08:14 +01:00
|
|
|
if($session->isTicketSession()) {
|
|
|
|
$ticketNumber = $session->getTicketNumber();
|
|
|
|
$ticket = Ticket::getByTicketNumber($ticketNumber);
|
|
|
|
$authorName = $ticket->authorToArray()['name'];
|
|
|
|
}
|
|
|
|
|
2016-12-29 01:55:00 +01:00
|
|
|
if($author === null) {
|
2019-07-05 01:22:38 +02:00
|
|
|
$author = Controller::getLoggedUser();
|
2019-11-08 14:57:25 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if(!$author->isNull()) {
|
|
|
|
$authorName = $author->name;
|
2019-07-05 01:22:38 +02:00
|
|
|
}
|
|
|
|
|
2017-01-05 20:26:43 +01:00
|
|
|
$log = new Log();
|
2016-12-29 01:55:00 +01:00
|
|
|
|
|
|
|
$log->setProperties(array(
|
|
|
|
'type' => $type,
|
2017-01-11 08:25:26 +01:00
|
|
|
'to' => $to,
|
2019-11-08 14:08:14 +01:00
|
|
|
'date' => Date::getCurrentDate(),
|
|
|
|
'authorName' => $authorName
|
2016-12-29 01:55:00 +01:00
|
|
|
));
|
2016-12-29 06:50:53 +01:00
|
|
|
|
|
|
|
if($author instanceof User) {
|
|
|
|
$log->authorUser = $author;
|
|
|
|
} else {
|
|
|
|
$log->authorStaff = $author;
|
|
|
|
}
|
|
|
|
|
2016-12-29 01:55:00 +01:00
|
|
|
$log->store();
|
|
|
|
}
|
2016-12-29 06:50:53 +01:00
|
|
|
|
2016-12-29 06:04:35 +01:00
|
|
|
public function toArray() {
|
2017-01-05 20:26:43 +01:00
|
|
|
$author = ($this->authorUser instanceof User) ? $this->authorUser : $this->authorStaff;
|
2019-08-22 21:17:45 +02:00
|
|
|
|
2016-12-29 06:04:35 +01:00
|
|
|
return [
|
|
|
|
'type' => $this->type,
|
|
|
|
'to' => $this->to,
|
2017-01-05 20:26:43 +01:00
|
|
|
'author' => [
|
2019-11-08 14:08:14 +01:00
|
|
|
'name' => $this->authorName,
|
2019-11-14 15:34:20 +01:00
|
|
|
'id' => ($author && !$author->isNull()) ? $author->id : null,
|
2017-01-05 20:26:43 +01:00
|
|
|
'staff' => $author instanceof Staff
|
2017-01-11 08:25:26 +01:00
|
|
|
],
|
2019-07-05 01:22:38 +02:00
|
|
|
'date' => $this->date
|
2016-12-29 06:04:35 +01:00
|
|
|
];
|
|
|
|
}
|
2019-07-05 01:22:38 +02:00
|
|
|
}
|