Mercurial > hg > isophonics-drupal-site
diff core/lib/Drupal/Component/Plugin/DependentPluginInterface.php @ 0:4c8ae668cc8c
Initial import (non-working)
author | Chris Cannam |
---|---|
date | Wed, 29 Nov 2017 16:09:58 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/core/lib/Drupal/Component/Plugin/DependentPluginInterface.php Wed Nov 29 16:09:58 2017 +0000 @@ -0,0 +1,37 @@ +<?php + +namespace Drupal\Component\Plugin; + +/** + * Provides an interface for a plugin that has dependencies. + * + * @ingroup plugin_api + */ +interface DependentPluginInterface { + + /** + * Calculates dependencies for the configured plugin. + * + * Dependencies are saved in the plugin's configuration entity and are used to + * determine configuration synchronization order. For example, if the plugin + * integrates with specific user roles, this method should return an array of + * dependencies listing the specified roles. + * + * @return array + * An array of dependencies grouped by type (config, content, module, + * theme). For example: + * @code + * array( + * 'config' => array('user.role.anonymous', 'user.role.authenticated'), + * 'content' => array('node:article:f0a189e6-55fb-47fb-8005-5bef81c44d6d'), + * 'module' => array('node', 'user'), + * 'theme' => array('seven'), + * ); + * @endcode + * + * @see \Drupal\Core\Config\Entity\ConfigDependencyManager + * @see \Drupal\Core\Entity\EntityInterface::getConfigDependencyName() + */ + public function calculateDependencies(); + +}