linku/feedback

Abstract layer between services and output in PHP

1.0.3 2021-11-08 13:28 UTC

This package is auto-updated.

Last update: 2024-12-08 19:40:19 UTC


README

Build Status Software License Packagist Version

Feedback is an io abstraction that lets you decouple functional code and business logic from (CLI) I/O.

Installation

composer require linku/feedback

Use

In the class or service you want to decouple, add a Feedback attribute and make sure it is filled with an instance of NoFeedback by default.

In order to allow the code calling this service to override the default feedback, add a setFeedback method.

In the logic of your service, you can now call the feedback methods.

<?php

use Linku\Feedback\Feedback;
use Linku\Feedback\NoFeedback;

class MyService
{
    /**
     * @var Feedback
     */
    private $feedback;

    public function __construct()
    {
        $this->feedback = new NoFeedback();
    }

    public function setFeedback(Feedback $feedback): void
    {
        $this->feedback = $feedback;    
    }

    public function run(): void
    {
        $this->feedback->info('Starting my service run');

        $this->feedback->startProcess();

        for ($i = 0; $i < 100; $i++) {
            try {
                // Do something in a loop here
            } catch (\Throwable $exception) {
                $this->feedback->exception($exception);
            }

            $this->feedback->advanceProcess();
        }

        $this->feedback->finishProcess();

        $this->feedback->success('Completed my service run');
    }
}

In the script or CLI command that uses your service, set the apropriate feedback.

<?php

$service = new MyService();

$service->setFeedback(new LoggerFeedback(new Logger()));

$service->run();

Available feedback

NoFeedback

A safe fallback that doesn't output anything.

ClosureFeedback

A feedback you can fill with your own anonymous functions.

LoggerFeedback

A feedback that will write to any PSR-3 Logger.

ChainedFeedback

A feedback that lets you use multiple feedbacks at the same time.

<?php

$myService->setFeedback(new ChainedFeedback(
    new LoggerFeedback(new Logger()),
    new ClosureFeedback(/* ... */)
));

Other feedback packages

SymfonyStyleFeedback

If you use Symfony CLI, check out Linku/SymfonyStyleFeedback for integration with the Symfony Style component.