SessionIterator.php 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  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\web;
  8. /**
  9. * SessionIterator implements an [[\Iterator|iterator]] for traversing session variables managed by [[Session]].
  10. *
  11. * @author Qiang Xue <qiang.xue@gmail.com>
  12. * @since 2.0
  13. */
  14. class SessionIterator implements \Iterator
  15. {
  16. /**
  17. * @var array list of keys in the map
  18. */
  19. private $_keys;
  20. /**
  21. * @var string|int|false current key
  22. */
  23. private $_key;
  24. /**
  25. * Constructor.
  26. */
  27. public function __construct()
  28. {
  29. $this->_keys = array_keys(isset($_SESSION) ? $_SESSION : []);
  30. $this->rewind();
  31. }
  32. /**
  33. * Rewinds internal array pointer.
  34. * This method is required by the interface [[\Iterator]].
  35. */
  36. #[\ReturnTypeWillChange]
  37. public function rewind()
  38. {
  39. $this->_key = reset($this->_keys);
  40. }
  41. /**
  42. * Returns the key of the current array element.
  43. * This method is required by the interface [[\Iterator]].
  44. * @return string|int|null the key of the current array element
  45. */
  46. #[\ReturnTypeWillChange]
  47. public function key()
  48. {
  49. return $this->_key === false ? null : $this->_key;
  50. }
  51. /**
  52. * Returns the current array element.
  53. * This method is required by the interface [[\Iterator]].
  54. * @return mixed the current array element
  55. */
  56. #[\ReturnTypeWillChange]
  57. public function current()
  58. {
  59. return $this->_key !== false && isset($_SESSION[$this->_key]) ? $_SESSION[$this->_key] : null;
  60. }
  61. /**
  62. * Moves the internal pointer to the next array element.
  63. * This method is required by the interface [[\Iterator]].
  64. */
  65. #[\ReturnTypeWillChange]
  66. public function next()
  67. {
  68. do {
  69. $this->_key = next($this->_keys);
  70. } while ($this->_key !== false && !isset($_SESSION[$this->_key]));
  71. }
  72. /**
  73. * Returns whether there is an element at current position.
  74. * This method is required by the interface [[\Iterator]].
  75. * @return bool
  76. */
  77. #[\ReturnTypeWillChange]
  78. public function valid()
  79. {
  80. return $this->_key !== false;
  81. }
  82. }