123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171 |
- <?php
- declare(strict_types=1);
- /**
- * SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors
- * SPDX-License-Identifier: AGPL-3.0-or-later
- */
- namespace OCP\EventDispatcher;
- use ArrayAccess;
- use ArrayIterator;
- use InvalidArgumentException;
- use IteratorAggregate;
- use Traversable;
- use function array_key_exists;
- /**
- * Class GenericEvent
- *
- * convenience reimplementation of \Symfony\Component\GenericEvent against
- * \OCP\EventDispatcher\Event
- *
- * @since 18.0.0
- * @deprecated 22.0.0 use \OCP\EventDispatcher\Event
- */
- class GenericEvent extends Event implements ArrayAccess, IteratorAggregate {
- /** @deprecated 22.0.0 */
- protected $subject;
- /** @deprecated 22.0.0 */
- protected $arguments;
- /**
- * Encapsulate an event with $subject and $args.
- *
- * @since 18.0.0
- * @deprecated 22.0.0
- */
- public function __construct($subject = null, array $arguments = []) {
- parent::__construct();
- $this->subject = $subject;
- $this->arguments = $arguments;
- }
- /**
- * Getter for subject property.
- *
- * @since 18.0.0
- * @deprecated 22.0.0
- */
- public function getSubject() {
- return $this->subject;
- }
- /**
- * Get argument by key.
- *
- * @throws InvalidArgumentException if key is not found
- * @since 18.0.0
- * @deprecated 22.0.0
- */
- public function getArgument(string $key) {
- if ($this->hasArgument($key)) {
- return $this->arguments[$key];
- }
- throw new InvalidArgumentException(sprintf('Argument "%s" not found.', $key));
- }
- /**
- * Add argument to event.
- *
- * @since 18.0.0
- * @deprecated 22.0.0
- */
- public function setArgument($key, $value): GenericEvent {
- $this->arguments[$key] = $value;
- return $this;
- }
- /**
- * Getter for all arguments.
- *
- * @since 18.0.0
- * @deprecated 22.0.0
- */
- public function getArguments(): array {
- return $this->arguments;
- }
- /**
- * Set args property.
- *
- * @since 18.0.0
- * @deprecated 22.0.0
- */
- public function setArguments(array $args = []): GenericEvent {
- $this->arguments = $args;
- return $this;
- }
- /**
- * Has argument.
- *
- * @since 18.0.0
- * @deprecated 22.0.0
- */
- public function hasArgument($key): bool {
- return array_key_exists($key, $this->arguments);
- }
- /**
- * Retrieve an external iterator
- *
- * @link https://php.net/manual/en/iteratoraggregate.getiterator.php
- * @since 18.0.0
- * @deprecated 22.0.0
- */
- public function getIterator(): Traversable {
- return new ArrayIterator($this->arguments);
- }
- /**
- * Whether a offset exists
- *
- * @link https://php.net/manual/en/arrayaccess.offsetexists.php
- * @since 18.0.0
- * @deprecated 22.0.0
- */
- public function offsetExists($offset): bool {
- return $this->hasArgument($offset);
- }
- /**
- * Offset to retrieve
- *
- * @link https://php.net/manual/en/arrayaccess.offsetget.php
- * @since 18.0.0
- * @deprecated 22.0.0
- * @return mixed
- */
- #[\ReturnTypeWillChange]
- public function offsetGet($offset) {
- return $this->arguments[$offset];
- }
- /**
- * Offset to set
- *
- * @link https://php.net/manual/en/arrayaccess.offsetset.php
- * @since 18.0.0
- * @deprecated 22.0.0
- */
- public function offsetSet($offset, $value): void {
- $this->setArgument($offset, $value);
- }
- /**
- * Offset to unset
- *
- * @link https://php.net/manual/en/arrayaccess.offsetunset.php
- * @since 18.0.0
- * @deprecated 22.0.0
- */
- public function offsetUnset($offset): void {
- if ($this->hasArgument($offset)) {
- unset($this->arguments[$offset]);
- }
- }
- }
|