Skip to content

Commit

Permalink
refactor: Improve the code quality
Browse files Browse the repository at this point in the history
Signed-off-by: provokateurin <[email protected]>
  • Loading branch information
provokateurin committed Nov 12, 2024
1 parent feaedf2 commit f604bd8
Show file tree
Hide file tree
Showing 7 changed files with 54 additions and 63 deletions.
58 changes: 27 additions & 31 deletions generate-spec.php
Original file line number Diff line number Diff line change
Expand Up @@ -84,11 +84,7 @@

$appIsCore = false;
$appID = (string)$xml->id;
if ($xml->namespace) {
$readableAppID = (string)$xml->namespace;
} else {
$readableAppID = Helpers::generateReadableAppID($appID);
}
$readableAppID = $xml->namespace ? (string)$xml->namespace : Helpers::generateReadableAppID($appID);
$appSummary = (string)$xml->summary;
$appVersion = (string)$xml->version;
$appLicence = (string)$xml->licence;
Expand Down Expand Up @@ -182,8 +178,8 @@
* @var Class_ $node
*/
foreach ($nodeFinder->findInstanceOf($astParser->parse(file_get_contents($path)), Class_::class) as $node) {
$implementsCapability = count(array_filter($node->implements, fn (Name $name): bool => $name->getLast() == 'ICapability')) > 0;
$implementsPublicCapability = count(array_filter($node->implements, fn (Name $name): bool => $name->getLast() == 'IPublicCapability')) > 0;
$implementsCapability = array_filter($node->implements, fn (Name $name): bool => $name->getLast() === 'ICapability') !== [];
$implementsPublicCapability = array_filter($node->implements, fn (Name $name): bool => $name->getLast() === 'IPublicCapability') !== [];
if (!$implementsCapability && !$implementsPublicCapability) {
continue;
}
Expand Down Expand Up @@ -327,7 +323,7 @@
}
}

if (count($parsedRoutes) === 0) {
if ($parsedRoutes === []) {
Logger::warning('Routes', 'No routes were loaded');
}

Expand All @@ -344,7 +340,7 @@
foreach ($value as $route) {
$routeName = $route['name'];

$postfix = array_key_exists('postfix', $route) ? $route['postfix'] : null;
$postfix = $route['postfix'] ?? null;
$verb = array_key_exists('verb', $route) ? $route['verb'] : 'GET';
$requirements = array_key_exists('requirements', $route) ? $route['requirements'] : [];
$defaults = array_key_exists('defaults', $route) ? $route['defaults'] : [];
Expand All @@ -364,7 +360,7 @@
}

$methodName = lcfirst(str_replace('_', '', ucwords(explode('#', (string)$routeName)[1], '_')));
if ($methodName == 'preflightedCors') {
if ($methodName === 'preflightedCors') {
continue;
}

Expand All @@ -384,7 +380,7 @@

$controllerScopes = Helpers::getOpenAPIAttributeScopes($controllerClass, $routeName);
if (Helpers::classMethodHasAnnotationOrAttribute($controllerClass, 'IgnoreOpenAPI')) {
if (count($controllerScopes) === 0 || (in_array('ignore', $controllerScopes, true) && count($controllerScopes) === 1)) {
if ($controllerScopes === [] || (in_array('ignore', $controllerScopes, true) && count($controllerScopes) === 1)) {
Logger::debug($routeName, "Controller '" . $controllerName . "' ignored because of IgnoreOpenAPI attribute");
continue;
}
Expand All @@ -403,24 +399,24 @@

$tagName = implode('_', array_map(fn (string $s) => strtolower($s), Helpers::splitOnUppercaseFollowedByNonUppercase($controllerName)));
$doc = $controllerClass->getDocComment()?->getText();
if ($doc != null && count(array_filter($tags, fn (array $tag): bool => $tag['name'] == $tagName)) == 0) {
if ($doc != null && count(array_filter($tags, fn (array $tag): bool => $tag['name'] === $tagName)) == 0) {
$classDescription = [];

$docNodes = $phpDocParser->parse(new TokenIterator($lexer->tokenize($doc)))->children;
foreach ($docNodes as $docNode) {
if ($docNode instanceof PhpDocTextNode) {
$block = Helpers::cleanDocComment($docNode->text);
if ($block == '') {
if ($block === '') {
continue;
}
$classDescription[] = $block;
}
}

if (count($classDescription) > 0) {
if ($classDescription !== []) {
$tags[] = [
'name' => $tagName,
'description' => join("\n", $classDescription),
'description' => implode("\n", $classDescription),
];
}
}
Expand Down Expand Up @@ -448,7 +444,7 @@
$scopes = Helpers::getOpenAPIAttributeScopes($classMethod, $routeName);

if ($isIgnored) {
if (count($scopes) === 0 || (in_array('ignore', $scopes, true) && count($scopes) === 1)) {
if ($scopes === [] || (in_array('ignore', $scopes, true) && count($scopes) === 1)) {
Logger::debug($routeName, 'Route ignored because of IgnoreOpenAPI attribute');
continue;
}
Expand Down Expand Up @@ -497,7 +493,7 @@
}

$classMethodInfo = ControllerMethod::parse($routeName, $definitions, $methodFunction, $isAdmin, $isDeprecated, $isPasswordConfirmation);
if (count($classMethodInfo->returns) > 0) {
if ($classMethodInfo->returns !== []) {
Logger::error($routeName, 'Returns an invalid response');
continue;
}
Expand All @@ -521,7 +517,7 @@
$docStatusCodes = array_map(fn (ControllerMethodResponse $response): int => $response->statusCode, array_filter($classMethodInfo->responses, fn (?ControllerMethodResponse $response): bool => $response != null));
$missingDocStatusCodes = array_unique(array_filter(array_diff($codeStatusCodes, $docStatusCodes), fn (int $code): bool => $code < 500));

if (count($missingDocStatusCodes) > 0) {
if ($missingDocStatusCodes !== []) {
Logger::error($routeName, 'Returns undocumented status codes: ' . implode(', ', $missingDocStatusCodes));
continue;
}
Expand Down Expand Up @@ -587,7 +583,7 @@

foreach ($urlParameters as $urlParameter) {
$matchingParameters = array_filter($route->controllerMethod->parameters, fn (ControllerMethodParameter $param): bool => $param->name == $urlParameter);
$requirement = array_key_exists($urlParameter, $route->requirements) ? $route->requirements[$urlParameter] : null;
$requirement = $route->requirements[$urlParameter] ?? null;
if (count($matchingParameters) == 1) {
$parameter = $matchingParameters[array_keys($matchingParameters)[0]];
if ($parameter?->methodParameter == null && ($route->requirements == null || !array_key_exists($urlParameter, $route->requirements))) {
Expand All @@ -609,7 +605,7 @@
$requirement = '^' . $requirement;
}
if (!str_ends_with((string)$requirement, '$')) {
$requirement = $requirement . '$';
$requirement .= '$';
}
}

Expand Down Expand Up @@ -671,7 +667,7 @@

$mergedResponses = [];
foreach (array_unique(array_map(fn (ControllerMethodResponse $response): int => $response->statusCode, array_filter($route->controllerMethod->responses, fn (?ControllerMethodResponse $response): bool => $response != null))) as $statusCode) {
if ($firstStatusCode && count($mergedResponses) > 0) {
if ($firstStatusCode && $mergedResponses !== []) {
break;
}

Expand All @@ -685,14 +681,14 @@

$mergedContentTypeResponses = [];
foreach (array_unique(array_map(fn (ControllerMethodResponse $response): ?string => $response->contentType, array_filter($statusCodeResponses, fn (ControllerMethodResponse $response): bool => $response->contentType != null))) as $contentType) {
if ($firstContentType && count($mergedContentTypeResponses) > 0) {
if ($firstContentType && $mergedContentTypeResponses !== []) {
break;
}

/** @var ControllerMethodResponse[] $contentTypeResponses */
$contentTypeResponses = array_values(array_filter($statusCodeResponses, fn (ControllerMethodResponse $response): bool => $response->contentType == $contentType));

$hasEmpty = count(array_filter($contentTypeResponses, fn (ControllerMethodResponse $response): bool => $response->type == null)) > 0;
$hasEmpty = array_filter($contentTypeResponses, fn (ControllerMethodResponse $response): bool => $response->type == null) !== [];
$uniqueResponses = array_values(array_intersect_key($contentTypeResponses, array_unique(array_map(fn (ControllerMethodResponse $response): array|\stdClass => $response->type->toArray(), array_filter($contentTypeResponses, fn (ControllerMethodResponse $response): bool => $response->type != null)), SORT_REGULAR)));
if (count($uniqueResponses) == 1) {
if ($hasEmpty) {
Expand All @@ -716,7 +712,7 @@
$response = [
'description' => array_key_exists($statusCode, $route->controllerMethod->responseDescription) ? $route->controllerMethod->responseDescription[$statusCode] : '',
];
if (count($headers) > 0) {
if ($headers !== []) {
$response['headers'] = array_combine(
array_keys($headers),
array_map(
Expand All @@ -727,7 +723,7 @@
),
);
}
if (count($mergedContentTypeResponses) > 0) {
if ($mergedContentTypeResponses !== []) {
$response['content'] = $mergedContentTypeResponses;
}
$mergedResponses[$statusCode] = $response;
Expand All @@ -751,7 +747,7 @@
if ($route->controllerMethod->summary !== null) {
$operation['summary'] = $route->controllerMethod->summary;
}
if (count($route->controllerMethod->description) > 0) {
if ($route->controllerMethod->description !== []) {
$operation['description'] = implode("\n", $route->controllerMethod->description);
}
if ($route->controllerMethod->isDeprecated) {
Expand All @@ -762,7 +758,7 @@
}
$operation['security'] = $security;

if (count($bodyParameters) > 0) {
if ($bodyParameters !== []) {
$requiredBodyParameters = [];

foreach ($bodyParameters as $bodyParameter) {
Expand All @@ -772,7 +768,7 @@
}
}

$required = count($requiredBodyParameters) > 0;
$required = $requiredBodyParameters !== [];

$schema = [
'type' => 'object',
Expand Down Expand Up @@ -823,7 +819,7 @@
],
];
}
if (count($parameters) > 0) {
if ($parameters !== []) {
$operation['parameters'] = $parameters;
}

Expand Down Expand Up @@ -919,7 +915,7 @@

if (!$hasSingleScope) {
$scopePaths['full'] = [];
} elseif (count($scopePaths) === 0) {
} elseif ($scopePaths === []) {
if (isset($schemas['Capabilities']) || isset($schemas['PublicCapabilities'])) {
Logger::debug('app', 'Generating default scope without routes to populate capabilities');
$scopePaths['default'] = [];
Expand Down Expand Up @@ -988,7 +984,7 @@
$scopedSchemas['PublicCapabilities'] = $schemas['PublicCapabilities'];
}

if (count($scopedSchemas) === 0) {
if ($scopedSchemas === []) {
$scopedSchemas = new stdClass();
} else {
ksort($scopedSchemas);
Expand Down
5 changes: 3 additions & 2 deletions merge-specs.php
Original file line number Diff line number Diff line change
Expand Up @@ -129,7 +129,7 @@ function rewriteSchemaNames(array $spec): array {
$schemas = $spec['components']['schemas'];
$readableAppID = Helpers::generateReadableAppID($spec['info']['title']);
return array_combine(
array_map(fn (string $key): string => $key == 'OCSMeta' ? $key : $readableAppID . $key, array_keys($schemas)),
array_map(fn (string $key): string => $key === 'OCSMeta' ? $key : $readableAppID . $key, array_keys($schemas)),
array_values($schemas),
);
}
Expand Down Expand Up @@ -164,7 +164,8 @@ function rewriteOperations(array $spec): array {
$operation['responses'] = [$value => $operation['responses'][$value]];
}
if (array_key_exists('security', $operation)) {
for ($i = 0; $i < count($operation['security']); $i++) {
$counter = count($operation['security']);
for ($i = 0; $i < $counter; $i++) {
if (count($operation['security'][$i]) == 0) {
$operation['security'][$i] = new stdClass(); // When reading {} will be converted to [], so we have to fix it
}
Expand Down
1 change: 1 addition & 0 deletions rector.php
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
->withPhpSets()
->withPreparedSets(
deadCode: true,
codeQuality: true,
typeDeclarations: true,
strictBooleans: true,
);
15 changes: 8 additions & 7 deletions src/ControllerMethod.php
Original file line number Diff line number Diff line change
Expand Up @@ -54,13 +54,14 @@ public static function parse(string $context, array $definitions, ClassMethod $m
foreach ($docNodes as $docNode) {
if ($docNode instanceof PhpDocTextNode) {
$block = Helpers::cleanDocComment($docNode->text);
if ($block == '') {
if ($block === '') {
continue;
}
$pattern = '/([0-9]{3}): /';
$pattern = '/(\d{3}): /';
if (preg_match($pattern, $block)) {
$parts = preg_split($pattern, $block, -1, PREG_SPLIT_DELIM_CAPTURE | PREG_SPLIT_NO_EMPTY);
for ($i = 0; $i < count($parts); $i += 2) {
$counter = count($parts);
for ($i = 0; $i < $counter; $i += 2) {
$statusCode = intval($parts[$i]);
$responseDescriptions[$statusCode] = trim($parts[$i + 1]);
}
Expand Down Expand Up @@ -109,7 +110,7 @@ public static function parse(string $context, array $definitions, ClassMethod $m

if (!$allowMissingDocs) {
foreach (array_unique(array_map(fn (ControllerMethodResponse $response): int => $response->statusCode, array_filter($responses, fn (?ControllerMethodResponse $response): bool => $response != null))) as $statusCode) {
if ($statusCode < 500 && (!array_key_exists($statusCode, $responseDescriptions) || $responseDescriptions[$statusCode] == '')) {
if ($statusCode < 500 && (!array_key_exists($statusCode, $responseDescriptions) || $responseDescriptions[$statusCode] === '')) {
Logger::error($context, 'Missing description for status code ' . $statusCode);
}
}
Expand All @@ -136,7 +137,7 @@ public static function parse(string $context, array $definitions, ClassMethod $m
}
}

if ($paramTag !== null && $psalmParamTag !== null) {
if ($paramTag instanceof \PHPStan\PhpDocParser\Ast\PhpDoc\ParamTagValueNode && $psalmParamTag instanceof \PHPStan\PhpDocParser\Ast\PhpDoc\ParamTagValueNode) {
// Use all the type information from @psalm-param because it is more specific,
// but pull the description from @param and @psalm-param because usually only one of them has it.
if ($psalmParamTag->description !== '') {
Expand Down Expand Up @@ -176,10 +177,10 @@ public static function parse(string $context, array $definitions, ClassMethod $m
}

$param = new ControllerMethodParameter($context, $definitions, $methodParameterName, $methodParameter, $type);
} elseif ($psalmParamTag !== null) {
} elseif ($psalmParamTag instanceof \PHPStan\PhpDocParser\Ast\PhpDoc\ParamTagValueNode) {
$type = OpenApiType::resolve($context . ': @param: ' . $methodParameterName, $definitions, $psalmParamTag);
$param = new ControllerMethodParameter($context, $definitions, $methodParameterName, $methodParameter, $type);
} elseif ($paramTag !== null) {
} elseif ($paramTag instanceof \PHPStan\PhpDocParser\Ast\PhpDoc\ParamTagValueNode) {
$type = OpenApiType::resolve($context . ': @param: ' . $methodParameterName, $definitions, $paramTag);
$param = new ControllerMethodParameter($context, $definitions, $methodParameterName, $methodParameter, $type);
} elseif ($allowMissingDocs) {
Expand Down
6 changes: 3 additions & 3 deletions src/Helpers.php
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,7 @@ public static function mergeSchemas(array $schemas): mixed {
if (!in_array(true, array_map(fn ($schema): bool => is_array($schema), $schemas))) {
$results = array_values(array_unique($schemas));
if (count($results) > 1) {
throw new Exception('Incompatibles types: ' . join(', ', $results));
throw new Exception('Incompatibles types: ' . implode(', ', $results));
}
return $results[0];
}
Expand Down Expand Up @@ -205,7 +205,7 @@ public static function getOpenAPIAttributeScopes(ClassMethod|Class_|Node $node,
foreach ($node->attrGroups as $attrGroup) {
foreach ($attrGroup->attrs as $attr) {
if ($attr->name->getLast() === self::OPENAPI_ATTRIBUTE_CLASSNAME) {
if (empty($attr->args)) {
if ($attr->args === []) {
$scopes[] = 'default';
continue;
}
Expand All @@ -230,7 +230,7 @@ public static function getOpenAPIAttributeTagsByScope(ClassMethod|Class_|Node $n
foreach ($node->attrGroups as $attrGroup) {
foreach ($attrGroup->attrs as $attr) {
if ($attr->name->getLast() === self::OPENAPI_ATTRIBUTE_CLASSNAME) {
if (empty($attr->args)) {
if ($attr->args === []) {
$tags[$defaultScope] = [$defaultTag];
continue;
}
Expand Down
Loading

0 comments on commit f604bd8

Please sign in to comment.