2021-11-18 17:44:47 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Kirby\Panel;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The Json abstract response class provides
|
|
|
|
* common framework for Fiber requests
|
|
|
|
* to render the JSON object for, e.g.
|
|
|
|
* Panel dialogs, dropdowns etc.
|
|
|
|
* @since 3.6.0
|
|
|
|
*
|
|
|
|
* @package Kirby Panel
|
|
|
|
* @author Bastian Allgeier <bastian@getkirby.com>
|
|
|
|
* @link https://getkirby.com
|
2022-03-22 15:39:39 +01:00
|
|
|
* @copyright Bastian Allgeier
|
2021-11-18 17:44:47 +01:00
|
|
|
* @license https://getkirby.com/license
|
|
|
|
*/
|
|
|
|
abstract class Json
|
|
|
|
{
|
|
|
|
protected static $key = '$response';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Renders the error response with the provided message
|
|
|
|
*
|
|
|
|
* @param string $message
|
|
|
|
* @param int $code
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public static function error(string $message, int $code = 404)
|
|
|
|
{
|
|
|
|
return [
|
|
|
|
'code' => $code,
|
|
|
|
'error' => $message
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Prepares the JSON response for the Panel
|
|
|
|
*
|
|
|
|
* @param mixed $data
|
|
|
|
* @param array $options
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public static function response($data, array $options = [])
|
|
|
|
{
|
|
|
|
// handle redirects
|
|
|
|
if (is_a($data, 'Kirby\Panel\Redirect') === true) {
|
|
|
|
$data = [
|
|
|
|
'redirect' => $data->location(),
|
|
|
|
'code' => $data->code()
|
|
|
|
];
|
|
|
|
|
|
|
|
// handle Kirby exceptions
|
|
|
|
} elseif (is_a($data, 'Kirby\Exception\Exception') === true) {
|
|
|
|
$data = static::error($data->getMessage(), $data->getHttpCode());
|
|
|
|
|
|
|
|
// handle exceptions
|
|
|
|
} elseif (is_a($data, 'Throwable') === true) {
|
|
|
|
$data = static::error($data->getMessage(), 500);
|
|
|
|
|
|
|
|
// only expect arrays from here on
|
|
|
|
} elseif (is_array($data) === false) {
|
|
|
|
$data = static::error('Invalid response', 500);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (empty($data) === true) {
|
|
|
|
$data = static::error('The response is empty', 404);
|
|
|
|
}
|
|
|
|
|
|
|
|
// always inject the response code
|
2022-03-22 15:39:39 +01:00
|
|
|
$data['code'] ??= 200;
|
2021-11-18 17:44:47 +01:00
|
|
|
$data['path'] = $options['path'] ?? null;
|
|
|
|
$data['referrer'] = Panel::referrer();
|
|
|
|
|
|
|
|
return Panel::json([static::$key => $data], $data['code']);
|
|
|
|
}
|
|
|
|
}
|