winter/modules/system/models/RequestLog.php

66 lines
1.4 KiB
PHP
Raw Normal View History

<?php namespace System\Models;
2016-04-16 07:44:18 +10:00
use App;
use Model;
use Request;
/**
* Model for logging 404 errors
2014-10-03 18:00:21 +10:00
*
* @package october\system
* @author Alexey Bobkov, Samuel Georges
*/
class RequestLog extends Model
{
/**
* @var string The database table used by the model.
*/
protected $table = 'system_request_logs';
/**
* @var array The attributes that aren't mass assignable.
*/
protected $guarded = [];
/**
* @var array List of attribute names which are json encoded and decoded from the database.
*/
protected $jsonable = ['referer'];
/**
* Creates a log record
* @return self
*/
2014-07-30 17:33:26 +10:00
public static function add($statusCode = 404)
{
2016-04-16 07:44:18 +10:00
if (!App::hasDatabase()) {
return;
}
2015-03-14 15:07:57 +11:00
if (!LogSetting::get('log_requests')) {
return;
}
$record = static::firstOrNew([
'url' => substr(Request::fullUrl(), 0, 191),
2014-07-30 17:33:26 +10:00
'status_code' => $statusCode,
]);
if ($referer = Request::header('referer')) {
$referers = (array) $record->referer ?: [];
$referers[] = $referer;
$record->referer = $referers;
}
if (!$record->exists) {
$record->count = 1;
$record->save();
}
else {
$record->increment('count');
}
return $record;
}
2014-10-18 11:58:50 +02:00
}