2014-11-25 11:19:20 +00:00
|
|
|
<?php
|
|
|
|
|
2015-04-19 08:52:39 +01:00
|
|
|
/*
|
|
|
|
* This file is part of Cachet.
|
|
|
|
*
|
2015-07-06 17:37:01 +01:00
|
|
|
* (c) Alt Three Services Limited
|
2015-04-19 08:52:39 +01:00
|
|
|
*
|
|
|
|
* For the full copyright and license information, please view the LICENSE
|
|
|
|
* file that was distributed with this source code.
|
|
|
|
*/
|
|
|
|
|
2015-01-02 00:18:19 +00:00
|
|
|
namespace CachetHQ\Cachet\Models;
|
|
|
|
|
2015-08-03 22:32:36 +01:00
|
|
|
use AltThree\Validator\ValidatingTrait;
|
2017-03-18 11:15:43 +00:00
|
|
|
use AltThree\Validator\ValidationException;
|
2016-02-23 13:34:22 -06:00
|
|
|
use CachetHQ\Cachet\Models\Traits\SortableTrait;
|
2015-06-16 09:46:29 +01:00
|
|
|
use CachetHQ\Cachet\Presenters\MetricPresenter;
|
2016-06-02 09:06:40 +01:00
|
|
|
use Illuminate\Database\Eloquent\Builder;
|
2015-01-01 12:23:17 +00:00
|
|
|
use Illuminate\Database\Eloquent\Model;
|
2017-03-18 11:15:43 +00:00
|
|
|
use Illuminate\Support\MessageBag;
|
2015-05-16 13:57:32 -05:00
|
|
|
use McCool\LaravelAutoPresenter\HasPresenter;
|
2014-11-25 21:35:52 +00:00
|
|
|
|
2015-05-16 13:57:32 -05:00
|
|
|
class Metric extends Model implements HasPresenter
|
2014-12-20 21:20:17 +00:00
|
|
|
{
|
2016-02-23 13:34:22 -06:00
|
|
|
use SortableTrait, ValidatingTrait;
|
2014-11-25 21:35:52 +00:00
|
|
|
|
2015-12-25 19:13:28 +08:00
|
|
|
/**
|
|
|
|
* The calculation type of sum.
|
|
|
|
*
|
|
|
|
* @var int
|
|
|
|
*/
|
2015-03-17 16:41:23 +00:00
|
|
|
const CALC_SUM = 0;
|
2015-12-25 19:13:28 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The calculation type of average.
|
|
|
|
*
|
|
|
|
* @var int
|
|
|
|
*/
|
2015-03-17 16:41:23 +00:00
|
|
|
const CALC_AVG = 1;
|
|
|
|
|
2016-12-04 16:54:36 +00:00
|
|
|
/**
|
|
|
|
* Viewable only authenticated users.
|
|
|
|
*
|
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
const VISIBLE_AUTHENTICATED = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Viewable by public.
|
|
|
|
*
|
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
const VISIBLE_GUEST = 1;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Viewable by nobody.
|
|
|
|
*
|
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
const VISIBLE_HIDDEN = 2;
|
|
|
|
|
2017-03-18 11:15:43 +00:00
|
|
|
/**
|
|
|
|
* Array of acceptable threshold minutes.
|
|
|
|
*
|
|
|
|
* @var int[]
|
|
|
|
*/
|
|
|
|
const ACCEPTABLE_THRESHOLDS = [1, 2, 3, 4, 5, 6, 10, 12, 15, 20, 30, 60];
|
|
|
|
|
2015-01-21 02:32:18 -06:00
|
|
|
/**
|
|
|
|
* The model's attributes.
|
|
|
|
*
|
2015-02-23 08:27:43 +00:00
|
|
|
* @var string[]
|
2015-01-21 02:32:18 -06:00
|
|
|
*/
|
|
|
|
protected $attributes = [
|
2015-02-23 08:27:43 +00:00
|
|
|
'name' => '',
|
|
|
|
'display_chart' => 1,
|
2015-03-17 16:41:23 +00:00
|
|
|
'default_value' => 0,
|
|
|
|
'calc_type' => 0,
|
2015-08-13 22:58:15 +01:00
|
|
|
'places' => 2,
|
2015-12-26 16:43:22 +00:00
|
|
|
'default_view' => 1,
|
2016-03-02 12:09:57 +00:00
|
|
|
'threshold' => 5,
|
2016-06-02 09:06:40 +01:00
|
|
|
'order' => 0,
|
2016-12-04 16:54:36 +00:00
|
|
|
'visible' => 1,
|
2015-01-21 02:32:18 -06:00
|
|
|
];
|
|
|
|
|
2015-01-01 18:57:33 +00:00
|
|
|
/**
|
2015-08-22 15:57:53 +01:00
|
|
|
* The attributes that should be casted to native types.
|
2015-01-01 18:57:33 +00:00
|
|
|
*
|
|
|
|
* @var string[]
|
|
|
|
*/
|
2015-08-22 15:57:53 +01:00
|
|
|
protected $casts = [
|
|
|
|
'name' => 'string',
|
|
|
|
'display_chart' => 'bool',
|
|
|
|
'default_value' => 'int',
|
|
|
|
'calc_type' => 'int',
|
|
|
|
'places' => 'int',
|
2015-12-26 16:43:22 +00:00
|
|
|
'default_view' => 'int',
|
2016-03-02 12:09:57 +00:00
|
|
|
'threshold' => 'int',
|
2016-06-02 09:06:40 +01:00
|
|
|
'order' => 'int',
|
2016-12-04 16:54:36 +00:00
|
|
|
'visible' => 'int',
|
2014-11-27 16:05:00 +00:00
|
|
|
];
|
2014-11-25 21:35:52 +00:00
|
|
|
|
2015-01-01 18:57:33 +00:00
|
|
|
/**
|
|
|
|
* The fillable properties.
|
|
|
|
*
|
|
|
|
* @var string[]
|
|
|
|
*/
|
2015-08-13 22:58:15 +01:00
|
|
|
protected $fillable = [
|
|
|
|
'name',
|
|
|
|
'suffix',
|
|
|
|
'description',
|
|
|
|
'display_chart',
|
|
|
|
'default_value',
|
|
|
|
'calc_type',
|
|
|
|
'places',
|
2015-12-26 16:43:22 +00:00
|
|
|
'default_view',
|
2016-03-02 12:09:57 +00:00
|
|
|
'threshold',
|
2016-06-02 09:06:40 +01:00
|
|
|
'order',
|
2016-12-04 16:54:36 +00:00
|
|
|
'visible',
|
2015-08-13 22:58:15 +01:00
|
|
|
];
|
2014-11-25 21:35:52 +00:00
|
|
|
|
2015-08-22 15:57:53 +01:00
|
|
|
/**
|
|
|
|
* The validation rules.
|
|
|
|
*
|
|
|
|
* @var string[]
|
|
|
|
*/
|
|
|
|
public $rules = [
|
|
|
|
'name' => 'required',
|
|
|
|
'suffix' => 'required',
|
2016-10-19 12:29:16 +01:00
|
|
|
'display_chart' => 'required|bool',
|
|
|
|
'default_value' => 'required|numeric',
|
|
|
|
'places' => 'required|numeric|between:0,4',
|
|
|
|
'default_view' => 'required|numeric|between:0,3',
|
|
|
|
'threshold' => 'required|numeric|between:0,10',
|
2016-12-04 16:54:36 +00:00
|
|
|
'visible' => 'required|numeric|between:0,2',
|
2015-08-22 15:57:53 +01:00
|
|
|
];
|
|
|
|
|
2016-02-23 13:34:22 -06:00
|
|
|
/**
|
|
|
|
* The sortable fields.
|
|
|
|
*
|
|
|
|
* @var string[]
|
|
|
|
*/
|
|
|
|
protected $sortable = [
|
|
|
|
'id',
|
|
|
|
'name',
|
|
|
|
'display_chart',
|
|
|
|
'default_value',
|
|
|
|
'calc_type',
|
2016-06-02 09:06:40 +01:00
|
|
|
'order',
|
2016-12-04 16:54:36 +00:00
|
|
|
'visible',
|
2016-02-23 13:34:22 -06:00
|
|
|
];
|
|
|
|
|
2016-12-15 20:09:59 +00:00
|
|
|
/**
|
|
|
|
* Overrides the models boot method.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public static function boot()
|
|
|
|
{
|
|
|
|
parent::boot();
|
|
|
|
|
|
|
|
// When deleting a metric, delete the points too.
|
|
|
|
self::deleting(function ($model) {
|
|
|
|
$model->points()->delete();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2017-06-13 19:25:43 +01:00
|
|
|
/**
|
|
|
|
* Get all of the meta relation.
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\MorphMany
|
|
|
|
*/
|
|
|
|
public function meta()
|
|
|
|
{
|
|
|
|
return $this->morphMany(Meta::class, 'meta');
|
|
|
|
}
|
|
|
|
|
2014-12-01 08:52:34 +00:00
|
|
|
/**
|
2016-08-10 10:46:45 +01:00
|
|
|
* Get the points relation.
|
2014-12-30 18:19:22 +00:00
|
|
|
*
|
2015-01-01 18:57:33 +00:00
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\HasMany
|
2014-12-01 08:52:34 +00:00
|
|
|
*/
|
2014-12-20 21:20:17 +00:00
|
|
|
public function points()
|
|
|
|
{
|
2015-06-16 09:46:29 +01:00
|
|
|
return $this->hasMany(MetricPoint::class, 'metric_id', 'id');
|
2014-12-01 08:52:34 +00:00
|
|
|
}
|
|
|
|
|
2016-06-02 09:06:40 +01:00
|
|
|
/**
|
|
|
|
* Scope metrics to those of which are displayable.
|
|
|
|
*
|
|
|
|
* @param \Illuminate\Database\Eloquent\Builder $query
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Database\Eloquent\Builder
|
|
|
|
*/
|
|
|
|
public function scopeDisplayable(Builder $query)
|
|
|
|
{
|
2016-12-04 16:54:36 +00:00
|
|
|
return $query->where('display_chart', '=', true)->where('visible', '!=', self::VISIBLE_HIDDEN);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Finds all metrics which are visible to public.
|
|
|
|
*
|
|
|
|
* @param \Illuminate\Database\Eloquent\Builder $query
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Database\Eloquent\Builder
|
|
|
|
*/
|
|
|
|
public function scopeVisible(Builder $query)
|
|
|
|
{
|
|
|
|
return $query->where('visible', '=', self::VISIBLE_GUEST);
|
2016-06-02 09:06:40 +01:00
|
|
|
}
|
|
|
|
|
2014-11-27 16:05:00 +00:00
|
|
|
/**
|
|
|
|
* Determines whether a chart should be shown.
|
2014-12-30 18:19:22 +00:00
|
|
|
*
|
2014-11-27 16:05:00 +00:00
|
|
|
* @return bool
|
|
|
|
*/
|
2014-12-20 21:20:17 +00:00
|
|
|
public function getShouldDisplayAttribute()
|
|
|
|
{
|
2016-10-19 12:29:16 +01:00
|
|
|
return $this->display_chart;
|
2014-11-27 16:05:00 +00:00
|
|
|
}
|
2015-05-16 13:57:32 -05:00
|
|
|
|
2017-03-18 11:15:43 +00:00
|
|
|
/**
|
|
|
|
* Validate the model before save.
|
|
|
|
*
|
|
|
|
* @throws \AltThree\Validator\ValidationException
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function validate()
|
|
|
|
{
|
|
|
|
$messages = [];
|
|
|
|
|
2017-04-02 14:35:34 +01:00
|
|
|
if (60 % $this->threshold !== 0) {
|
2017-04-02 14:46:13 +01:00
|
|
|
$messages[] = 'Threshold must divide by 60.';
|
2017-03-18 11:15:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($messages) {
|
|
|
|
throw new ValidationException(new MessageBag($messages));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-16 13:57:32 -05:00
|
|
|
/**
|
|
|
|
* Get the presenter class.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getPresenterClass()
|
|
|
|
{
|
2015-06-16 09:46:29 +01:00
|
|
|
return MetricPresenter::class;
|
2015-05-16 13:57:32 -05:00
|
|
|
}
|
2014-11-27 22:08:28 +00:00
|
|
|
}
|