/var/www/hkosl.com/imusiccircle/webadmin/libraies/filp/whoops/src/Whoops/Handler/JsonResponseHandler.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
<?php
/**
 * Whoops - php errors for cool kids
 * @author Filipe Dobreira <http://github.com/filp>
 */

namespace Whoops\Handler;

use 
Whoops\Exception\Formatter;

/**
 * Catches an exception and converts it to a JSON
 * response. Additionally can also return exception
 * frames for consumption by an API.
 */
class JsonResponseHandler extends Handler
{
    
/**
     * @var bool
     */
    
private $returnFrames false;

    
/**
     * @param  bool|null  $returnFrames
     * @return bool|$this
     */
    
public function addTraceToOutput($returnFrames null)
    {
        if (
func_num_args() == 0) {
            return 
$this->returnFrames;
        }

        
$this->returnFrames = (bool) $returnFrames;
        return 
$this;
    }

    
/**
     * @return int
     */
    
public function handle()
    {
        
$response = array(
            
'error' => Formatter::formatExceptionAsDataArray(
                
$this->getInspector(),
                
$this->addTraceToOutput()
            ),
        );

        if (\
Whoops\Util\Misc::canSendHeaders()) {
            
header('Content-Type: application/json');
        }

        echo 
json_encode($responsedefined('JSON_PARTIAL_OUTPUT_ON_ERROR') ? JSON_PARTIAL_OUTPUT_ON_ERROR 0);

        return 
Handler::QUIT;
    }
}