Skip to main content
Version: Next

Upgrade Guide

We are pleased to present version 1.2.3 of the MoonGuard Filament Plugin!

What's new

In this release, we have added a functionality to monitor the performance and health of your applications.

This functionality allows for tracking CPU load, RAM usage, and hard disk storage space.

It also includes break changes, mostly related to class names, new configuration file and updated migrations. This guide explains how to upgrade your project to v1.2.3

Update custom Site model

When creating a custom site model, make sure to include any new variables for the site table in both the $fillable and $cast variables. Additionally, don't forget to add the serverMetrics() relation method.


<?php

namespace Taecontrol\MoonGuard\Models;

use Spatie\Url\Url;
use Illuminate\Database\Eloquent\Model;
//...

class Site extends Model implements MoonGuardSite
{
use HasFactory;

protected $fillable = [
//...
'cpu_limit',
'ram_limit',
'disk_limit',
'server_monitoring_notification_enabled',
];

protected $casts = [
//...
'server_monitoring_notification_enabled' => 'boolean',
];

//...
public function serverMetrics(): HasMany
{
return $this->hasMany(ServerMetric::class);
}
}

Commands

The MoonGuardCommandScheduler is being updated to include a new PruneServerMetricCommand and to change the DeleteOldExceptionCommand class to PruneExceptionCommand. Therefore, you need to ensure that you add these changes to your scheduler.


<?php

use Taecontrol\MoonGuard\Console\MoonGuardCommandsScheduler;
//...

protected function schedule(Schedule $schedule): void
{
MoonGuardCommandsScheduler::scheduleMoonGuardCommands(
$schedule,
//...
'0 0 * * *', //<-- [Optional] Prune Exceptions Cron
'0 0 * * *' //<-- [Optional] Prune Server Metrics
);
}

In case that you're using DeleteOldExceptionCommand you need to replace it with the new PruneExceptionCommand, in your console/kernel.php file.


<?php
//...
use Taecontrol\MoonGuard\Console\Commands\PruneExceptionCommand;

Migrations

We have updated the main migration stub file to include a new server_metrics table. Additionally, we have added new fields to the Site table, such as server_monitoring_notification_enabled, cpu_limit, ram_limit, and disk_limit, to support the new server monitoring feature.

This changes on the database structure implies adding two migration files:

php artisan make:migration create_server_metrics_table
php artisan make:migration update_sites_table

Then add the following structure:

create_server_metrics_table


<?php

use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
use Taecontrol\MoonGuard\Repositories\SiteRepository;

return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::create('server_metrics', function (Blueprint $table) {
$table->id();
$table->integer('cpu_load');
$table->integer('memory_usage');
$table->json('disk_usage');
$table->foreignIdFor(SiteRepository::resolveModelClass())
->constrained()
->cascadeOnDelete()
->cascadeOnUpdate();

$table->timestamps();
});
}

/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::table('server_metrics', function (Blueprint $table) {
$table->dropForeignIdFor(SiteRepository::resolveModelClass());
});

Schema::dropIfExists('server_metrics');
}
};

update_sites_table

<?php

use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

return new class extends Migration
{
public function up()
{
Schema::table('sites', function (Blueprint $table) {
$table->boolean('server_monitoring_notification_enabled')->default(false);
$table->integer('cpu_limit')->nullable();
$table->integer('ram_limit')->nullable();
$table->integer('disk_limit')->nullable();
});
}
};

Finally run the migrations to update the database.

php artisan migrate

Please refers to migrations documentation for more information.

Upgrade config

We have updated our moonguard.php configuration file to incorporate the server metrics features. As part of this update, we have changed the exception_deletion configuration to prune_deletion.

<?php
[
//...
'prune_exception' => [
/*
* Enable or disable pruning exceptions data.
*/
'enabled' => true,

/*
* Eliminates exceptions that are older than 7 days.
*/
'prune_exceptions_older_than_days' => 7,
],
]

We have also included the prune_server_monitoring configuration and added the ServerMetricAlertEvent and ServerMetricAlertListener classes to the event array.


<?php

[
//...
'prune_server_monitoring' => [
/*
* Enables or disables pruning server monitoring data.
*/
'enabled' => true,

/*
* Deletes server monitoring logs that are older than 7 days..
*/
'prune_server_monitoring_records_older_than_days' => 7,
],
]

<?php

[
//...
'events' => [
/*
* the events that can be listened for.
* you can add your own listeners here.
*/
'listen' => [
//...
\Taecontrol\MoonGuard\Events\ServerMetricAlertEvent::class => [
\Taecontrol\MoonGuard\Listeners\ServerMetricAlertListener::class,
],
],
],
]

Please refers to config documentation for more information.