/**
  * @return mixed get the data to be serialized
  */
 public function getData()
 {
     $queries = $duplicates = array();
     $queryTotals = array('count' => 0, 'time' => 0);
     if (count(DB::getConnections())) {
         $threshold = Config::get('slow_query');
         foreach (DB::getQueryLog() as $query) {
             $queryTotals['count'] += 1;
             //base informations
             $query['sql'] = str_replace("\n", '', $query['query']);
             $queryTotals['time'] += $query['time'];
             //duplicate queries
             $query['sql_simplified'] = $this->simplifiedQuery($query['sql']);
             if (array_key_exists($query['sql_simplified'], $duplicates)) {
                 $duplicates[$query['sql_simplified']]['time'] += $query['time'];
                 $duplicates[$query['sql_simplified']]['qty']++;
             } else {
                 $duplicates[$query['sql_simplified']] = array('time' => $query['time'], 'qty' => 1);
             }
             if ($query['time'] >= $threshold) {
                 $query['slow'] = 'slow';
             }
             //TODO :: slow query threshold
             //TODO :: implement "explain"
             $queries[] = $query;
         }
     }
     foreach ($duplicates as $query => $duplicate) {
         if ($duplicate['qty'] == 1) {
             unset($duplicates[$query]);
         }
     }
     return array('database' => array('queries' => $queries, 'duplicates' => $duplicates, 'popup' => array('Total Queries' => $queryTotals['count'], 'Total Time' => Utils::getReadableTime($queryTotals['time']))));
 }
Example #2
0
 /**
  * @return mixed get the data to be serialized
  */
 public function getData()
 {
     //this may happen in case of early termination
     if (empty($this->data)) {
         $this->register();
     }
     $this->data['events'] = Stopwatch::getEvents();
     //In some cases the start time can be calculated wrong, in this case we take the first timer's origin
     $stopwatchStartTime = current($this->data['events']);
     if ($stopwatchStartTime->getOrigin() / 1000 < $this->data['appStartTime']) {
         $this->data['appStartTime'] = $stopwatchStartTime->getOrigin() / 1000;
     }
     $this->data['totalTime'] = microtime(true) - $this->data['appStartTime'];
     $this->data['popup'] = array('Load time' => Utils::getReadableTime($this->data['totalTime'] * 1000), 'Max time' => Utils::getReadableTime(ini_get('max_execution_time') * 1000));
     return array('time' => $this->data);
 }
Example #3
0
 /**
  * @return mixed get the data to be serialized
  */
 public function getData()
 {
     $files = get_included_files();
     $fileList = array();
     $largestFile = 0;
     $totalSize = 0;
     foreach ($files as $file) {
         if (file_exists($file)) {
             $size = filesize($file);
         } else {
             $size = 0;
         }
         $fileList[] = array('name' => Utils::path($file), 'size' => $size);
         $totalSize += $size;
         if ($size > $largestFile) {
             $largestFile = $size;
         }
     }
     return array('files' => array('list' => $fileList, 'popup' => array("Total Files" => count($files), "Total Size" => Utils::getReadableSize($totalSize), "Largest File" => Utils::getReadableSize($largestFile))));
 }
Example #4
0
<h2>Files</h2>

<?php 
if (empty($files)) {
    ?>
    <h3>No loaded files.</h3>
<?php 
} else {
    ?>
    <table class="op-table">
    <?php 
    foreach ($files as $file) {
        ?>
        <tr><td><span class="indicator"><?php 
        echo \Onigoetz\Profiler\Utils::getReadableSize($file['size']);
        ?>
</span> <?php 
        echo $file['name'];
        ?>
</td></tr>
        <?php 
    }
    ?>
    </table>
<?php 
}
Example #5
0
    if (count($duplicates)) {
        ?>
        <table class="op-table">
            <?php 
        foreach ($duplicates as $sql => $query) {
            ?>
                <tr>
                    <td class="query <?php 
            array_key_exists('slow', $query) ? $query['slow'] : '';
            ?>
>
                    <span class=" indicator"><?php 
            echo $query['qty'];
            ?>
&times; (Total <?php 
            echo \Onigoetz\Profiler\Utils::getReadableTime($query['time']);
            ?>
)</span>
                    <pre><?php 
            echo $sql;
            ?>
</pre>
                    </td>
                </tr>
            <?php 
        }
        ?>
        </table>
    <?php 
    } else {
        ?>
 public function onCloseHeaders(Request $request, Response $response)
 {
     try {
         $this->app['stopwatch']->stop('Framework running.');
     } catch (\LogicException $e) {
         //no problem here, this event might not be started
     }
     //Generate data anyway
     $this->collectors->generateData();
     $this->collectors->saveData();
     $time = '';
     $time_collector = $this->collectors->getData();
     if (array_key_exists('time', $time_collector)) {
         $time = Utils::getReadableTime($time_collector['time']['totalTime'] * 1000);
     }
     $response->headers->add(array('X-Profile-env' => $this->app->environment(), 'X-Profile-time' => $time));
 }
Example #7
0
    };
    return View::render($view_path . '/panels/variables.php', array('variables' => $data['variables'], 'e' => $e));
}, 'title' => function ($data, $icon) {
    return new PanelTitle('Variables');
}));
Panels::register(array('name' => 'database', 'datasource' => array('database'), 'icon' => "", 'panel' => function ($data) use($view_path) {
    return View::render($view_path . '/panels/database.php', $data['database']);
}, 'title' => function ($data, $icon) {
    return new PanelTitle($data['database']['popup']['Total Queries'], $icon, $data['database']['popup']);
}));
Panels::register(array('name' => 'files', 'datasource' => array('files'), 'icon' => "", 'panel' => function ($data) use($view_path) {
    return View::render($view_path . '/panels/files.php', array('files' => $data['files']['list']));
}, 'title' => function ($data, $icon) {
    return new PanelTitle($data['files']['popup']["Total Files"], $icon, $data['files']['popup']);
}));
Panels::register(array('name' => 'monolog', 'datasource' => array('monolog'), 'icon' => "", 'panel' => function ($data) use($view_path) {
    return View::render($view_path . '/panels/monolog.php', array('logs' => $data['monolog']['logs'], 'logger' => $data['monolog']['logger']));
}, 'title' => function ($data, $icon) {
    return new PanelTitle(count($data['monolog']['logs']), $icon);
}));
Panels::register(array('name' => 'router', 'datasource' => array('router'), 'icon' => '', 'panel' => function ($data) use($view_path) {
    return View::render($view_path . '/panels/router.php', array('routes' => $data['router']));
}, 'title' => function ($data, $icon) {
    $popup = array('Routes' => count($data['router']['routes']));
    return new PanelTitle('Routes', $icon, $popup);
}));
Panels::register(array('name' => 'time', 'datasource' => array('time'), 'icon' => '', 'panel' => function ($data) use($view_path) {
    return View::render($view_path . '/panels/time.php', array('events' => $data['time']['events']));
}, 'title' => function ($data, $icon) {
    return new PanelTitle(Utils::getReadableTime($data['time']['totalTime'] * 1000), $icon, $data['time']['popup']);
}));