1. Go to this page and download the library: Download faustoff/laravel-contextify library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
faustoff / laravel-contextify example snippets
namespace App\Services;
use Faustoff\Contextify\Loggable;
class OrderService
{
use Loggable;
public function order(): void
{
// You business logic here
// Just a log message
$this->logSuccess('Order was created');
// Log message with context data
$this->logSuccess('Order was created', ['key' => 'value']);
// Log message with context data both in log and notification
$this->logSuccess('Order was created', ['key' => 'value'], true);
}
}
namespace App\Services\OrderService;
use Faustoff\Contextify\HasLog;
class OrderService
{
use HasLog;
public function order()
{
// ...
$this->log->logSuccess('Order was created');
}
}
namespace App\Http\Controllers;
use App\Services\OrderService;
use Illuminate\Routing\Controller;
use Faustoff\Contextify\Loggable;
use Faustoff\Contextify\LoggableInterface;
class OrderController extends Controller implements LoggableInterface
{
use Loggable;
public function store()
{
(new OrderService())->setLog($this)->order();
}
}
namespace App\Services;
use Faustoff\Contextify\Loggable;
class OrderService
{
use Loggable;
public function order(): void
{
// You business logic here
// Log message and notification with context data
$this->logSuccess('Order was created', ['key' => 'value'], true);
}
}
namespace App\Console\Commands;
use Illuminate\Console\Command;
use Faustoff\Contextify\Console\Loggable;
class SyncData extends Command
{
use Loggable;
protected $signature = 'data:sync';
public function handle(): int
{
$this->logSuccess('Data was synced');
return self::SUCCESS;
}
}
namespace App\Console\Commands;
use Illuminate\Console\Command;
use Faustoff\Contextify\Console\Trackable;
class SyncData extends Command
{
use Trackable;
protected $signature = 'data:sync';
public function handle(): int
{
// You business logic here
$this->logSuccess('Data was synced');
return self::SUCCESS;
}
}
namespace App\Console\Commands;
use Illuminate\Console\Command;
use Faustoff\Contextify\Console\Outputable;
class SyncData extends Command
{
use Outputable;
protected $signature = 'data:sync';
public function handle(): int
{
// You business logic here
$this->info('Data was synced');
return self::SUCCESS;
}
}
namespace App\Console\Commands;
use Faustoff\Contextify\Console\Loggable;
use Illuminate\Console\Command;
use Symfony\Component\Console\Command\SignalableCommandInterface;
class ConsumeStats extends Command implements SignalableCommandInterface
{
use Terminatable;
protected $signature = 'stats:consume';
public function handle(): void
{
while (true) {
// ...
if ($this->shouldTerminate) {
// Execution terminated by handle shutdown signal
break;
}
}
}
}
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.