Passed
Push — master ( 441645...db9692 )
by Thomas
08:54
created

CacheAfterCallAspect::afterCall()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 10
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 2
eloc 8
nc 2
nop 4
dl 0
loc 10
rs 10
c 0
b 0
f 0
1
<?php
2
3
namespace LeKoala\DebugBar\Aspects;
4
5
use LeKoala\DebugBar\Collector\PartialCacheCollector;
6
use SilverStripe\Core\Convert;
7
use SilverStripe\Core\Injector\AfterCallAspect;
8
9
class CacheAfterCallAspect implements AfterCallAspect
10
{
11
    /**
12
     * Logs all hits/misses after a CacheInterface::get call is made.
13
     *
14
     * {@inheritdoc}
15
     */
16
    public function afterCall($proxied, $method, $args, $result)
17
    {
18
        $message = (empty($result)) ? "Missed: {$args[0]}" : "Hit: {$args[0]}";
19
        $result = preg_replace('/\s+/', ' ', trim($result));
20
        $result = Convert::raw2att($result);
21
        PartialCacheCollector::addTemplateCache(
22
            $message,
23
            array(
24
                'cache_result' =>
25
                    array('result' => $result)
26
            )
27
        );
28
    }
29
}
30