- new map change log to Slack channel - new "rally point" logging to Slack channel - new "rally point" poke options (e.g. custom message), closed #295 - new log options for WebSocket installations - added ship "mass" logging (backend only), #313 - added map logging to Slack, #326 - added "ESI error rate" limit detection - added "Monolog" as new logging library (Composer dependency) - added "Swiftmailer" as new eMail library (Composer dependency) - added Support for Redis session hander (performance boost) - improved character select panels (visible "online" status) - improved "activity logging" (more DB columns added to check) - improved eMail logging (HTML template support) - improved "delete map" now become "inactive" for some days before delete - improved character logout handling - improved /setup page for DB bootstrap (new button for DB create if not exists) - fixed broken ship tracking (ship name re-added) - fixed broken ship tracking for multiple chars on different browser tabs - fixed broken cursor coordinates, closed #518 - fixed null pointer "charactermodel.php->isActive():925" closed #529 - fixed broken "scroll offset", closed #533 closed #534 - Updated "validation" library JS v0.10.1 -> v0.11.9 - Updated ORM Mapper _Cortex_ v1.5.0-dev -> v1.5.0 - and many more....
166 lines
4.6 KiB
PHP
166 lines
4.6 KiB
PHP
<?php
|
|
/**
|
|
* Created by PhpStorm.
|
|
* User: exodu
|
|
* Date: 04.08.2017
|
|
* Time: 22:08
|
|
*/
|
|
|
|
namespace Lib\Logging;
|
|
|
|
|
|
use controller\LogController;
|
|
|
|
class MapLog extends AbstractCharacterLog{
|
|
|
|
/**
|
|
* List of possible handlers (tested)
|
|
* -> final handler will be set dynamic for per instance
|
|
* @var array
|
|
*/
|
|
protected $handlerConfig = [
|
|
//'stream' => 'json',
|
|
//'zmq' => 'json',
|
|
//'slackMap' => 'json'
|
|
];
|
|
|
|
/**
|
|
* @var string
|
|
*/
|
|
protected $channelType = 'map';
|
|
|
|
/**
|
|
* @var bool
|
|
*/
|
|
protected $logActivity = false;
|
|
|
|
|
|
public function __construct(string $action, array $objectData){
|
|
parent::__construct($action, $objectData);
|
|
|
|
$this->setLevel('info');
|
|
$this->setTag($this->getTagFromAction());
|
|
}
|
|
|
|
/**
|
|
* get log tag depending on log action
|
|
* @return string
|
|
*/
|
|
public function getTagFromAction(){
|
|
$tag = parent::getTag();
|
|
$actionParts = $this->getActionParts();
|
|
switch($actionParts[1]){
|
|
case 'create': $tag = 'success'; break;
|
|
case 'update': $tag = 'warning'; break;
|
|
case 'delete': $tag = 'danger'; break;
|
|
}
|
|
|
|
return $tag;
|
|
}
|
|
|
|
/**
|
|
* @return string
|
|
*/
|
|
public function getChannelName(): string{
|
|
return $this->getChannelType() . '_' . $this->getChannelId();
|
|
}
|
|
|
|
/**
|
|
* @return string
|
|
*/
|
|
public function getMessage() : string{
|
|
return $this->getActionParts()[0] . " '{objName}'";
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
public function getData() : array{
|
|
$data = parent::getData();
|
|
|
|
// add system, connection, signature data -------------------------------------------------
|
|
if(!empty($tempLogData = $this->getTempData())){
|
|
$objectData['object'] = $tempLogData;
|
|
$data = $objectData + $data;
|
|
}
|
|
|
|
// add human readable changes to string ---------------------------------------------------
|
|
$data['formatted'] = $this->formatData($data);
|
|
|
|
return $data;
|
|
}
|
|
|
|
/**
|
|
* @param array $data
|
|
* @return string
|
|
*/
|
|
protected function formatData(array $data): string{
|
|
$actionParts = $this->getActionParts();
|
|
$objectString = !empty($data['object']) ? "'" . $data['object']['objName'] . "'" . ' #' . $data['object']['objId'] : '';
|
|
$string = ucfirst($actionParts[1]) . 'd ' . $actionParts[0] . " " . $objectString;
|
|
|
|
// format changed columns (recursive) ---------------------------------------------
|
|
switch($actionParts[1]){
|
|
case 'create':
|
|
case 'update':
|
|
$formatChanges = function(array $changes) use ( &$formatChanges ): string{
|
|
$string = '';
|
|
foreach($changes as $field => $value){
|
|
if(is_array($value)){
|
|
$string .= $field . ": ";
|
|
$string .= $formatChanges($value);
|
|
$string .= next( $changes ) ? " , " : '';
|
|
}else{
|
|
if(is_numeric($value)){
|
|
$formattedValue = $value;
|
|
}elseif(is_null($value)){
|
|
$formattedValue = "NULL";
|
|
}elseif(empty($value)){
|
|
$formattedValue = "' '";
|
|
}elseif(is_string($value)){
|
|
$formattedValue = "'" . $value . "'";
|
|
}else{
|
|
$formattedValue = (string)$value;
|
|
}
|
|
|
|
$string .= $formattedValue;
|
|
if($field == 'old'){
|
|
$string .= " ➜ ";
|
|
}
|
|
}
|
|
}
|
|
return $string;
|
|
};
|
|
|
|
$string .= ' | ' . $formatChanges($data['main']);
|
|
break;
|
|
}
|
|
|
|
return $string;
|
|
}
|
|
|
|
/**
|
|
* split $action "CamelCase" wise
|
|
* @return array
|
|
*/
|
|
protected function getActionParts(): array{
|
|
return array_map('strtolower', preg_split('/(?=[A-Z])/', $this->getAction()));
|
|
}
|
|
|
|
/**
|
|
* @param bool $logActivity
|
|
*/
|
|
public function logActivity(bool $logActivity){
|
|
$this->logActivity = $logActivity;
|
|
}
|
|
|
|
public function buffer(){
|
|
parent::buffer();
|
|
|
|
if($this->logActivity){
|
|
// map logs should also used for "activity" logging
|
|
LogController::instance()->push($this);
|
|
}
|
|
}
|
|
|
|
} |