Laravel - Контракты
Контракты Laravel - это набор интерфейсов с различными функциями и основными услугами, предоставляемыми фреймворком.
Например, Illuminate\Contracts\Queue\Queue контракт использует метод, который необходим для постановки заданий в очередь и Illuminate\Contracts\Mail\Mailer использует метод отправки электронных писем.
Каждый определенный контракт включает соответствующую реализацию структуры. Все контракты Laravel доступны в репозитории GitHub, как указано ниже -
https://github.com/illuminate/contracts
Этот репозиторий предоставляет множество контрактов, доступных в среде Laravel, которые можно загрузить и использовать соответствующим образом.
Важные точки
При работе с контрактами Laravel обратите внимание на следующие важные моменты:
Обязательно определять фасады в конструкторе класса.
Контракты явно определены в классах, и вам не нужно определять контракты в конструкторах.
пример
Рассмотрим контракт, используемый для авторизации в Laravel, который упомянут ниже -
<?php
namespace Illuminate\Contracts\Auth\Access;
interface Authorizable{
   /**
      * Determine if the entity has a given ability.
      *
      * @param string $ability
      * @param array|mixed $arguments
      * @return bool
   */
   public function can($ability, $arguments = []);
} 
    В контракте используется функция can, которая включает parameter названный ability и arguments который использует идентификацию пользователя в виде array.
Вам нужно будет определить контракт, как показано в синтаксисе ниже -
interface <contract-name> 
    Контракты используются как фасады для создания надежных, хорошо протестированных приложений Laravel. Есть разныеpractical differences с использованием договоров и фасадов.
В следующем коде показано использование контракта для кеширования репозитория -
<?php
namespace App\Orders;
use Illuminate\Contracts\Cache\Repository as Cache;
class Repository{
   /**
      * The cache instance.
   */
   
   protected $cache;
   
   /**
      * Create a new repository instance.
      *
      * @param Cache $cache
      * @return void
   */
   
   public function __construct(Cache $cache) {
      $this->cache = $cache;
   }
} 
    Контракт не содержит реализации и новых зависимостей; легко написать альтернативную реализацию указанного контракта, таким образом, пользователь может заменить реализацию кеширования без изменения какой-либо базы кода.