Merge pull request #2931 from nstapelbroek/feature/2895-custom-meta-descriptions-per-incident
Custom meta descriptions per incident
This commit is contained in:
@@ -140,7 +140,7 @@ final class CreateIncidentCommand
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function __construct($name, $status, $message, $visible, $component_id, $component_status, $notify, $stickied, $occurred_at, $template, array $template_vars = [], $meta = [])
|
||||
public function __construct($name, $status, $message, $visible, $component_id, $component_status, $notify, $stickied, $occurred_at, $template, array $template_vars = [], array $meta = [])
|
||||
{
|
||||
$this->name = $name;
|
||||
$this->status = $status;
|
||||
|
||||
@@ -106,6 +106,13 @@ final class UpdateIncidentCommand
|
||||
*/
|
||||
public $template_vars;
|
||||
|
||||
/**
|
||||
* Meta key/value pairs.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
public $meta = [];
|
||||
|
||||
/**
|
||||
* The validation rules.
|
||||
*
|
||||
@@ -122,6 +129,7 @@ final class UpdateIncidentCommand
|
||||
'stickied' => 'nullable|bool',
|
||||
'occurred_at' => 'nullable|string',
|
||||
'template' => 'nullable|string',
|
||||
'meta' => 'nullable|array',
|
||||
];
|
||||
|
||||
/**
|
||||
@@ -139,10 +147,11 @@ final class UpdateIncidentCommand
|
||||
* @param string|null $occurred_at
|
||||
* @param string|null $template
|
||||
* @param array $template_vars
|
||||
* @param array $meta
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function __construct(Incident $incident, $name, $status, $message, $visible, $component_id, $component_status, $notify, $stickied, $occurred_at, $template, array $template_vars = [])
|
||||
public function __construct(Incident $incident, $name, $status, $message, $visible, $component_id, $component_status, $notify, $stickied, $occurred_at, $template, array $template_vars = [], array $meta = [])
|
||||
{
|
||||
$this->incident = $incident;
|
||||
$this->name = $name;
|
||||
@@ -156,5 +165,6 @@ final class UpdateIncidentCommand
|
||||
$this->occurred_at = $occurred_at;
|
||||
$this->template = $template;
|
||||
$this->template_vars = $template_vars;
|
||||
$this->meta = $meta;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -15,6 +15,7 @@ use CachetHQ\Cachet\Bus\Commands\Component\UpdateComponentCommand;
|
||||
use CachetHQ\Cachet\Bus\Commands\Incident\CreateIncidentCommand;
|
||||
use CachetHQ\Cachet\Bus\Events\Incident\IncidentWasCreatedEvent;
|
||||
use CachetHQ\Cachet\Bus\Exceptions\Incident\InvalidIncidentTimestampException;
|
||||
use CachetHQ\Cachet\Bus\Handlers\Traits\StoresMeta;
|
||||
use CachetHQ\Cachet\Models\Component;
|
||||
use CachetHQ\Cachet\Models\Incident;
|
||||
use CachetHQ\Cachet\Models\IncidentTemplate;
|
||||
@@ -32,6 +33,8 @@ use Twig\Loader\ArrayLoader as Twig_Loader_Array;
|
||||
*/
|
||||
class CreateIncidentCommandHandler
|
||||
{
|
||||
use StoresMeta;
|
||||
|
||||
/**
|
||||
* The authentication guard instance.
|
||||
*
|
||||
@@ -104,14 +107,7 @@ class CreateIncidentCommandHandler
|
||||
|
||||
// Store any meta?
|
||||
if ($meta = $command->meta) {
|
||||
foreach ($meta as $key => $value) {
|
||||
Meta::create([
|
||||
'key' => $key,
|
||||
'value' => $value,
|
||||
'meta_type' => 'incidents',
|
||||
'meta_id' => $incident->id,
|
||||
]);
|
||||
}
|
||||
$this->storeMeta($command->meta, 'incidents', $incident->id);
|
||||
}
|
||||
|
||||
// Update the component.
|
||||
|
||||
@@ -15,6 +15,7 @@ use CachetHQ\Cachet\Bus\Commands\Component\UpdateComponentCommand;
|
||||
use CachetHQ\Cachet\Bus\Commands\Incident\UpdateIncidentCommand;
|
||||
use CachetHQ\Cachet\Bus\Events\Incident\IncidentWasUpdatedEvent;
|
||||
use CachetHQ\Cachet\Bus\Exceptions\Incident\InvalidIncidentTimestampException;
|
||||
use CachetHQ\Cachet\Bus\Handlers\Traits\StoresMeta;
|
||||
use CachetHQ\Cachet\Models\Component;
|
||||
use CachetHQ\Cachet\Models\Incident;
|
||||
use CachetHQ\Cachet\Models\IncidentTemplate;
|
||||
@@ -30,6 +31,8 @@ use Twig\Loader\ArrayLoader as Twig_Loader_Array;
|
||||
*/
|
||||
class UpdateIncidentCommandHandler
|
||||
{
|
||||
use StoresMeta;
|
||||
|
||||
/**
|
||||
* The authentication guard instance.
|
||||
*
|
||||
@@ -86,6 +89,11 @@ class UpdateIncidentCommandHandler
|
||||
// Rather than making lots of updates, just fill and save.
|
||||
$incident->save();
|
||||
|
||||
// Store any meta?
|
||||
if ($meta = $command->meta) {
|
||||
$this->storeMeta($command->meta, 'incidents', $incident->id);
|
||||
}
|
||||
|
||||
// Update the component.
|
||||
if ($component = Component::find($command->component_id)) {
|
||||
execute(new UpdateComponentCommand(
|
||||
|
||||
81
app/Bus/Handlers/Traits/StoresMeta.php
Normal file
81
app/Bus/Handlers/Traits/StoresMeta.php
Normal file
@@ -0,0 +1,81 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of Cachet.
|
||||
*
|
||||
* (c) Alt Three Services Limited
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace CachetHQ\Cachet\Bus\Handlers\Traits;
|
||||
|
||||
use CachetHQ\Cachet\Models\Meta;
|
||||
|
||||
trait StoresMeta
|
||||
{
|
||||
/**
|
||||
* Stores all Meta values of a model.
|
||||
*
|
||||
* @param array $metaData
|
||||
* @param string $metaType
|
||||
* @param string|int $metaId
|
||||
* @param string $metaModel
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function storeMeta($metaData, $metaType, $metaId, $metaModel = Meta::class)
|
||||
{
|
||||
// Validation required instead of type hinting because it could be passed as false or NULL
|
||||
if (!is_array($metaData)) {
|
||||
return;
|
||||
}
|
||||
|
||||
foreach ($metaData as $key => $value) {
|
||||
$modelInstance = call_user_func(
|
||||
[$metaModel, 'firstOrNew'],
|
||||
[
|
||||
'key' => $key,
|
||||
'meta_type' => $metaType,
|
||||
'meta_id' => $metaId,
|
||||
]
|
||||
);
|
||||
|
||||
$value = $this->removeEmptyValues($value);
|
||||
if (!empty($value)) {
|
||||
$modelInstance->setAttribute('value', $value);
|
||||
$modelInstance->save();
|
||||
continue;
|
||||
}
|
||||
|
||||
// The value is empty, remove the row
|
||||
if ($modelInstance->exists) {
|
||||
$modelInstance->delete();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine if a Value is empty.
|
||||
*
|
||||
* @param mixed $values
|
||||
*
|
||||
* @return array|mixed
|
||||
*/
|
||||
protected function removeEmptyValues($values)
|
||||
{
|
||||
if (!is_array($values)) {
|
||||
return empty($values) ? null : $values;
|
||||
}
|
||||
|
||||
foreach ($values as $key => $value) {
|
||||
if (!empty($value)) {
|
||||
continue;
|
||||
}
|
||||
unset($values[$key]);
|
||||
}
|
||||
|
||||
return $values;
|
||||
}
|
||||
}
|
||||
@@ -128,7 +128,8 @@ class IncidentController extends Controller
|
||||
Binput::get('stickied', false),
|
||||
Binput::get('occurred_at'),
|
||||
null,
|
||||
[]
|
||||
[],
|
||||
['seo' => Binput::get('seo', [])]
|
||||
));
|
||||
} catch (ValidationException $e) {
|
||||
return cachet_redirect('dashboard.incidents.create')
|
||||
@@ -258,7 +259,8 @@ class IncidentController extends Controller
|
||||
Binput::get('stickied', false),
|
||||
Binput::get('occurred_at'),
|
||||
null,
|
||||
[]
|
||||
[],
|
||||
['seo' => Binput::get('seo', [])]
|
||||
));
|
||||
} catch (ValidationException $e) {
|
||||
return cachet_redirect('dashboard.incidents.edit', ['id' => $incident->id])
|
||||
|
||||
Reference in New Issue
Block a user