ChainedDependency.php 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. <?php
  2. /**
  3. * @link https://www.yiiframework.com/
  4. * @copyright Copyright (c) 2008 Yii Software LLC
  5. * @license https://www.yiiframework.com/license/
  6. */
  7. namespace yii\caching;
  8. /**
  9. * ChainedDependency represents a dependency which is composed of a list of other dependencies.
  10. *
  11. * When [[dependOnAll]] is true, if any of the dependencies has changed, this dependency is
  12. * considered changed; When [[dependOnAll]] is false, if one of the dependencies has NOT changed,
  13. * this dependency is considered NOT changed.
  14. *
  15. * For more details and usage information on Cache, see the [guide article on caching](guide:caching-overview).
  16. *
  17. * @author Qiang Xue <qiang.xue@gmail.com>
  18. * @since 2.0
  19. */
  20. class ChainedDependency extends Dependency
  21. {
  22. /**
  23. * @var Dependency[] list of dependencies that this dependency is composed of.
  24. * Each array element must be a dependency object.
  25. */
  26. public $dependencies = [];
  27. /**
  28. * @var bool whether this dependency is depending on every dependency in [[dependencies]].
  29. * Defaults to true, meaning if any of the dependencies has changed, this dependency is considered changed.
  30. * When it is set false, it means if one of the dependencies has NOT changed, this dependency
  31. * is considered NOT changed.
  32. */
  33. public $dependOnAll = true;
  34. /**
  35. * Evaluates the dependency by generating and saving the data related with dependency.
  36. * @param CacheInterface $cache the cache component that is currently evaluating this dependency
  37. */
  38. public function evaluateDependency($cache)
  39. {
  40. foreach ($this->dependencies as $dependency) {
  41. $dependency->evaluateDependency($cache);
  42. }
  43. }
  44. /**
  45. * Generates the data needed to determine if dependency has been changed.
  46. * This method does nothing in this class.
  47. * @param CacheInterface $cache the cache component that is currently evaluating this dependency
  48. * @return mixed the data needed to determine if dependency has been changed.
  49. */
  50. protected function generateDependencyData($cache)
  51. {
  52. return null;
  53. }
  54. /**
  55. * {@inheritdoc}
  56. */
  57. public function isChanged($cache)
  58. {
  59. foreach ($this->dependencies as $dependency) {
  60. if ($this->dependOnAll && $dependency->isChanged($cache)) {
  61. return true;
  62. } elseif (!$this->dependOnAll && !$dependency->isChanged($cache)) {
  63. return false;
  64. }
  65. }
  66. return !$this->dependOnAll;
  67. }
  68. }