Files
pathfinder/app/main/lib/logging/RallyLog.php
Exodus4D a8edf39697 - new "logging" system for map/system/signature/connection changes, closed #271
- 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....
2017-10-22 17:58:34 +02:00

105 lines
2.6 KiB
PHP

<?php
/**
* Created by PhpStorm.
* User: exodu
* Date: 22.09.2017
* Time: 16:50
*/
namespace Lib\Logging;
use lib\Config;
class RallyLog extends AbstractCharacterLog{
/**
* List of possible handlers (tested)
* -> final handler will be set dynamic for per instance
* @var array
*/
protected $handlerConfig = [
// 'slackRally' => 'json',
// 'mail' => 'html'
];
/**
* @var string
*/
protected $channelType = 'rally';
public function __construct(string $action, array $objectData){
parent::__construct($action, $objectData);
$this->setLevel('notice');
$this->setTag('information');
}
/**
* @return string
*/
protected function getThumbUrl() : string{
$url = '';
if(is_object($character = $this->getCharacter())){
$characterLog = $character->getLog();
if($characterLog && !empty($characterLog->shipTypeId)){
$url = Config::getPathfinderData('api.ccp_image_server') . '/Render/' . $characterLog->shipTypeId . '_64.png';
}else{
$url = parent::getThumbUrl();
}
}
return $url;
}
/**
* @return string
*/
public function getMessage() : string{
return "*New RallyPoint system '{objName}'* _#{objId}_ *map '{channelName}'* _#{channelId}_ ";
}
/**
* @return array
*/
public function getData() : array{
$data = parent::getData();
// add system -----------------------------------------------------------------------------
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{
$string = '';
if(
!empty($data['object']) &&
!empty($data['channel'])
){
$replace = [
'{objName}' => $data['object']['objName'],
'{objId}' => $data['object']['objId'],
'{channelName}' => $data['channel']['channelName'],
'{channelId}' => $data['channel']['channelId']
];
$string = str_replace(array_keys($replace), array_values($replace), $this->getMessage());
}
return $string;
}
}