Artykuł "Laravel Attributes Overview: What and How to Use" (Przegląd atrybutów Laravel: co i jak używać) potępił możliwość uproszczenia wstrzykiwania zależności za pomocą atrybutów. Nie jest jednak konieczne ograniczanie się tylko do standardowych atrybutów Laravel. Możesz utworzyć własny atrybut, który wykona żądane zadanie.
Przykład stworzenia atrybutu, który automatycznie pobiera wartości z konfiguracji, czyli ma być podobny do pomocnika config():
Najpierw stwórzmy klasę MyConfig, która implementuje interfejs Illuminate\Contracts\Container\ContextualAttribute. Jest to konieczne, aby kontener mógł z nim pracować.
namespace App\Attributes;
use Attribute;
use Illuminate\Contracts\Container\Container;
use Illuminate\Contracts\Container\ContextualAttribute;
#[Attribute(Attribute::TARGET_PARAMETER)]
class MyConfig implements ContextualAttribute
{
public function __construct(
public string $key,
) {}
public static function resolve(self $attribute, Container $container)
{
return $container->make('config')->get($attribute->key);
}
}
Teraz atrybut #[MyConfig] jest gotowy. Użyj go, na przykład, aby automatycznie podstawić nazwę aplikacji w kontrolerze:
namespace App\Http\Controllers;
use App\Attributes\MyConfig;
class ExampleController extends Controller
{
public function __construct(
#[MyConfig('app.name')] protected string $appName
) {}
public function show(): string
{
return "Имя приложения: {$this->appName}";
}
}
Oczywiście, Laravel ma już , Configale najważniejsze jest to, że ten przykład można łatwo dostosować do innych zadań, takich jak podstawianie kluczy API, flag itp.