256 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			256 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
/*
 | 
						|
 * This file is part of the Symfony package.
 | 
						|
 *
 | 
						|
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
						|
 *
 | 
						|
 * For the full copyright and license information, please view the LICENSE
 | 
						|
 * file that was distributed with this source code.
 | 
						|
 */
 | 
						|
 | 
						|
namespace Symfony\Component\HttpKernel\Profiler;
 | 
						|
 | 
						|
use Symfony\Component\HttpKernel\DataCollector\DataCollectorInterface;
 | 
						|
 | 
						|
/**
 | 
						|
 * Profile.
 | 
						|
 *
 | 
						|
 * @author Fabien Potencier <fabien@symfony.com>
 | 
						|
 */
 | 
						|
class Profile
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * @var DataCollectorInterface[]
 | 
						|
     */
 | 
						|
    private array $collectors = [];
 | 
						|
 | 
						|
    private ?string $ip = null;
 | 
						|
    private ?string $method = null;
 | 
						|
    private ?string $url = null;
 | 
						|
    private ?int $time = null;
 | 
						|
    private ?int $statusCode = null;
 | 
						|
    private ?self $parent = null;
 | 
						|
    private ?string $virtualType = null;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var Profile[]
 | 
						|
     */
 | 
						|
    private array $children = [];
 | 
						|
 | 
						|
    public function __construct(
 | 
						|
        private string $token,
 | 
						|
    ) {
 | 
						|
    }
 | 
						|
 | 
						|
    public function setToken(string $token): void
 | 
						|
    {
 | 
						|
        $this->token = $token;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gets the token.
 | 
						|
     */
 | 
						|
    public function getToken(): string
 | 
						|
    {
 | 
						|
        return $this->token;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Sets the parent token.
 | 
						|
     */
 | 
						|
    public function setParent(self $parent): void
 | 
						|
    {
 | 
						|
        $this->parent = $parent;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Returns the parent profile.
 | 
						|
     */
 | 
						|
    public function getParent(): ?self
 | 
						|
    {
 | 
						|
        return $this->parent;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Returns the parent token.
 | 
						|
     */
 | 
						|
    public function getParentToken(): ?string
 | 
						|
    {
 | 
						|
        return $this->parent?->getToken();
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Returns the IP.
 | 
						|
     */
 | 
						|
    public function getIp(): ?string
 | 
						|
    {
 | 
						|
        return $this->ip;
 | 
						|
    }
 | 
						|
 | 
						|
    public function setIp(?string $ip): void
 | 
						|
    {
 | 
						|
        $this->ip = $ip;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Returns the request method.
 | 
						|
     */
 | 
						|
    public function getMethod(): ?string
 | 
						|
    {
 | 
						|
        return $this->method;
 | 
						|
    }
 | 
						|
 | 
						|
    public function setMethod(string $method): void
 | 
						|
    {
 | 
						|
        $this->method = $method;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Returns the URL.
 | 
						|
     */
 | 
						|
    public function getUrl(): ?string
 | 
						|
    {
 | 
						|
        return $this->url;
 | 
						|
    }
 | 
						|
 | 
						|
    public function setUrl(?string $url): void
 | 
						|
    {
 | 
						|
        $this->url = $url;
 | 
						|
    }
 | 
						|
 | 
						|
    public function getTime(): int
 | 
						|
    {
 | 
						|
        return $this->time ?? 0;
 | 
						|
    }
 | 
						|
 | 
						|
    public function setTime(int $time): void
 | 
						|
    {
 | 
						|
        $this->time = $time;
 | 
						|
    }
 | 
						|
 | 
						|
    public function setStatusCode(int $statusCode): void
 | 
						|
    {
 | 
						|
        $this->statusCode = $statusCode;
 | 
						|
    }
 | 
						|
 | 
						|
    public function getStatusCode(): ?int
 | 
						|
    {
 | 
						|
        return $this->statusCode;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @internal
 | 
						|
     */
 | 
						|
    public function setVirtualType(?string $virtualType): void
 | 
						|
    {
 | 
						|
        $this->virtualType = $virtualType;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @internal
 | 
						|
     */
 | 
						|
    public function getVirtualType(): ?string
 | 
						|
    {
 | 
						|
        return $this->virtualType;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Finds children profilers.
 | 
						|
     *
 | 
						|
     * @return self[]
 | 
						|
     */
 | 
						|
    public function getChildren(): array
 | 
						|
    {
 | 
						|
        return $this->children;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Sets children profiler.
 | 
						|
     *
 | 
						|
     * @param Profile[] $children
 | 
						|
     */
 | 
						|
    public function setChildren(array $children): void
 | 
						|
    {
 | 
						|
        $this->children = [];
 | 
						|
        foreach ($children as $child) {
 | 
						|
            $this->addChild($child);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Adds the child token.
 | 
						|
     */
 | 
						|
    public function addChild(self $child): void
 | 
						|
    {
 | 
						|
        $this->children[] = $child;
 | 
						|
        $child->setParent($this);
 | 
						|
    }
 | 
						|
 | 
						|
    public function getChildByToken(string $token): ?self
 | 
						|
    {
 | 
						|
        foreach ($this->children as $child) {
 | 
						|
            if ($token === $child->getToken()) {
 | 
						|
                return $child;
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        return null;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gets a Collector by name.
 | 
						|
     *
 | 
						|
     * @throws \InvalidArgumentException if the collector does not exist
 | 
						|
     */
 | 
						|
    public function getCollector(string $name): DataCollectorInterface
 | 
						|
    {
 | 
						|
        if (!isset($this->collectors[$name])) {
 | 
						|
            throw new \InvalidArgumentException(\sprintf('Collector "%s" does not exist.', $name));
 | 
						|
        }
 | 
						|
 | 
						|
        return $this->collectors[$name];
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gets the Collectors associated with this profile.
 | 
						|
     *
 | 
						|
     * @return DataCollectorInterface[]
 | 
						|
     */
 | 
						|
    public function getCollectors(): array
 | 
						|
    {
 | 
						|
        return $this->collectors;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Sets the Collectors associated with this profile.
 | 
						|
     *
 | 
						|
     * @param DataCollectorInterface[] $collectors
 | 
						|
     */
 | 
						|
    public function setCollectors(array $collectors): void
 | 
						|
    {
 | 
						|
        $this->collectors = [];
 | 
						|
        foreach ($collectors as $collector) {
 | 
						|
            $this->addCollector($collector);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Adds a Collector.
 | 
						|
     */
 | 
						|
    public function addCollector(DataCollectorInterface $collector): void
 | 
						|
    {
 | 
						|
        $this->collectors[$collector->getName()] = $collector;
 | 
						|
    }
 | 
						|
 | 
						|
    public function hasCollector(string $name): bool
 | 
						|
    {
 | 
						|
        return isset($this->collectors[$name]);
 | 
						|
    }
 | 
						|
 | 
						|
    public function __sleep(): array
 | 
						|
    {
 | 
						|
        return ['token', 'parent', 'children', 'collectors', 'ip', 'method', 'url', 'time', 'statusCode', 'virtualType'];
 | 
						|
    }
 | 
						|
}
 |