2014-07-30 17:18:59 +10:00
|
|
|
<?php namespace System\Models;
|
2014-07-29 20:07:20 +10:00
|
|
|
|
|
|
|
use Model;
|
|
|
|
use Request;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Model for logging 404 errors
|
|
|
|
*/
|
2014-07-30 17:18:59 +10:00
|
|
|
class RequestLog extends Model
|
2014-07-29 20:07:20 +10:00
|
|
|
{
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var string The database table used by the model.
|
|
|
|
*/
|
2014-07-30 17:18:59 +10:00
|
|
|
protected $table = 'system_request_logs';
|
2014-07-29 20:07:20 +10:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var array The attributes that aren't mass assignable.
|
|
|
|
*/
|
|
|
|
protected $guarded = [];
|
|
|
|
|
2014-07-30 18:24:16 +10:00
|
|
|
/**
|
|
|
|
* @var array List of attribute names which are json encoded and decoded from the database.
|
|
|
|
*/
|
|
|
|
protected $jsonable = ['referer'];
|
|
|
|
|
2014-07-29 20:07:20 +10:00
|
|
|
/**
|
|
|
|
* Creates a log record
|
|
|
|
* @return self
|
|
|
|
*/
|
2014-07-30 17:33:26 +10:00
|
|
|
public static function add($statusCode = 404)
|
2014-07-29 20:07:20 +10:00
|
|
|
{
|
|
|
|
$record = static::firstOrNew([
|
|
|
|
'url' => Request::fullUrl(),
|
2014-07-30 17:33:26 +10:00
|
|
|
'status_code' => $statusCode,
|
2014-07-29 20:07:20 +10:00
|
|
|
]);
|
|
|
|
|
2014-07-30 18:24:16 +10:00
|
|
|
if ($referer = Request::header('referer')) {
|
|
|
|
$referers = (array) $record->referer ?: [];
|
|
|
|
$referers[] = $referer;
|
|
|
|
$record->referer = $referers;
|
|
|
|
}
|
|
|
|
|
2014-07-29 20:07:20 +10:00
|
|
|
if (!$record->exists) {
|
|
|
|
$record->count = 1;
|
|
|
|
$record->save();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$record->increment('count');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $record;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|