1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-18 09:04:35 +01:00
invoiceninja/app/Models/SystemLog.php

110 lines
2.7 KiB
PHP
Raw Normal View History

2019-10-01 03:56:48 +02:00
<?php
/**
* Invoice Ninja (https://invoiceninja.com).
2019-10-01 03:56:48 +02:00
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
* @copyright Copyright (c) 2021. Invoice Ninja LLC (https://invoiceninja.com)
2019-10-01 03:56:48 +02:00
*
* @license https://opensource.org/licenses/AAL
*/
namespace App\Models;
2020-08-24 12:28:47 +02:00
use App\Utils\Traits\MakesHash;
2019-10-01 03:56:48 +02:00
use Illuminate\Database\Eloquent\Model;
2020-08-24 12:28:47 +02:00
use Illuminate\Database\Eloquent\SoftDeletes;
2019-10-01 03:56:48 +02:00
class SystemLog extends Model
{
2020-08-24 12:28:47 +02:00
use Filterable;
use SoftDeletes;
use MakesHash;
2020-08-24 12:28:47 +02:00
protected $casts = [
'updated_at' => 'timestamp',
'created_at' => 'timestamp',
'deleted_at' => 'timestamp',
'log' => 'array',
2020-08-24 12:28:47 +02:00
];
protected $dateFormat = 'Y-m-d H:i:s.u';
2019-10-01 03:56:48 +02:00
/* Category IDs */
const CATEGORY_GATEWAY_RESPONSE = 1;
const CATEGORY_MAIL = 2;
2021-01-13 00:12:01 +01:00
const CATEGORY_WEBHOOK = 3;
2021-01-14 04:44:52 +01:00
const CATEGORY_PDF = 4;
const CATEGORY_SECURITY = 5;
2019-10-01 03:56:48 +02:00
/* Event IDs*/
const EVENT_PAYMENT_RECONCILIATION_FAILURE = 10;
const EVENT_PAYMENT_RECONCILIATION_SUCCESS = 11;
const EVENT_GATEWAY_SUCCESS = 21;
const EVENT_GATEWAY_FAILURE = 22;
const EVENT_GATEWAY_ERROR = 23;
const EVENT_MAIL_SEND = 30;
const EVENT_MAIL_RETRY_QUEUE = 31; //we use this to queue emails that are spooled and not sent due to the email queue quota being exceeded.
2021-02-23 23:56:23 +01:00
const EVENT_MAIL_BOUNCED = 32;
const EVENT_MAIL_SPAM_COMPLAINT = 33;
const EVENT_MAIL_DELIVERY = 34;
2021-01-13 00:12:01 +01:00
const EVENT_WEBHOOK_RESPONSE = 40;
2021-01-13 00:25:33 +01:00
const EVENT_PDF_RESPONSE = 50;
2021-01-14 04:44:52 +01:00
const EVENT_AUTHENTICATION_FAILURE = 60;
const EVENT_USER = 61;
/*Type IDs*/
const TYPE_PAYPAL = 300;
const TYPE_STRIPE = 301;
const TYPE_LEDGER = 302;
const TYPE_FAILURE = 303;
2020-06-11 15:13:35 +02:00
const TYPE_CHECKOUT = 304;
const TYPE_AUTHORIZE = 305;
const TYPE_CUSTOM = 306;
const TYPE_QUOTA_EXCEEDED = 400;
const TYPE_UPSTREAM_FAILURE = 401;
2021-01-13 00:12:01 +01:00
const TYPE_WEBHOOK_RESPONSE = 500;
2021-01-14 04:44:52 +01:00
2021-01-13 00:25:33 +01:00
const TYPE_PDF_FAILURE = 600;
const TYPE_PDF_SUCCESS = 601;
2021-01-13 00:12:01 +01:00
2021-01-14 04:44:52 +01:00
const TYPE_MODIFIED = 701;
const TYPE_DELETED = 702;
protected $fillable = [
'client_id',
'company_id',
'user_id',
'log',
'category_id',
'event_id',
'type_id',
];
2020-11-25 15:19:52 +01:00
public function resolveRouteBinding($value, $field = null)
2020-08-24 11:51:19 +02:00
{
if (is_numeric($value)) {
throw new ModelNotFoundException("Record with value {$value} not found");
}
return $this
->where('id', $this->decodePrimaryKey($value))->firstOrFail();
}
2020-08-24 12:28:47 +02:00
/*
2020-08-24 12:28:47 +02:00
V2 type of scope
*/
public function scopeCompany($query)
{
$query->where('company_id', auth()->user()->companyId());
2020-08-24 12:28:47 +02:00
return $query;
}
2020-11-25 15:19:52 +01:00
}