interface TypedDataInterface

Same name in other branches
  1. 9 core/lib/Drupal/Core/TypedData/TypedDataInterface.php \Drupal\Core\TypedData\TypedDataInterface
  2. 8.9.x core/lib/Drupal/Core/TypedData/TypedDataInterface.php \Drupal\Core\TypedData\TypedDataInterface
  3. 10 core/lib/Drupal/Core/TypedData/TypedDataInterface.php \Drupal\Core\TypedData\TypedDataInterface

Interface for typed data objects.

Hierarchy

Expanded class hierarchy of TypedDataInterface

All classes that implement TypedDataInterface

See also

\Drupal\Core\TypedData\DataDefinitionInterface

Related topics

32 files declare their use of TypedDataInterface
ComplexDataConstraintValidator.php in core/lib/Drupal/Core/Validation/Plugin/Validation/Constraint/ComplexDataConstraintValidator.php
ConfigEntityValidationTestBase.php in core/tests/Drupal/KernelTests/Core/Config/ConfigEntityValidationTestBase.php
ConfigMapperManager.php in core/modules/config_translation/src/ConfigMapperManager.php
ConfigMapperManagerTest.php in core/modules/config_translation/tests/src/Unit/ConfigMapperManagerTest.php
ConfigTranslationFormBase.php in core/modules/config_translation/src/Form/ConfigTranslationFormBase.php

... See full list

File

core/lib/Drupal/Core/TypedData/TypedDataInterface.php, line 12

Namespace

Drupal\Core\TypedData
View source
interface TypedDataInterface {
    
    /**
     * Constructs a TypedData object given its definition and context.
     *
     * @param \Drupal\Core\TypedData\DataDefinitionInterface $definition
     *   The data definition.
     * @param string|null $name
     *   (optional) The name of the created property, or NULL if it is the root
     *   of a typed data tree. Defaults to NULL.
     * @param \Drupal\Core\TypedData\TraversableTypedDataInterface $parent
     *   (optional) The parent object of the data property, or NULL if it is the
     *   root of a typed data tree. Defaults to NULL.
     *
     * @todo When \Drupal\Core\Config\TypedConfigManager has been fixed to use
     *   class-based definitions, type-hint $definition to
     *   DataDefinitionInterface. https://www.drupal.org/node/1928868
     *
     * @see \Drupal\Core\TypedData\TypedDataManager::create()
     */
    public static function createInstance($definition, $name = NULL, ?TraversableTypedDataInterface $parent = NULL);
    
    /**
     * Gets the data definition.
     *
     * @return \Drupal\Core\TypedData\DataDefinitionInterface
     *   The data definition object.
     */
    public function getDataDefinition();
    
    /**
     * Gets the data value.
     *
     * @return mixed
     *   The data value.
     */
    public function getValue();
    
    /**
     * Sets the data value.
     *
     * @param mixed|null $value
     *   The value to set in the format as documented for the data type or NULL to
     *   unset the data value.
     * @param bool $notify
     *   (optional) Whether to notify the parent object of the change. Defaults to
     *   TRUE. If a property is updated from a parent object, set it to FALSE to
     *   avoid being notified again.
     *
     * @throws \InvalidArgumentException
     *   If the value input is inappropriate.
     * @throws \Drupal\Core\TypedData\Exception\ReadOnlyException
     *   If the data is read-only.
     */
    public function setValue($value, $notify = TRUE);
    
    /**
     * Returns a string representation of the data.
     *
     * @return string
     *   The string representation of the data.
     */
    public function getString();
    
    /**
     * Gets a list of validation constraints.
     *
     * @return array
     *   Array of constraints, each being an instance of
     *   \Symfony\Component\Validator\Constraint.
     */
    public function getConstraints();
    
    /**
     * Validates the currently set data value.
     *
     * @return \Symfony\Component\Validator\ConstraintViolationListInterface
     *   A list of constraint violations. If the list is empty, validation
     *   succeeded.
     */
    public function validate();
    
    /**
     * Applies the default value.
     *
     * @param bool $notify
     *   (optional) Whether to notify the parent object of the change. Defaults to
     *   TRUE. If a property is updated from a parent object, set it to FALSE to
     *   avoid being notified again.
     *
     * @return $this
     *   Returns itself to allow for chaining.
     */
    public function applyDefaultValue($notify = TRUE);
    
    /**
     * Returns the name of a property or item.
     *
     * @return string|int|null
     *   If the data is a property of some complex data, the name of the property.
     *   If the data is an item of a list, the name is the numeric position of the
     *   item in the list, starting with 0. Otherwise, NULL is returned.
     */
    public function getName();
    
    /**
     * Returns the parent data structure; i.e. either complex data or a list.
     *
     * @return \Drupal\Core\TypedData\TraversableTypedDataInterface|null
     *   The parent data structure, either complex data or a list; or NULL if this
     *   is the root of the typed data tree.
     */
    public function getParent();
    
    /**
     * Returns the root of the typed data tree.
     *
     * Returns the root data for a tree of typed data objects; e.g. for an entity
     * field item the root of the tree is its parent entity object.
     *
     * @return \Drupal\Core\TypedData\TraversableTypedDataInterface
     *   The root data structure, either complex data or a list.
     */
    public function getRoot();
    
    /**
     * Returns the property path of the data.
     *
     * The trail of property names relative to the root of the typed data tree,
     * separated by dots; e.g. 'field_text.0.format'.
     *
     * @return string
     *   The property path relative to the root of the typed tree, or an empty
     *   string if this is the root.
     */
    public function getPropertyPath();
    
    /**
     * Sets the context of a property or item via a context aware parent.
     *
     * This method is supposed to be called by the factory only.
     *
     * @param string|null $name
     *   (optional) The name of the property or the delta of the list item,
     *   or NULL if it is the root of a typed data tree. Defaults to NULL.
     * @param \Drupal\Core\TypedData\TraversableTypedDataInterface|null $parent
     *   (optional) The parent object of the data property, or NULL if it is the
     *   root of a typed data tree. Defaults to NULL.
     */
    public function setContext($name = NULL, ?TraversableTypedDataInterface $parent = NULL);

}

Members

Title Sort descending Modifiers Object type Summary Overrides
TypedDataInterface::applyDefaultValue public function Applies the default value. 1
TypedDataInterface::createInstance public static function Constructs a TypedData object given its definition and context. 1
TypedDataInterface::getConstraints public function Gets a list of validation constraints. 1
TypedDataInterface::getDataDefinition public function Gets the data definition. 3
TypedDataInterface::getName public function Returns the name of a property or item. 1
TypedDataInterface::getParent public function Returns the parent data structure; i.e. either complex data or a list. 1
TypedDataInterface::getPropertyPath public function Returns the property path of the data. 1
TypedDataInterface::getRoot public function Returns the root of the typed data tree. 1
TypedDataInterface::getString public function Returns a string representation of the data. 1
TypedDataInterface::getValue public function Gets the data value. 1
TypedDataInterface::setContext public function Sets the context of a property or item via a context aware parent. 1
TypedDataInterface::setValue public function Sets the data value. 1
TypedDataInterface::validate public function Validates the currently set data value. 1

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