mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-08-23 16:13:50 +00:00
apply more cs rules for php-cs
This commit is contained in:
@@ -11,20 +11,11 @@ declare(strict_types=1);
|
||||
|
||||
namespace Chill\MainBundle\CRUD\Routing;
|
||||
|
||||
use RuntimeException;
|
||||
use Symfony\Component\Config\Loader\Loader;
|
||||
use Symfony\Component\HttpFoundation\Request;
|
||||
use Symfony\Component\Routing\Route;
|
||||
use Symfony\Component\Routing\RouteCollection;
|
||||
|
||||
use function array_filter;
|
||||
use function array_keys;
|
||||
use function array_search;
|
||||
use function count;
|
||||
use function in_array;
|
||||
|
||||
use const ARRAY_FILTER_USE_BOTH;
|
||||
|
||||
class CRUDRoutesLoader extends Loader
|
||||
{
|
||||
private const ALL_INDEX_METHODS = [Request::METHOD_GET, Request::METHOD_HEAD];
|
||||
@@ -46,13 +37,12 @@ class CRUDRoutesLoader extends Loader
|
||||
/**
|
||||
* Load routes for CRUD and CRUD Api.
|
||||
*
|
||||
* @param mixed $resource
|
||||
* @param mixed|null $type
|
||||
*/
|
||||
public function load($resource, $type = null): RouteCollection
|
||||
{
|
||||
if (true === $this->isLoaded) {
|
||||
throw new RuntimeException('Do not add the "CRUD" loader twice');
|
||||
throw new \RuntimeException('Do not add the "CRUD" loader twice');
|
||||
}
|
||||
|
||||
$collection = new RouteCollection();
|
||||
@@ -69,7 +59,6 @@ class CRUDRoutesLoader extends Loader
|
||||
}
|
||||
|
||||
/**
|
||||
* @param mixed $resource
|
||||
* @param null $type
|
||||
*
|
||||
* @return bool
|
||||
@@ -81,13 +70,11 @@ class CRUDRoutesLoader extends Loader
|
||||
|
||||
/**
|
||||
* Load routes for api single.
|
||||
*
|
||||
* @param $crudConfig
|
||||
*/
|
||||
protected function loadApi(array $crudConfig): RouteCollection
|
||||
{
|
||||
$collection = new RouteCollection();
|
||||
$controller = 'csapi_' . $crudConfig['name'] . '_controller';
|
||||
$controller = 'csapi_'.$crudConfig['name'].'_controller';
|
||||
|
||||
foreach ($crudConfig['actions'] as $name => $action) {
|
||||
// filter only on single actions
|
||||
@@ -100,40 +87,38 @@ class CRUDRoutesLoader extends Loader
|
||||
$controllerAction = match ($name) {
|
||||
'_entity' => 'entityApi',
|
||||
'_index' => 'indexApi',
|
||||
default => $name . 'Api',
|
||||
default => $name.'Api',
|
||||
};
|
||||
|
||||
$defaults = [
|
||||
'_controller' => $controller . ':' . ($action['controller_action'] ?? $controllerAction),
|
||||
'_controller' => $controller.':'.($action['controller_action'] ?? $controllerAction),
|
||||
];
|
||||
|
||||
// path are rewritten
|
||||
// if name === 'default', we rewrite it to nothing :-)
|
||||
$localName = in_array($name, ['_entity', '_index'], true) ? '' : '/' . $name;
|
||||
$localName = \in_array($name, ['_entity', '_index'], true) ? '' : '/'.$name;
|
||||
|
||||
if ('collection' === $action['single_collection'] || '_index' === $name) {
|
||||
$localPath = $action['path'] ?? $localName . '.{_format}';
|
||||
$localPath = $action['path'] ?? $localName.'.{_format}';
|
||||
} else {
|
||||
$localPath = $action['path'] ?? '/{id}' . $localName . '.{_format}';
|
||||
$localPath = $action['path'] ?? '/{id}'.$localName.'.{_format}';
|
||||
}
|
||||
$path = $crudConfig['base_path'] . $localPath;
|
||||
$path = $crudConfig['base_path'].$localPath;
|
||||
|
||||
$requirements = $action['requirements'] ?? ['{id}' => '\d+'];
|
||||
|
||||
$methods = array_keys(array_filter(
|
||||
$methods = \array_keys(\array_filter(
|
||||
$action['methods'],
|
||||
static fn ($value, $key) => $value,
|
||||
ARRAY_FILTER_USE_BOTH
|
||||
\ARRAY_FILTER_USE_BOTH
|
||||
));
|
||||
|
||||
if (count($methods) === 0) {
|
||||
throw new RuntimeException("The api configuration named \"{$crudConfig['name']}\", action \"{$name}\", " .
|
||||
'does not have any allowed methods. You should remove this action from the config ' .
|
||||
'or allow, at least, one method');
|
||||
if (0 === \count($methods)) {
|
||||
throw new \RuntimeException("The api configuration named \"{$crudConfig['name']}\", action \"{$name}\", ".'does not have any allowed methods. You should remove this action from the config or allow, at least, one method');
|
||||
}
|
||||
|
||||
if ('_entity' === $name && in_array(Request::METHOD_POST, $methods, true)) {
|
||||
unset($methods[array_search(Request::METHOD_POST, $methods, true)]);
|
||||
if ('_entity' === $name && \in_array(Request::METHOD_POST, $methods, true)) {
|
||||
unset($methods[\array_search(Request::METHOD_POST, $methods, true)]);
|
||||
$entityPostRoute = $this->createEntityPostRoute(
|
||||
$name,
|
||||
$crudConfig,
|
||||
@@ -146,7 +131,7 @@ class CRUDRoutesLoader extends Loader
|
||||
);
|
||||
}
|
||||
|
||||
if (count($methods) === 0) {
|
||||
if (0 === \count($methods)) {
|
||||
// the only method was POST,
|
||||
// continue to next
|
||||
continue;
|
||||
@@ -155,7 +140,7 @@ class CRUDRoutesLoader extends Loader
|
||||
$route = new Route($path, $defaults, $requirements);
|
||||
$route->setMethods($methods);
|
||||
|
||||
$collection->add('chill_api_single_' . $crudConfig['name'] . '_' . $name, $route);
|
||||
$collection->add('chill_api_single_'.$crudConfig['name'].'_'.$name, $route);
|
||||
}
|
||||
|
||||
return $collection;
|
||||
@@ -163,35 +148,33 @@ class CRUDRoutesLoader extends Loader
|
||||
|
||||
/**
|
||||
* Load routes for CRUD (without api).
|
||||
*
|
||||
* @param $crudConfig
|
||||
*/
|
||||
protected function loadCrudConfig($crudConfig): RouteCollection
|
||||
{
|
||||
$collection = new RouteCollection();
|
||||
$controller = 'cscrud_' . $crudConfig['name'] . '_controller';
|
||||
$controller = 'cscrud_'.$crudConfig['name'].'_controller';
|
||||
|
||||
foreach ($crudConfig['actions'] as $name => $action) {
|
||||
// defaults (controller name)
|
||||
$defaults = [
|
||||
'_controller' => $controller . ':' . ($action['controller_action'] ?? $name),
|
||||
'_controller' => $controller.':'.($action['controller_action'] ?? $name),
|
||||
];
|
||||
|
||||
if ('index' === $name) {
|
||||
$path = '{_locale}' . $crudConfig['base_path'];
|
||||
$path = '{_locale}'.$crudConfig['base_path'];
|
||||
$route = new Route($path, $defaults);
|
||||
} elseif ('new' === $name) {
|
||||
$path = '{_locale}' . $crudConfig['base_path'] . '/' . $name;
|
||||
$path = '{_locale}'.$crudConfig['base_path'].'/'.$name;
|
||||
$route = new Route($path, $defaults);
|
||||
} else {
|
||||
$path = '{_locale}' . $crudConfig['base_path'] . ($action['path'] ?? '/{id}/' . $name);
|
||||
$path = '{_locale}'.$crudConfig['base_path'].($action['path'] ?? '/{id}/'.$name);
|
||||
$requirements = $action['requirements'] ?? [
|
||||
'{id}' => '\d+',
|
||||
];
|
||||
$route = new Route($path, $defaults, $requirements);
|
||||
}
|
||||
|
||||
$collection->add('chill_crud_' . $crudConfig['name'] . '_' . $name, $route);
|
||||
$collection->add('chill_crud_'.$crudConfig['name'].'_'.$name, $route);
|
||||
}
|
||||
|
||||
return $collection;
|
||||
@@ -199,11 +182,11 @@ class CRUDRoutesLoader extends Loader
|
||||
|
||||
private function createEntityPostRoute(string $name, $crudConfig, array $action, $controller): Route
|
||||
{
|
||||
$localPath = $action['path'] . '.{_format}';
|
||||
$localPath = $action['path'].'.{_format}';
|
||||
$defaults = [
|
||||
'_controller' => $controller . ':' . ($action['controller_action'] ?? 'entityPost'),
|
||||
'_controller' => $controller.':'.($action['controller_action'] ?? 'entityPost'),
|
||||
];
|
||||
$path = $crudConfig['base_path'] . $localPath;
|
||||
$path = $crudConfig['base_path'].$localPath;
|
||||
$requirements = $action['requirements'] ?? [];
|
||||
$route = new Route($path, $defaults, $requirements);
|
||||
$route->setMethods([Request::METHOD_POST]);
|
||||
|
Reference in New Issue
Block a user