1
0
Fork 0
mirror of synced 2024-07-01 04:30:59 +12:00
appwrite/app/controllers/api/graphql.php

85 lines
3 KiB
PHP
Raw Normal View History

2020-01-04 10:16:26 +13:00
<?php
2020-06-23 00:04:19 +12:00
use GraphQL\GraphQL;
2021-03-13 08:00:43 +13:00
use GraphQL\Type;
use Appwrite\Utopia\Response;
2021-03-17 02:34:11 +13:00
use GraphQL\Error\DebugFlag;
2021-03-11 02:51:03 +13:00
use GraphQL\Error\Error;
use GraphQL\Error\FormattedError;
2020-06-29 05:31:21 +12:00
use Utopia\App;
2020-01-04 10:16:26 +13:00
2021-03-05 07:40:52 +13:00
App::post('/v1/graphql')
->desc('GraphQL Endpoint')
2021-03-05 07:40:52 +13:00
->label('scope', 'graphql')
->inject('request')
->inject('response')
2021-03-10 20:42:45 +13:00
->inject('schema')
2021-03-11 04:22:19 +13:00
->inject('utopia')
->inject('register')
->middleware(true)
2021-03-11 04:22:19 +13:00
->action(function ($request, $response, $schema, $utopia, $register) {
2021-03-13 08:00:43 +13:00
/** @var Utopia\Swoole\Request $request */
/** @var Appwrite\Utopia\Response $response */
/** @var Type\Schema $schema */
/** @var Utopia\App $utopia */
/** @var Utopia\Registry\Registry $register */
2021-03-05 07:40:52 +13:00
2021-03-12 04:44:04 +13:00
$myErrorFormatter = function(Error $error) {
$formattedError = FormattedError::createFromException($error);
// var_dump("***** IN ERROR FORMATTER ******");
// var_dump("{$error->getMessage()}");
// var_dump("{$error->getCode()}");
// var_dump("{$error->getFile()}");
// var_dump("{$error->getLine()}");
// var_dump("{$error->getTrace()}");
$formattedError['code'] = $error->getCode();
$formattedError['file'] = $error->getFile();
$formattedError['line'] = $error->getLine();
// $formattedError['trace'] = $error->getTrace();
2021-03-12 04:44:04 +13:00
return $formattedError;
};
$myErrorHandler = function(array $errors, callable $formatter) {
// $errors = array_map( function ($error) {
// unset($error['trace']);
// },$errors);
// var_dump("**** In My Error Handler *****");
// var_dump($errors);
return array_map($formatter, $errors);
};
2021-03-11 02:51:03 +13:00
$query = $request->getPayload('query', '');
$variables = $request->getPayload('variables', null);
$response->setContentType(Response::CONTENT_TYPE_NULL);
2021-03-11 04:22:19 +13:00
$register->set('__app', function() use ($utopia) {
return $utopia;
});
$register->set('__response', function() use ($response) {
return $response;
});
2021-03-11 02:51:03 +13:00
try {
2021-03-17 02:34:11 +13:00
$debug = DebugFlag::INCLUDE_DEBUG_MESSAGE | DebugFlag::INCLUDE_TRACE;
2021-03-11 02:51:03 +13:00
$rootValue = [];
$result = GraphQL::executeQuery($schema, $query, $rootValue, null, $variables)->setErrorFormatter($myErrorFormatter)->setErrorsHandler($myErrorHandler);
2021-03-17 02:34:11 +13:00
$output = $result->toArray($debug);
2021-03-11 02:51:03 +13:00
} catch (\Exception $error) {
$output = [
'errors' => [
[
'message' => $error->getMessage().'xxx',
'code' => $error->getCode(),
'file' => $error->getFile(),
'line' => $error->getLine(),
'trace' => $error->getTrace(),
2020-06-23 00:04:19 +12:00
]
2021-03-11 02:51:03 +13:00
]
];
}
$response->json($output);
2020-01-04 10:16:26 +13:00
}
2021-03-05 07:40:52 +13:00
);