Completed
Pull Request — master (#78)
by Franco
01:33
created

CacheAfterCallAspect::afterCall()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 11
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

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