mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-24 02:13:15 +00:00
160 lines
6.6 KiB
PHP
160 lines
6.6 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of Phraseanet
|
|
*
|
|
* (c) 2005-2015 Alchemy
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Alchemy\Phrasea\Application;
|
|
|
|
use Alchemy\Phrasea\Application as PhraseaApplication;
|
|
use Alchemy\Phrasea\Controller\Api\Result;
|
|
use Alchemy\Phrasea\ControllerProvider\Api\OAuth2;
|
|
use Alchemy\Phrasea\ControllerProvider\Api\V1;
|
|
use Alchemy\Phrasea\ControllerProvider\Datafiles;
|
|
use Alchemy\Phrasea\ControllerProvider\MediaAccessor;
|
|
use Alchemy\Phrasea\ControllerProvider\Minifier;
|
|
use Alchemy\Phrasea\ControllerProvider\Permalink;
|
|
use Alchemy\Phrasea\Core\Event\ApiResultEvent;
|
|
use Alchemy\Phrasea\Core\Event\Subscriber\ApiCorsSubscriber;
|
|
use Alchemy\Phrasea\Core\Event\Subscriber\ApiExceptionHandlerSubscriber;
|
|
use Alchemy\Phrasea\Core\Event\Subscriber\ApiOauth2ErrorsSubscriber;
|
|
use Alchemy\Phrasea\Core\PhraseaEvents;
|
|
use Alchemy\Phrasea\Core\Provider\JsonSchemaServiceProvider;
|
|
use Monolog\Logger;
|
|
use Monolog\Processor\WebProcessor;
|
|
use Silex\Application as SilexApplication;
|
|
use Silex\Provider\WebProfilerServiceProvider;
|
|
use Sorien\Provider\DoctrineProfilerServiceProvider;
|
|
use Symfony\Component\HttpFoundation\Request;
|
|
use Symfony\Component\HttpFoundation\Response;
|
|
|
|
return call_user_func(function ($environment = PhraseaApplication::ENV_PROD) {
|
|
$app = new PhraseaApplication($environment);
|
|
|
|
$app->register(new OAuth2());
|
|
$app->register(new V1());
|
|
$app->loadPlugins();
|
|
|
|
$app['exception_handler'] = $app->share(function ($app) {
|
|
$handler = new ApiExceptionHandlerSubscriber($app);
|
|
$handler->setLogger($app['monolog']);
|
|
|
|
return $handler;
|
|
});
|
|
$app['monolog'] = $app->share($app->extend('monolog', function (Logger $monolog) {
|
|
$monolog->pushProcessor(new WebProcessor());
|
|
|
|
return $monolog;
|
|
}));
|
|
|
|
// handle API content negotiation
|
|
$app->before(function(Request $request) use ($app) {
|
|
// register custom API format
|
|
$request->setFormat(Result::FORMAT_JSON_EXTENDED, V1::$extendedContentTypes['json']);
|
|
$request->setFormat(Result::FORMAT_YAML_EXTENDED, V1::$extendedContentTypes['yaml']);
|
|
$request->setFormat(Result::FORMAT_JSONP_EXTENDED, V1::$extendedContentTypes['jsonp']);
|
|
$request->setFormat(Result::FORMAT_JSONP, array('text/javascript', 'application/javascript'));
|
|
|
|
$format = $app['format.negotiator']->getBest(
|
|
$request->headers->get('accept', 'application/json'),
|
|
array_merge(
|
|
['application/json', 'application/yaml', 'text/yaml', 'text/javascript', 'application/javascript'],
|
|
V1::$extendedContentTypes['json'],
|
|
V1::$extendedContentTypes['yaml']
|
|
)
|
|
);
|
|
|
|
// throw unacceptable http error if API can not handle asked format
|
|
if (null === $format) {
|
|
$app->abort(406);
|
|
}
|
|
// set request format according to negotiated content or override format with JSONP if callback parameter is defined
|
|
if (trim($request->get('callback')) !== '') {
|
|
$request->setRequestFormat(Result::FORMAT_JSONP);
|
|
} else {
|
|
$request->setRequestFormat($request->getFormat($format->getValue()));
|
|
}
|
|
|
|
// tells whether asked format is extended or not
|
|
$request->attributes->set('_extended', in_array(
|
|
$request->getRequestFormat(Result::FORMAT_JSON),
|
|
array(
|
|
Result::FORMAT_JSON_EXTENDED,
|
|
Result::FORMAT_YAML_EXTENDED,
|
|
Result::FORMAT_JSONP_EXTENDED
|
|
)
|
|
));
|
|
}, PhraseaApplication::EARLY_EVENT);
|
|
|
|
$app->after(function(Request $request, Response $response) use ($app) {
|
|
if ($request->getRequestFormat(Result::FORMAT_JSON) === Result::FORMAT_JSONP && !$response->isOk() && !$response->isServerError()) {
|
|
$response->setStatusCode(200);
|
|
}
|
|
|
|
// set response content type
|
|
if (!$response->headers->get('Content-Type')) {
|
|
$response->headers->set('Content-Type', $request->getMimeType($request->getRequestFormat(Result::FORMAT_JSON)));
|
|
}
|
|
});
|
|
|
|
$app->register(new JsonSchemaServiceProvider());
|
|
$app->get('/api/', function (Request $request, SilexApplication $app) {
|
|
return Result::create($request, [
|
|
'name' => $app['conf']->get(['registry', 'general', 'title']),
|
|
'type' => 'phraseanet',
|
|
'description' => $app['conf']->get(['registry', 'general', 'description']),
|
|
'documentation' => 'https://docs.phraseanet.com/Devel',
|
|
'versions' => [
|
|
'1' => [
|
|
'number' => V1::VERSION,
|
|
'uri' => '/api/v1/',
|
|
'authenticationProtocol' => 'OAuth2',
|
|
'authenticationVersion' => 'draft#v9',
|
|
'authenticationEndPoints' => [
|
|
'authorization_token' => '/api/oauthv2/authorize',
|
|
'access_token' => '/api/oauthv2/token'
|
|
]
|
|
]
|
|
]
|
|
])->createResponse();
|
|
});
|
|
|
|
$app->mount('/api/oauthv2', new OAuth2());
|
|
$app->mount('/datafiles/', new Datafiles());
|
|
$app->mount('/api/v1', new V1());
|
|
$app->mount('/permalink/', new Permalink());
|
|
$app->mount($app['controller.media_accessor.route_prefix'], new MediaAccessor());
|
|
$app->mount('/include/minify/', new Minifier());
|
|
|
|
if (PhraseaApplication::ENV_DEV === $app->getEnvironment()) {
|
|
$app->register($p = new WebProfilerServiceProvider(), [
|
|
'profiler.cache_dir' => $app['cache.path'].'/profiler',
|
|
]);
|
|
$app->mount('/_profiler', $p);
|
|
|
|
if ($app['phraseanet.configuration-tester']->isInstalled()) {
|
|
$app->register(new DoctrineProfilerServiceProvider());
|
|
$app['db'] = $app->share(function (PhraseaApplication $app) {
|
|
return $app['orm.em']->getConnection();
|
|
});
|
|
}
|
|
}
|
|
|
|
$app['dispatcher'] = $app->share($app->extend('dispatcher', function ($dispatcher, PhraseaApplication $app) {
|
|
$dispatcher->addSubscriber(new ApiOauth2ErrorsSubscriber($app['phraseanet.exception_handler'], $app['translator']));
|
|
|
|
return $dispatcher;
|
|
}));
|
|
$app->after(function (Request $request, Response $response) use ($app) {
|
|
$app['dispatcher']->dispatch(PhraseaEvents::API_RESULT, new ApiResultEvent($request, $response));
|
|
});
|
|
$app['dispatcher']->addSubscriber(new ApiCorsSubscriber($app));
|
|
|
|
return $app;
|
|
}, isset($environment) ? $environment : PhraseaApplication::ENV_PROD);
|