AttributeBase.php

Namespace

Drupal\Component\Plugin\Attribute

File

core/lib/Drupal/Component/Plugin/Attribute/AttributeBase.php

View source
<?php

namespace Drupal\Component\Plugin\Attribute;


/**
 * Provides a base class for classed attributes.
 */
abstract class AttributeBase implements AttributeInterface {
  
  /**
   * The class used for this attribute class.
   *
   * @var class-string
   */
  protected string $class;
  
  /**
   * The provider of the attribute class.
   */
  protected string|null $provider = NULL;
  
  /**
   * The dependencies for the attribute class.
   *
   * Dependencies are keyed by type. If the type is 'class', 'interface', or
   * 'trait', the values for the type are class names. If the type is
   * 'provider', the values for the type are provider names.
   *
   * @var array{"class"?: list<class-string>, "interface"?: list<class-string>, "trait"?: list<class-string>, "provider"?: list<string>}|null
   */
  protected array|null $dependencies = NULL;
  
  /**
   * @param string $id
   *   The attribute class ID.
   */
  public function __construct(protected readonly string $id) {
  }
  
  /**
   * {@inheritdoc}
   */
  public function getProvider() : ?string {
    return $this->provider;
  }
  
  /**
   * {@inheritdoc}
   */
  public function setProvider(string $provider) : void {
    $this->provider = $provider;
  }
  
  /**
   * {@inheritdoc}
   */
  public function getId() : string {
    return $this->id;
  }
  
  /**
   * {@inheritdoc}
   */
  public function getClass() : string {
    return $this->class;
  }
  
  /**
   * {@inheritdoc}
   */
  public function setClass(string $class) : void {
    $this->class = $class;
  }
  
  /**
   * {@inheritdoc}
   */
  public function getDependencies() : ?array {
    return $this->dependencies;
  }
  
  /**
   * {@inheritdoc}
   */
  public function setDependencies(?array $dependencies) : void {
    $this->dependencies = $dependencies;
  }
  
  /**
   * {@inheritdoc}
   */
  public function get() : array|object {
    return array_filter(get_object_vars($this) + [
      'class' => $this->getClass(),
      'provider' => $this->getProvider(),
    ], function ($value, $key) {
      return !($value === NULL && in_array($key, [
        'deriver',
        'provider',
        'dependencies',
      ]));
    }, ARRAY_FILTER_USE_BOTH);
  }

}

Classes

Title Deprecated Summary
AttributeBase Provides a base class for classed attributes.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.