Passed
Push — master ( 182ddb...cf05b0 )
by Gaetano
07:26
created

DeprecationLogger::logDeprecationUnlessCalledBy()   A

Complexity

Conditions 3
Paths 3

Size

Total Lines 14
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 3
eloc 7
c 0
b 0
f 0
nc 3
nop 1
dl 0
loc 14
rs 10
1
<?php
2
3
namespace PhpXmlRpc\Traits;
4
5
use PhpXmlRpc\PhpXmlRpc;
6
7
trait DeprecationLogger
8
{
9
    use LoggerAware;
10
11
    protected function logDeprecation($message)
12
    {
13
        if (PhpXmlRpc::$xmlrpc_silence_deprecations) {
14
            return;
15
        }
16
17
        $this->getLogger()->warning('XML-RPC Deprecated: ' . $message);
18
    }
19
20
    /**
21
     * @param string $callee
22
     * @param string $expectedCaller atm only the method name is supported
23
     * @return void
24
     */
25
    protected function logDeprecationUnlessCalledBy($expectedCaller)
26
    {
27
        if (PhpXmlRpc::$xmlrpc_silence_deprecations) {
28
            return;
29
        }
30
31
        $trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 3);
32
        /// @todo we should check as well $trace[2]['class'], and make sure that it is a descendent of the class passed in in $expectedCaller
33
        if ($trace[2]['function'] === $expectedCaller) {
34
            return;
35
        }
36
37
        $this->getLogger()->warning('XML-RPC Deprecated: ' . $trace[1]['class'] . '::' . $trace[1]['function'] .
38
            ' is only supposed to be called by ' . $expectedCaller);
39
    }
40
}
41