276 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			276 lines
		
	
	
		
			5.2 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
 | 
						|
{
 | 
						|
    private $token;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var DataCollectorInterface[]
 | 
						|
     */
 | 
						|
    private $collectors = array();
 | 
						|
 | 
						|
    private $ip;
 | 
						|
    private $method;
 | 
						|
    private $url;
 | 
						|
    private $time;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var Profile
 | 
						|
     */
 | 
						|
    private $parent;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var Profile[]
 | 
						|
     */
 | 
						|
    private $children = array();
 | 
						|
 | 
						|
    /**
 | 
						|
     * Constructor.
 | 
						|
     *
 | 
						|
     * @param string $token The token
 | 
						|
     */
 | 
						|
    public function __construct($token)
 | 
						|
    {
 | 
						|
        $this->token = $token;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Sets the token.
 | 
						|
     *
 | 
						|
     * @param string $token The token
 | 
						|
     */
 | 
						|
    public function setToken($token)
 | 
						|
    {
 | 
						|
        $this->token = $token;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gets the token.
 | 
						|
     *
 | 
						|
     * @return string The token
 | 
						|
     */
 | 
						|
    public function getToken()
 | 
						|
    {
 | 
						|
        return $this->token;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Sets the parent token
 | 
						|
     *
 | 
						|
     * @param Profile $parent The parent Profile
 | 
						|
     */
 | 
						|
    public function setParent(Profile $parent)
 | 
						|
    {
 | 
						|
        $this->parent = $parent;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Returns the parent profile.
 | 
						|
     *
 | 
						|
     * @return Profile The parent profile
 | 
						|
     */
 | 
						|
    public function getParent()
 | 
						|
    {
 | 
						|
        return $this->parent;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Returns the parent token.
 | 
						|
     *
 | 
						|
     * @return null|string The parent token
 | 
						|
     */
 | 
						|
    public function getParentToken()
 | 
						|
    {
 | 
						|
        return $this->parent ? $this->parent->getToken() : null;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Returns the IP.
 | 
						|
     *
 | 
						|
     * @return string The IP
 | 
						|
     */
 | 
						|
    public function getIp()
 | 
						|
    {
 | 
						|
        return $this->ip;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Sets the IP.
 | 
						|
     *
 | 
						|
     * @param string $ip
 | 
						|
     */
 | 
						|
    public function setIp($ip)
 | 
						|
    {
 | 
						|
        $this->ip = $ip;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Returns the request method.
 | 
						|
     *
 | 
						|
     * @return string The request method
 | 
						|
     */
 | 
						|
    public function getMethod()
 | 
						|
    {
 | 
						|
        return $this->method;
 | 
						|
    }
 | 
						|
 | 
						|
    public function setMethod($method)
 | 
						|
    {
 | 
						|
        $this->method = $method;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Returns the URL.
 | 
						|
     *
 | 
						|
     * @return string The URL
 | 
						|
     */
 | 
						|
    public function getUrl()
 | 
						|
    {
 | 
						|
        return $this->url;
 | 
						|
    }
 | 
						|
 | 
						|
    public function setUrl($url)
 | 
						|
    {
 | 
						|
        $this->url = $url;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Returns the time.
 | 
						|
     *
 | 
						|
     * @return string The time
 | 
						|
     */
 | 
						|
    public function getTime()
 | 
						|
    {
 | 
						|
        if (null === $this->time) {
 | 
						|
            return 0;
 | 
						|
        }
 | 
						|
 | 
						|
        return $this->time;
 | 
						|
    }
 | 
						|
 | 
						|
    public function setTime($time)
 | 
						|
    {
 | 
						|
        $this->time = $time;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Finds children profilers.
 | 
						|
     *
 | 
						|
     * @return Profile[] An array of Profile
 | 
						|
     */
 | 
						|
    public function getChildren()
 | 
						|
    {
 | 
						|
        return $this->children;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Sets children profiler.
 | 
						|
     *
 | 
						|
     * @param Profile[] $children An array of Profile
 | 
						|
     */
 | 
						|
    public function setChildren(array $children)
 | 
						|
    {
 | 
						|
        $this->children = array();
 | 
						|
        foreach ($children as $child) {
 | 
						|
            $this->addChild($child);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Adds the child token
 | 
						|
     *
 | 
						|
     * @param Profile $child The child Profile
 | 
						|
     */
 | 
						|
    public function addChild(Profile $child)
 | 
						|
    {
 | 
						|
        $this->children[] = $child;
 | 
						|
        $child->setParent($this);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gets a Collector by name.
 | 
						|
     *
 | 
						|
     * @param string $name A collector name
 | 
						|
     *
 | 
						|
     * @return DataCollectorInterface A DataCollectorInterface instance
 | 
						|
     *
 | 
						|
     * @throws \InvalidArgumentException if the collector does not exist
 | 
						|
     */
 | 
						|
    public function getCollector($name)
 | 
						|
    {
 | 
						|
        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()
 | 
						|
    {
 | 
						|
        return $this->collectors;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Sets the Collectors associated with this profile.
 | 
						|
     *
 | 
						|
     * @param DataCollectorInterface[] $collectors
 | 
						|
     */
 | 
						|
    public function setCollectors(array $collectors)
 | 
						|
    {
 | 
						|
        $this->collectors = array();
 | 
						|
        foreach ($collectors as $collector) {
 | 
						|
            $this->addCollector($collector);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Adds a Collector.
 | 
						|
     *
 | 
						|
     * @param DataCollectorInterface $collector A DataCollectorInterface instance
 | 
						|
     */
 | 
						|
    public function addCollector(DataCollectorInterface $collector)
 | 
						|
    {
 | 
						|
        $this->collectors[$collector->getName()] = $collector;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Returns true if a Collector for the given name exists.
 | 
						|
     *
 | 
						|
     * @param string $name A collector name
 | 
						|
     *
 | 
						|
     * @return Boolean
 | 
						|
     */
 | 
						|
    public function hasCollector($name)
 | 
						|
    {
 | 
						|
        return isset($this->collectors[$name]);
 | 
						|
    }
 | 
						|
 | 
						|
    public function __sleep()
 | 
						|
    {
 | 
						|
        return array('token', 'parent', 'children', 'collectors', 'ip', 'method', 'url', 'time');
 | 
						|
    }
 | 
						|
}
 |