| 1 | <?php |
||
| 16 | class AdapterPlugin extends PluginAbstract |
||
| 17 | { |
||
| 18 | /** |
||
| 19 | * @var BenchmarkInterface |
||
| 20 | */ |
||
| 21 | private $benchmark; |
||
| 22 | |||
| 23 | /** |
||
| 24 | * Start the query benchmark |
||
| 25 | * |
||
| 26 | * @param Event $event |
||
| 27 | * @param Adapter $database |
||
| 28 | */ |
||
| 29 | 1 | public function beforeQuery(Event $event, Adapter $database) |
|
| 30 | { |
||
| 31 | $metadata = [ |
||
| 32 | 1 | 'query' => $database->getSQLStatement() |
|
| 33 | 1 | ]; |
|
| 34 | 1 | $params = $database->getSQLVariables(); |
|
| 35 | 1 | if (isset($params)) { |
|
| 36 | 1 | $metadata['params'] = $params; |
|
| 37 | 1 | } |
|
| 38 | 1 | $bindtypes = $database->getSQLBindTypes(); |
|
| 39 | 1 | if (isset($bindtypes)) { |
|
| 40 | 1 | $metadata['bindTypes'] = $bindtypes; |
|
| 41 | 1 | } |
|
| 42 | 1 | $desc = $database->getDescriptor(); |
|
| 43 | 1 | if (isset($desc['dbname'])) { |
|
| 44 | 1 | $metadata['database'] = $desc['dbname']; |
|
| 45 | 1 | } |
|
| 46 | |||
| 47 | 1 | $this->benchmark = $this->getProfiler()->start(get_class($event->getSource()) . '::query', $metadata, 'Database'); |
|
| 48 | 1 | } |
|
| 49 | |||
| 50 | /** |
||
| 51 | * Stop the query benchmark |
||
| 52 | */ |
||
| 53 | 1 | public function afterQuery() |
|
| 57 | } |
||
| 58 |