koblog/bl-kernel/syslog.class.php

67 lines
1.6 KiB
PHP
Raw Normal View History

2017-05-19 00:45:14 +02:00
<?php defined('BLUDIT') or die('Bludit CMS.');
2018-08-03 18:59:23 +02:00
class Syslog extends dbJSON {
protected $dbFields = array(
2017-05-19 00:45:14 +02:00
'date'=> array('inFile'=>false, 'value'=>''),
'dictionaryKey'=> array('inFile'=>false, 'value'=>''),
'notes'=> array('inFile'=>false, 'value'=>''),
'username'=> array('inFile'=>false, 'value'=>''),
'idExecution'=> array('inFile'=>false, 'value'=>''),
'method'=> array('inFile'=>false, 'value'=>'')
);
function __construct()
{
parent::__construct(DB_SYSLOG);
}
2017-06-01 00:22:20 +02:00
// Returns TRUE if the ID of execution exists, FALSE otherwise
public function exists($idExecution)
{
2018-02-26 00:18:21 +01:00
foreach ($this->db as $field) {
if ($field['idExecution']==$idExecution) {
2017-06-01 00:22:20 +02:00
return true;
}
}
return false;
}
public function get($idExecution)
{
2018-02-26 00:18:21 +01:00
foreach ($this->db as $field) {
if ($field['idExecution']==$idExecution) {
2017-06-01 00:22:20 +02:00
return $field;
}
}
return false;
}
2017-05-19 00:45:14 +02:00
public function add($args)
{
global $L;
2017-05-19 00:45:14 +02:00
$data = array();
$data['date'] = Date::current(DB_DATE_FORMAT);
$data['dictionaryKey'] = $args['dictionaryKey'];
$data['notes'] = Sanitize::html($args['notes']);
2018-02-26 00:18:21 +01:00
// Unique ID for each execution, defined in boot/init.php
2017-05-19 00:45:14 +02:00
$data['idExecution'] = $GLOBALS['ID_EXECUTION'];
$data['method'] = $_SERVER['REQUEST_METHOD'];
// Username
$data['username'] = Session::get('username');
2018-02-26 00:18:21 +01:00
if (Text::isEmpty($data['username'])) {
2017-05-19 00:45:14 +02:00
return false;
}
2020-06-04 08:59:07 +02:00
// Insert at beginning of the database
2017-05-19 00:45:14 +02:00
array_unshift($this->db, $data);
// Keep just NOTIFICATIONS_AMOUNT notifications
$this->db = array_slice($this->db, 0, NOTIFICATIONS_AMOUNT);
2017-05-19 00:45:14 +02:00
// Save
return $this->save();
}
}